Skip to content

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

Notifications You must be signed in to change notification settings

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

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Function project

Welcome to your new Quarkus function project!

This sample project contains a single function: functions.Function.function(), the function just returns its argument.

Local execution

Make sure that Java 11 SDK is installed.

To start server locally run ./mvnw quarkus:dev. The command starts http server and automatically watches for changes of source code. If source code changes the change will be propagated to running server. It also opens debugging port 5005 so debugger can be attached if needed.

To run test locally run ./mvnw test.

The func CLI

It's recommended to set FUNC_REGISTRY environment variable.

# replace ~/.bashrc by your shell rc file
# replace docker.io/johndoe with your registry
export FUNC_REGISTRY=docker.io/johndoe
echo "export FUNC_REGISTRY=docker.io/johndoe" >> ~/.bashrc 

Building

This command builds OCI image for the function.

func build

By default, JVM build is used. To enable native build set following environment variables to func.yaml:

buildEnvs:
  - name: BP_NATIVE_IMAGE
    value: "true"
  - name: BP_MAVEN_BUILT_ARTIFACT
    value: func.yaml target/native-sources/*
  - name: BP_MAVEN_BUILD_ARGUMENTS
    value: package -DskipTests=true -Dmaven.javadoc.skip=true -Dquarkus.package.type=native-sources
  - name: BP_NATIVE_IMAGE_BUILD_ARGUMENTS_FILE
    value: native-image.args
  - name: BP_NATIVE_IMAGE_BUILT_ARTIFACT
    value: '*-runner.jar'

Running

This command runs the function locally in a container using the image created above.

func run

Deploying

This commands will build and deploy the function into cluster.

func deploy # also triggers build

Function invocation

Do not forget to set URL variable to the route of your function.

You get the route by following command.

func info

cURL

URL=http://localhost:8080/
curl -v ${URL} \
  -H "Content-Type:application/json" \
  -H "Ce-Id:1" \
  -H "Ce-Source:cloud-event-example" \
  -H "Ce-Type:dev.knative.example" \
  -H "Ce-Specversion:1.0" \
  -d "{\"message\": \"$(whoami)\"}\""

HTTPie

URL=http://localhost:8080/
http -v ${URL} \
  Content-Type:application/json \
  Ce-Id:1 \
  Ce-Source:cloud-event-example \
  Ce-Type:dev.knative.example \
  Ce-Specversion:1.0 \
  message=$(whoami)

About

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

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages