/tap-sample-apps

Primary LanguageStarlarkApache License 2.0Apache-2.0

hello-fun repo

This repo provides a simple Hello web app based on Spring Boot and Spring Cloud Function.

It can be deployed as a standalone web app, as a Tanzu Application Platform workload resource or, as a Kubernetes Deployment and Service.

The code

NOTE: The project is configured for Java 11, if you prefer a different version, then modify the java.version property in pom.xml.

The project contains the following Spring Cloud Function bean definition:

	@Bean
	public Function<String, String> hello() {
		return (in) -> {
			return "Hello " + in;
		};
	}

This simple function returns the input value, prefixed with "Hello ". This is just a simple example what a Spring Cloud Function can do. It is defined in src/main/java/com/example/helloapp/HelloAppApplication.java

Deployment

This app can be deployed as a stand-alone web app, as a Tanzu Application Platform (TAP) workload resource or, as a Kubernetes Deployment and Service.

Standalone app with embedded Tomcat server

You can build the project using Maven:

mvn clean package

To run the app using the embedded Tomcat server you can run this command:

mvn spring-boot:run

You can access the function using curl:

curl -w'\n' -H 'Content-Type: text/plain' localhost:8080 -d "Fun"

Deploying to Kubernetes using VMware Tanzu Developer Tools for Visual Studio Code

You can open this project using Visual Studio Code. Make sure you have VMware Tanzu Developer Tools for Visual Studio Code installed.

For best results use Tilt version v0.23.2 or later. You can install Tilt by following these instructions: https://docs.tilt.dev/install.html

Follow instructions in the documentation for deploying your app for live update and debugging.

These are the basic steps to use live update:

  1. In Visual Studio Code, navigate to Preferences > Settings > Extensions > Tanzu.
    • In the Source Image field, provide the destination image repository to publish an image containing your workload source code. This should match what is specified for SOURCE_IMAGE default in the Tiltfile.
  2. From the Command Palette (⇧⌘P), type "Tanzu", and select Tanzu: Live Update Start. You can view output from Tanzu Application Platform and from Tilt indicating that the container is being built and deployed.
    • You see "Live Update starting..." in the status bar at the bottom right.
    • Live update can take 1-3 minutes while the workload deploys and the Knative service becomes available.

      Note: Depending on the type of cluster you use, you might see an error similar to the following:

      ERROR: Stop! cluster-name might be production.
      If you're sure you want to deploy there, add:
              allow_k8s_contexts('cluster-name')
      to your Tiltfile. Otherwise, switch k8s contexts and restart Tilt.
      
      Follow the instructions and add the line "allow_k8s_contexts('cluster-name')" to your Tiltfile.
  3. When the Live Update status in the status bar is visible, resolve to "Live Update Started", navigate to http://localhost:8080 in your browser, and view your running application.
  4. Make changes to the source code. When the codes is saved the running application will get updated.
  5. Either continue making changes, or stop the live update when finished. Open the command palette (⇧⌘P), type "Tanzu", and select Tanzu: Live Update Stop.

Deploying to Kubernetes as a TAP workload with Tanzu CLI

If you make modifications to the source and push to your own Git repository, then you can update the spec.source.git information in the config/workload.yaml file.

When you are done developing your function app, you can simply deploy it using:

tanzu apps workload apply -f config/workload.yaml

If you would like deploy the code from your local working directory you can use the following command:

tanzu apps workload create tanzu-java-sample-app -f config/workload.yaml \
  --local-path . \
  --source-image <REPOSITORY-PREFIX>/tanzu-java-sample-app-source \
  --type web

Accessing the app deployed to your cluster

If you don't have curl installed it can be installed using downloads here: https://curl.se/download.html

Determine the URL to use for the accessing the app by running:

tanzu apps workload get tanzu-java-sample-app

To invoke the deployed function run the following curl command in another terminal window:

curl <URL> -w'\n' -H 'Content-Type: text/plain' -d Fun

This depends on the TAP installation having DNS configured for the Knative ingress.