# runs linkerd in a daemonset, in linker-to-linker mode --- apiVersion: v1 kind: ConfigMap metadata: name: l5d-config data: config.yaml: |- admin: ip: 0.0.0.0 port: 9990 namers: - kind: io.l5d.k8s # This namer has the daemonset transformer "built-in" prefix: /io.l5d.k8s.ds # We reference this in the outgoing router's dtab transformers: - kind: io.l5d.k8s.daemonset namespace: default port: incoming service: l5d - kind: io.l5d.k8s # The "basic" k8s namer. We reference this in the incoming router's dtab telemetry: - kind: io.l5d.prometheus - kind: io.l5d.recentRequests sampleRate: 0.25 usage: orgId: linkerd-examples-daemonset-egress routers: - protocol: http label: outgoing dtab: | /ph => /$/io.buoyant.rinet ; # Lookup the name in DNS /srv => /ph/80 ; # Use port 80 if unspecified /srv => /$/io.buoyant.porthostPfx/ph ; # Attempt to extract the port from the hostname /srv => /#/io.l5d.k8s.ds/default/http ; # Lookup the name in Kubernetes, use the linkerd daemonset pod /svc => /srv ; /svc/world => /srv/world-v1 ; servers: - port: 4140 ip: 0.0.0.0 service: responseClassifier: kind: io.l5d.http.retryableRead5XX client: kind: io.l5d.static configs: - prefix: "/$/io.buoyant.rinet/443/{service}" tls: commonName: "{service}" - protocol: http label: incoming dtab: | /srv => /#/io.l5d.k8s/default/http; /host => /srv; /svc => /host; /host/world => /srv/world-v1; interpreter: kind: default transformers: - kind: io.l5d.k8s.localnode servers: - port: 4141 ip: 0.0.0.0 --- apiVersion: extensions/v1beta1 kind: DaemonSet metadata: labels: app: l5d name: l5d spec: template: metadata: labels: app: l5d spec: volumes: - name: l5d-config configMap: name: "l5d-config" containers: - name: l5d image: buoyantio/linkerd:1.4.6 env: - name: POD_IP valueFrom: fieldRef: fieldPath: status.podIP args: - /io.buoyant/linkerd/config/config.yaml ports: - name: outgoing containerPort: 4140 hostPort: 4140 - name: incoming containerPort: 4141 - name: admin containerPort: 9990 volumeMounts: - name: "l5d-config" mountPath: "/io.buoyant/linkerd/config" readOnly: true - name: kubectl image: buoyantio/kubectl:v1.14.3 args: - "proxy" - "-p" - "8001" --- apiVersion: v1 kind: Service metadata: name: l5d spec: selector: app: l5d type: LoadBalancer ports: - name: outgoing port: 4140 - name: incoming port: 4141 - name: admin port: 9990