func/templates/springboot/http
github-actions[bot] a062cd2872
chore: update Springboot platform version to 3.4.6 (#2834)
Co-authored-by: Knative Automation <automation@knative.team>
2025-05-22 16:02:30 +00:00
..
.mvn/wrapper Update springboot templates to Spring Boot 3.0.5 (#1658) 2023-03-30 21:53:00 +00:00
src chore: update CA bundle (#2415) 2024-07-09 07:45:09 +00:00
.editorconfig feat: add spring cloud function runtime and templates (#231) 2020-11-25 12:15:48 -05:00
.gitignore feat: add spring cloud function runtime and templates (#231) 2020-11-25 12:15:48 -05:00
README.md chore: update maven profile buildEnv in springboot templates (#2014) 2023-10-18 19:32:51 +00:00
mvnw feat: add spring cloud function runtime and templates (#231) 2020-11-25 12:15:48 -05:00
mvnw.cmd feat: add spring cloud function runtime and templates (#231) 2020-11-25 12:15:48 -05:00
pom.xml chore: update Springboot platform version to 3.4.6 (#2834) 2025-05-22 16:02:30 +00:00

README.md

Function project

Welcome to your new Function project!

This sample project contains a single function based on Spring Cloud Function: functions.CloudFunctionApplication.echo(), which returns an echo of the data passed via HTTP request.

Local execution

Make sure that Java 17 SDK is installed since Spring Boot 3.0 requires Java 17.

To start server locally run ./mvnw spring-boot:run. 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 a debugger can be attached if needed.

To run tests 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 an OCI image for the function. By default, this will build a JVM image.

func build -v                  # build image

Note: If you want to enable the native build, you need to edit the func.yaml file and set the BP_NATIVE_IMAGE BuilderEnv variable to true:

buildEnvs:
  - name: BP_NATIVE_IMAGE
    value: "true"

Note: If you have issues with the Spring AOT processing in your build, you can turn this off by editing the func.yaml file and removing the BP_MAVEN_ACTIVE_PROFILES buildEnvs entry.

Removing the native profile means that you no longer will be able to build as a native image.

Running

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

func run

Deploying

This command will build and deploy the function into cluster.

func deploy -v # also triggers build

For ARM processor based systems

Building Spring Boot apps with Paketo Buildpacks on an ARM processor based system, like an Apple Macbook with an M1 or M2 chip, is not fully supported at the moment. There is work in progress to fix this, you can follow the Support ARM #435 issue. You can also join the #arm channel in the paketo slack (join at: https://slack.paketo.io/) to follow progress on this topic

To work around the multiarch limitation you can build the image on your local system using a community contributed multiarch builder that produces images for the arm64 arch.

You need to provide the --builder-image argument using dashaun/builder:tiny as the builder.

func build -v --builder-image dashaun/builder:tiny
func deploy --build=false

Note: This assumes that you are targeting a cluster that supports arm64 based images which would be the case if you ran a kind cluster on your local Mac system.

Function invocation

For the examples below, please be sure to set the URL variable to the route of your function.

You get the route by following command.

func info

Note the value of Routes: from the output, set $URL to its value.

TIP:

If you use kn then you can set the url by:

# kn service describe <function name> and show route url
export URL=$(kn service describe $(basename $PWD) -ourl)

func

Using func invoke command with Path-Based routing:

func invoke --target "$URL/echo" --data "$(whoami)"

If your function class only contains one function, then you can leave out the target path:

func invoke --data "$(whoami)"

cURL

curl -v "$URL/echo" \
  -H "Content-Type:text/plain" \
  -w "\n" \
  -d "$(whoami)"

If your function class only contains one function, then you can leave out the target path:

curl -v "$URL" \
  -H "Content-Type:text/plain" \
  -w "\n" \
  -d "$(whoami)"

HTTPie

echo "$(whoami)" | http -v "$URL/echo"

If your function class only contains one function, then you can leave out the target path:

echo "$(whoami)" | http -v "$URL"

Cleanup

To clean the deployed function run:

func delete