Sequence terminal

    The functions used in these examples live in https://github.com/knative/eventing-contrib/blob/master/cmd/appender/main.go.

    For this example, we’ll assume you have set up an InMemoryChannel as well as Knative Serving (for our functions). The examples use default namespace, again, if you want to deploy to another Namespace, you will need to modify the examples to reflect this.

    If you want to use different type of Channel, you will have to modify the Sequence.Spec.ChannelTemplate to create the appropriate Channel resources.

    Setup

    1. kubectl -n default create -f ./steps.yaml

    The sequence.yaml file contains the specifications for creating the Sequence. If you are using a different type of Channel, you need to change the spec.channelTemplate to point to your desired Channel.

    1. apiVersion: flows.knative.dev/v1beta1
    2. kind: Sequence
    3. metadata:
    4. name: sequence
    5. spec:
    6. channelTemplate:
    7. apiVersion: messaging.knative.dev/v1beta1
    8. kind: InMemoryChannel
    9. steps:
    10. - ref:
    11. kind: Service
    12. name: first
    13. - ref:
    14. kind: Service
    15. name: second
    16. - ref:
    17. apiVersion: serving.knative.dev/v1
    18. kind: Service
    19. name: third

    Change default below to create the Sequence in the Namespace where you want the resources to be created.

    This will create a PingSource which will send a CloudEvent with {"message": "Hello world!"} as the data payload every 2 minutes.

    1. apiVersion: sources.knative.dev/v1alpha2
    2. kind: PingSource
    3. metadata:
    4. name: ping-source
    5. spec:
    6. schedule: "*/2 * * * *"
    7. jsonData: '{"message": "Hello world!"}'
    8. ref:
    9. apiVersion: flows.knative.dev/v1beta1
    10. kind: Sequence

    Here, if you are using different type of Channel, you need to change the spec.channelTemplate to point to your desired Channel.

    1. kubectl -n default create -f ./ping-source.yaml

    Let’s look at the logs for the first Step in the Sequence:

    1. kubectl -n default logs -l serving.knative.dev/service=first -c user-container --tail=-1
    2. 2020/03/02 21:28:00 listening on 8080, appending " - Handled by 0" to events
    3. 2020/03/02 21:28:01 Received a new event:
    4. 2020/03/02 21:28:01 [2020-03-02T21:28:00.0010247Z] /apis/v1/namespaces/default/pingsources/ping-source dev.knative.sources.ping: &{Sequence:0 Message:Hello world!}
    5. 2020/03/02 21:28:01 Transform the event to:
    6. 2020/03/02 21:28:01 [2020-03-02T21:28:00.0010247Z] /apis/v1/namespaces/default/pingsources/ping-source dev.knative.sources.ping: &{Sequence:0 Message:Hello world! - Handled by 0}

    Then we can look at the output of the second Step in the Sequence:

    1. kubectl -n default logs -l serving.knative.dev/service=second -c user-container --tail=-1
    2. 2020/03/02 21:28:02 listening on 8080, appending " - Handled by 1" to events
    3. 2020/03/02 21:28:02 Received a new event:
    4. 2020/03/02 21:28:02 [2020-03-02T21:28:00.0010247Z] /apis/v1/namespaces/default/pingsources/ping-source dev.knative.sources.ping: &{Sequence:0 Message:Hello world! - Handled by 0}
    5. 2020/03/02 21:28:02 [2020-03-02T21:28:00.0010247Z] /apis/v1/namespaces/default/pingsources/ping-source dev.knative.sources.ping: &{Sequence:0 Message:Hello world! - Handled by 0 - Handled by 1}

    And you can see that the initial PingSource message ("Hello World!") has now been modified by the first step in the Sequence to include “ - Handled by 0”. Exciting :)

    Then we can look at the output of the last Step in the :