In this guide we'll deploy a natively compiled Quarkus application to Google Cloud Run. Here you will:
- Generate a Quarkus application.
- Generate all the configuration necessary to make deployment to Google Cloud Run quick and easy.
- Set up a Cloud Run service and deploy the application.
You will need the following:
- Maven 3.5.3+.
- Google Cloud CLI.
- A GCP account.
Create a simple "greeter" Quarkus application:
mvn io.quarkus:quarkus-maven-plugin:0.13.3:create \
-DprojectGroupId=org.acme \
-DprojectArtifactId=getting-started \
-DclassName="org.acme.quickstart.GreetingResource" \
-Dpath="/hello"
The greeter service looks like so:
@Path("/hello")
public class GreetingResource {
@GET
@Produces(MediaType.TEXT_PLAIN)
public String hello() {
return "hello";
}
}
Feel free to test and run this locally (see the getting started guide for more information). Alternatively, move on to the next step if you just want to get into production fast!
Cloud Run's container runtime contract states that:
- Executables in the container image must be compiled for Linux 64-bit.
- The container must listen for HTTP requests on
0.0.0.0
on the port defined by thePORT
environment variable (8080 by default).
To keep billing costs as low as possible, whatever runs inside the container should start fast, execute fast, and utilize as little memory as possible.
At this point then we should be sure to have an installation of GraalVM and Docker to take care of the native image compilation and containerization parts respectively. However, from a pure development perspective, compiling down our Quarkus application to a native image and containerizing it is we want to avoid. (In addition, GraalVM is not supported on Windows.) Therefore, we're going to delegate this to Google's Cloud Build.
The cloudify-maven-plugin
maven plugin will help turn your Quarkus application into a Cloud Run ready application.
Run the plugin like so:
mvn -N team.quad:cloudify-maven-plugin:0.1.0:gcloud-run
It generates the following:
- A Docker file.
- Google cloud configuration file for building and deploying.
- Scripts to help with the first time setup on Cloud Run.
The Cloud Run console (web interface) can be used to set up a Cloud Run project and service. Alternatively, at the root of our project is an interactive deploy
script, which will guide us through the setup from the command line.
Execute the script and follow the instructions:
./deploy
Or on Windows
deploy.cmd
The script will take you through the process of creating a project and linking your GCP billing account to it. Other tasks such as enabling various APIs, assigning roles to service accounts (for build and deploy permissions) and pushing the code to the cloud are taken care of automatically. Note that native compilation is not a lightweight task so the build step can take several minutes.