Skip to content

Latest commit

 

History

History
72 lines (56 loc) · 2.19 KB

README.md

File metadata and controls

72 lines (56 loc) · 2.19 KB

Rust Events Function

Welcome to your new Rust function project! The boilerplate actix web server is in src/main.rs. It's configured to invoke the handle function in src/handler.rs in response to a POST request containing a valid CloudEvent. You should put your desired behavior inside that handle function. In case you need to configure some resources for your function, you can do that in the configure function.

The app will expose three endpoints:

  • / Triggers the handle function for a POST method
  • /health/readiness The endpoint for a readiness health check
  • /health/liveness The endpoint for a liveness health check

You may use any of the available actix features to fulfill the requests at those endpoints.

Development

This is a fully self-contained application, so you can develop it as you would any other Rust application, e.g.

cargo build
cargo test
cargo run

Once running, the function is available at http://localhost:8080 and the health checks are at http://localhost:8080/health/readiness and http://localhost:8080/health/liveness. To POST an event to the function, a utility such as curl may be used:

curl -v -d '{"name": "Bootsy"}' \
  -H'content-type: application/json' \
  -H'ce-specversion: 1.0' \
  -H'ce-id: 1' \
  -H'ce-source: http://cloudevents.io' \
  -H'ce-type: dev.knative.example' \
  http://localhost:8080

Deployment

Use func to containerize your application, publish it to a registry and deploy it as a Knative Service in your Kubernetes cluster:

func deploy --registry=docker.io/<YOUR_ACCOUNT>

You can omit the --registry option by setting the FUNC_REGISTRY environment variable. And if you forget, you'll be prompted.

The output from a successful deploy should show the URL for the service, which you can also get via func describe, e.g.

curl -v -d '{"name": "Bootsy"}' \
  -H'content-type: application/json' \
  -H'ce-specversion: 1.0' \
  -H'ce-id: 1' \
  -H'ce-source: http://cloudevents.io' \
  -H'ce-type: dev.knative.example' \
  $(func describe -o url)

Have fun!