apiVersion:traefik.containo.us/v1alpha1kind:TraefikServicemetadata: name:wrr2 namespace:defaultspec: weighted: services: - name:s1 weight:1 port:80# Optional, as it is the default value kind:Service - name:s3 weight:1 port:80---apiVersion:traefik.containo.us/v1alpha1kind:TraefikServicemetadata: name:wrr1 namespace:defaultspec: weighted: services: - name:wrr2 kind:TraefikService weight:1 - name:s3 weight:1 port:80---apiVersion:traefik.containo.us/v1alpha1kind:TraefikServicemetadata: name:mirror1 namespace:defaultspec: mirroring: name:s1 port:80 mirrors: - name:s3 percent:20 port:80 - name:mirror2 kind:TraefikService percent:20---apiVersion:traefik.containo.us/v1alpha1kind:TraefikServicemetadata: name:mirror2 namespace:defaultspec: mirroring: name:wrr2 kind:TraefikService mirrors: - name:s2# Optional, as it is the default value kind:Service percent:20 port:80---apiVersion:traefik.containo.us/v1alpha1kind:IngressRoutemetadata: name:ingressroutespec: entryPoints: -web -websecure routes: - match:Host(`foo.com`)&&PathPrefix(`/bar`) kind:Rule priority:12# defining several services is possible and allowed, but for now the servers of# all the services (for a given route) get merged altogether under the same# load-balancing strategy. services: - name:s1 port:80 healthCheck: path:/health host:baz.com intervalSeconds:7 timeoutSeconds:60# strategy defines the load balancing strategy between the servers. It defaults# to Round Robin, and for now only Round Robin is supported anyway. strategy:RoundRobin - name:s2 port:433 healthCheck: path:/health host:baz.com intervalSeconds:7 timeoutSeconds:60 - match:PathPrefix(`/misc`) services: - name:s3 port:80 middlewares: - name:stripprefix - name:addprefix - match:PathPrefix(`/misc`) services: - name:s3# Optional, as it is the default value kind:Service port:8443# scheme allow to override the scheme for the service. (ex: https or h2c) scheme:https - match:PathPrefix(`/lb`) services: - name:wrr1 kind:TraefikService - match:PathPrefix(`/mirrored`) services: - name:mirror1 kind:TraefikService# use an empty tls object for TLS with Let's Encrypt tls: secretName:supersecret options: name:myTLSOption namespace:default---apiVersion:traefik.containo.us/v1alpha1kind:IngressRouteTCPmetadata: name:ingressroutetcp.crd namespace:defaultspec: entryPoints: -footcp routes: - match:HostSNI(`bar.com`) services: - name:whoamitcp port:8080 tls: secretName:foosecret passthrough:false options: name:myTLSOption namespace:default