Traffic management

    When you create a Knative Service, it does not have any default traffic spec settings. By setting the traffic spec, you can split traffic over any number of fixed Revisions, or send traffic to the latest Revision by setting latestRevision: true in the spec for a Service.

    In the following example, the spec defines an attribute called tag:

    When a tag attribute is applied to a Route, an address for the specific traffic target is created.

    In this example, you can access the staging target by accessing staging-<route name>.<namespace>.<domain>. The targets for example-service-2 and example-service-3 can only be accessed using the main route, <route name>.<namespace>.<domain>.

    When a traffic target is tagged, a new Kubernetes Service is created for that Service, so that other Services can access it within the cluster. From the previous example, a new Kubernetes Service called staging-<route name> will be created in the same namespace. This Service has the ability to override the visibility of this specific Route by applying the label networking.knative.dev/visibility with value cluster-local. See the documentation on for more information about how to restrict visibility on specific Routes.

    The following example shows a traffic spec where 100% of traffic is routed to the latestRevision of the Service. Under status you can see the name of the latest Revision that latestRevision was resolved to:

    1. apiVersion: serving.knative.dev/v1
    2. kind: Service
    3. metadata:
    4. name: example-service
    5. namespace: default
    6. spec:
    7. ...
    8. traffic:
    9. - latestRevision: true
    10. percent: 100
    11. status:
    12. ...
    13. traffic:
    14. - percent: 100
    15. revisionName: example-service-1

    The following example shows a traffic spec where 100% of traffic is routed to the current Revision, and the name of that Revision is specified as example-service-1. The latest ready Revision is kept available, even though no traffic is being routed to it:

    1. apiVersion: serving.knative.dev/v1
    2. kind: Service
    3. metadata:
    4. name: example-service
    5. namespace: default
    6. spec:
    7. ...
    8. traffic:
    9. - tag: current
    10. percent: 100
    11. - tag: latest
    12. latestRevision: true
    13. percent: 0

    The following example shows how the list of Revisions in the traffic spec can be extended so that traffic is split between multiple Revisions. This example sends 50% of traffic to the current Revision, example-service-1, and 50% of traffic to the candidate Revision, example-service-2:

    1. apiVersion: serving.knative.dev/v1
    2. metadata:
    3. name: example-service
    4. namespace: default
    5. spec:
    6. ...
    7. traffic:
    8. - tag: current
    9. revisionName: example-service-1
    10. percent: 50
    11. - tag: candidate
    12. revisionName: example-service-2
    13. percent: 50
    14. - tag: latest
    15. latestRevision: true
    16. percent: 0

    You can use the following kn CLI command to split traffic between revisions:

    1. kn service update <service-name> --traffic <revision-name>=<percent>

    Where:

    • <service-name> is the name of the Knative Service that you are configuring traffic routing for.
    • <revision-name> is the name of the revision that you want to configure to receive a percentage of traffic.
    • <percent> is the percentage of traffic that you want to send to the revision specified by <revision-name>.

    For example, to split traffic for a Service named example, by sending 80% of traffic to the Revision green and 20% of traffic to the Revision blue, you could run the following command:

    It is also possible to add tags to Revisions and then split traffic according to the tags you have set:

    1. kn service update example --tag revision-0001=green --tag @latest=blue
    1. kn service update example-service --traffic @latest=80 --traffic v1=20

    You can safely reroute traffic from a live version of an application to a new version by using a .

    1. Create and deploy an app as a Knative Service.
    2. Find the name of the first Revision that was created when you deployed the Service, by running the command:

      1. kubectl get configurations <service-name> -o=jsonpath='{.status.latestCreatedRevisionName}'

      Where <service-name> is the name of the Service that you have deployed.

    3. Define a Route to send inbound traffic to the Revision.

      Example Route

      1. apiVersion: serving.knative.dev/v1
      2. metadata:
      3. name: <route-name>
      4. namespace: default
      5. spec:
      6. traffic:
      7. - revisionName: <first-revision-name>
      8. percent: 100 # All traffic goes to this revision

      Where;

      • <route-name> is the name you choose for your route.
    4. Verify that you can view your app at the URL output you get from using the following command:

      Where <route-name> is the name of the Route you created in the previous step.

    5. Deploy a second Revision of your app by modifying at least one field in the template spec of the Service resource. For example, you can modify the image of the Service, or an env environment variable.

    6. Redeploy the Service by applying the updated Service resource. You can do this by applying the Service YAML file or by using the kn service update command if you have installed the kn CLI.

    7. Find the name of the second, latest Revision that was created when you redeployed the Service, by running the command:

      1. kubectl get configurations <service-name> -o=jsonpath='{.status.latestCreatedRevisionName}'

      Where <service-name> is the name of the Service that you have redeployed.

    8. Update your existing Route to create a new, test endpoint for the second Revision, while still sending all other traffic to the first Revision.

      Example of updated Route

      1. apiVersion: serving.knative.dev/v1
      2. kind: Route
      3. metadata:
      4. name: <route-name>
      5. namespace: default
      6. spec:
      7. traffic:
      8. - revisionName: <first-revision-name>
      9. percent: 100 # All traffic is still being routed to the first revision
      10. - revisionName: <second-revision-name>
      11. percent: 0 # 0% of traffic routed to the second revision
      12. tag: v2 # A named route

      Once you redeploy this Route by reapplying the YAML resource, the second Revision of the app is now staged.

      No traffic is routed to the second Revision at the main URL, and Knative creates a new Route named v2 for testing the newly deployed Revision.

    9. Get the URL of the new Route for the second Revision, by running the command:

      1. kubectl get route <route-name> --output jsonpath="{.status.traffic[*].url}"

      You can use this URL to validate that the new version of the app is behaving as expected before you route any traffic to it.

    10. Update your existing Route resource again, so that 50% of traffic is being sent to the first Revision, and 50% is being sent to the second Revision:

      Example of updated Route

      1. apiVersion: serving.knative.dev/v1
      2. kind: Route
      3. metadata:
      4. name: <route-name>
      5. namespace: default
      6. spec:
      7. traffic:
      8. - revisionName: <first-revision-name>
      9. percent: 50
      10. - revisionName: <second-revision-name>
      11. percent: 50
      12. tag: v2
    11. Once you are ready to route all traffic to the new version of the app, update the Route again to send 100% of traffic to the second Revision:

      Example of updated Route

      Tip

      You can remove the first Revision instead of setting it to 0% of traffic if you do not plan to roll back the Revision. Non-routeable Revision objects are then garbage-collected.