Skip to content

Knative func example created with [kn] func create -l rust -t cloudevents

Notifications You must be signed in to change notification settings

openshift-dev-console/kn-func-rust-cloudevents

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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 info, 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 info -o url)

Have fun!

About

Knative func example created with [kn] func create -l rust -t cloudevents

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published