docs/code-samples/serving/cloudevents/cloudevents-vertx
Samia Nneji 4eda564a0b
Move code samples to GitHub (#4565)
* Move samples off site

* Add redirects

* Fix code samples and links

* Change links

* Fix path to sample

* Fix a few more links

* Update samples path in test

* remove unecessary redirect

* update more links

* add closing bracket
2021-12-14 04:20:51 -08:00
..
src/main/java/org/knative/examples/cloudevents/vertx Move code samples to GitHub (#4565) 2021-12-14 04:20:51 -08:00
.gitignore Move code samples to GitHub (#4565) 2021-12-14 04:20:51 -08:00
README.md Move code samples to GitHub (#4565) 2021-12-14 04:20:51 -08:00
pom.xml Move code samples to GitHub (#4565) 2021-12-14 04:20:51 -08:00
service.yaml Move code samples to GitHub (#4565) 2021-12-14 04:20:51 -08:00

README.md

Cloud Events - Java and Vert.x

A simple web app written in Java using Vert.x that can receive CloudEvents. It supports running in two modes:

  1. The default mode has the app reply to your input events with the output event, which is simplest for demonstrating things working in isolation, but is also the model for working for the Knative Eventing Broker concept. The input event is modified assigning a new source and type attribute.

  2. K_SINK mode has the app send events to the destination encoded in $K_SINK, which is useful to demonstrate how folks can synthesize events to send to a Service or Broker when not initiated by a Broker invocation (e.g. implementing an event source). The input event is modified assigning a new source and type attribute.

The application will use $K_SINK-mode whenever the environment variable is specified.

Do the following steps to create the sample code and then deploy the app to your cluster. You can also download a working copy of the sample, by running the following commands:

git clone https://github.com/knative/docs.git knative-docs
cd knative-docs/code-samples/serving/cloudevents/cloudevents-vertx

Before you begin

  • A Kubernetes cluster with Knative installed and DNS configured. See Install Knative Serving.
  • Docker installed and running on your local machine, and a Docker Hub account configured (we'll use it for a container registry).

Build and deploy the sample

To build the image, run:

mvn compile jib:build -Dimage=<image_name>

=== "yaml"

To deploy the Knative Service, look in the `service.yaml` and replace `<image>` with the deployed image name. Then run:

```bash
kubectl apply -f service.yaml
```

=== "kn"

If using `kn` to deploy:

```bash
kn service create cloudevents-vertx --image=<image>
```

Testing the sample

Get the URL for your Service with:

$ kubectl get ksvc
NAME                URL                                            LATESTCREATED             LATESTREADY               READY   REASON
cloudevents-vertx   http://cloudevents-java.sslip.io                 cloudevents-vertx-86h28   cloudevents-vertx-86h28   True

Then send a CloudEvent to it with:

$ curl \
    -X POST -v \
    -H "content-type: application/json"  \
    -H "ce-specversion: 1.0"  \
    -H "ce-source: http://curl-command"  \
    -H "ce-type: curl.demo"  \
    -H "ce-id: 123-abc"  \
    -d '{"name":"Dave"}' \
    http://cloudevents-java.sslip.io

You can also send CloudEvents spawning a temporary curl pod in your cluster with:

$ kubectl run curl \
    --image=curlimages/curl --rm=true --restart=Never -ti -- \
    -X POST -v \
    -H "content-type: application/json"  \
    -H "ce-specversion: 1.0"  \
    -H "ce-source: http://curl-command"  \
    -H "ce-type: curl.demo"  \
    -H "ce-id: 123-abc"  \
    -d '{"name":"Dave"}' \
    http://cloudevents-java.default.svc

You'll see on the console:

> POST / HTTP/1.1
> Host: localhost:8080
> User-Agent: curl/7.69.1
> Accept: */*
> content-type: application/json
> ce-specversion: 1.0
> ce-source: http://curl-command
> ce-type: curl.demo
> ce-id: 123-abc
> Content-Length: 15
>
< HTTP/1.1 202 Accepted
< ce-specversion: 1.0
< ce-id: 123-abc
< ce-source: https://github.com/knative/docs/code-samples/serving/cloudevents/cloudevents-vertx
< ce-type: curl.demo
< content-type: application/json
< content-length: 15
<
{"name":"Dave"}

Removing the sample app deployment

To remove the sample app from your cluster, delete the service:

=== "yaml"

Run:

```bash
kubectl delete --filename service.yaml
```

=== "kn"

Run:

```bash
kn service delete cloudevents-vertx
```