Supported with ballerina services, listeners and functions.
Annotation Name
Description
Default value
name
Name of the deployment
<BALLERINA_FILE_NAME>-deployment or <BALLERINA_MODULE_NAME>-deployment
labels
Labels for deployment
{ app: <OUTPUT_FILE_NAME> }
annotations
Annotations for deployment
{}
dockerHost
Docker host IP and docker PORT.(e.g "tcp://192.168.99.100:2376")
DOCKER_HOST environment variable. If DOCKER_HOST is unavailable, uses "unix:///var/run/docker.sock" for Unix or uses "npipe:////./pipe/docker_engine" for Windows 10 or uses "localhost:2375"
dockerCertPath
Docker cert path
DOCKER_CERT_PATH environment variable
registry
Docker registry url
null
username
Username for the docker registry
null
password
Password for the docker registry
null
baseImage
Base image to create the docker image
openjdk:8-jre-alpine
image
Docker image with tag
<OUTPUT_FILE_NAME>:latest. If field registry is set then it will be prepended to the docker image name as /<OUTPUT_FILE_NAME>:latest
buildImage
Building docker image
true
push
Push docker image to registry. This will be effective if image buildImage field is true
false
copyFiles
Copy external files for Docker image
null
singleYAML
Generate a single yaml file for all k8s resources
true
namespace
Namespace of the deployment
null
replicas
Number of replicas
1
livenessProbe
Enable or disable liveness probe
false
readinessProbe
Enable or disable readiness probe
false
imagePullPolicy
Docker image pull policy
IfNotPresent
env
List of environment variables
null
podAnnotations
Pod annotations
{}
podTolerations
Pod tolerations
{}
buildExtension
Extension for building docker images and artifacts
<BALLERINA_SERVICE_NAME>.com or <BALLERINA_SERVICE_LISTENER_NAME>.com
path
Resource path.
/
targetPath
This will use for URL rewrite.
null
ingressClass
Ingress class
nginx
enableTLS
Enable ingress TLS
false
@kubernetes:HPA{}
Supported with ballerina services and functions.
Annotation Name
Description
Default value
name
Name of the Horizontal Pod Autoscaler
<BALLERINA_SERVICE_NAME>-hpa
labels
Labels for service
{ app: <OUTPUT_FILE_NAME> }
annotations
Map of annotations
null
minReplicas
Minimum number of replicas
Number of replicas in deployment
maxReplicas
Maximum number of replicas
minReplicas + 1
cpuPrecentage
CPU percentage to start scaling
50
@kubernetes:Secret{}
Supported with ballerina service and functions.
Annotation Name
Description
Default value
name
Name secret mount
<BALLERINA_SERVICE_NAME>-secret
labels
Labels for service
{ app: <OUTPUT_FILE_NAME> }
annotations
Map of annotations
null
mountPath
Path to mount on container
null
readOnly
Is mount read only
true
defaultMode
Default permission mode
null
data
Paths to data files
null
@kubernetes:ConfigMap{}
Supported with ballerina services and functions.
Annotation Name
Description
Default value
name
Name config map mount
<BALLERINA_SERVICE_NAME>-config-map
mountPath
Path to mount on container
null
readOnly
Is mount read only
true
defaultMode
Default permission mode
null
data
Paths to data files
null
@kubernetes:PersistentVolumeClaim{}
Supported with ballerina services and functions.
Annotation Name
Description
Default value
name
Name secret mount
null
labels
Labels for service
{ app: <OUTPUT_FILE_NAME> }
annotations
Metadata Annotations map
null
mountPath
Path to mount on container
null
accessMode
Access mode
ReadWriteOnce
volumeClaimSize
Size of the volume claim
null
readOnly
Is mount read only
false
@kubernetes:ResourceQuota{}
Support with ballerina services and functions.
Annotation Name
Description
Default value
name
Name of the resource quota
<BALLERINA_FILE_NAME>-resource-quota or <BALLERINA_MODULE_NAME>-resource-quota
labels
Labels for resource quota
{ app: <OUTPUT_FILE_NAME> }
annotations
Metadata Annotations map
null
hard
Hard rules
{}
scopes
Scopes to which the resource quota will be applied to
[]
@kubernetes:Job{}
Supported with ballerina main function.
Annotation Name
Description
Default value
name
Name of the job
<BALLERINA_FILE_NAME>-job or <BALLERINA_MODULE_NAME>-job
labels
Labels for job
{ app: <OUTPUT_FILE_NAME> }
annotations
Metadata Annotations map
{}
dockerHost
Docker host IP and docker PORT.(e.g "tcp://192.168.99.100:2376")
DOCKER_HOST environment variable. If DOCKER_HOST is unavailable, uses "unix:///var/run/docker.sock" for Unix or uses "npipe:////./pipe/docker_engine" for Windows 10 or uses "localhost:2375"
dockerCertPath
Docker cert path
DOCKER_CERT_PATH environment variable
registry
Docker registry url
null
username
Username for the docker registry
null
password
Password for the docker registry
null
baseImage
Base image to create the docker image
openjdk:8-jre-alpine
image
Docker image with tag
<OUTPUT_FILE_NAME>:latest. If field registry is set then it will be prepended to the docker image name as /<OUTPUT_FILE_NAME>:latest
buildImage
Building docker image
true
push
Push docker image to registry. This will be effective if image buildImage field is true
Run the Gradle command gradle build from within the kubernetes directory.
Copy build/kubernetes-extension-***.jar file to <BALLERINA_HOME>/bre/lib directory.
Enabling debug logs
Use the "BAL_DOCKER_DEBUG=true" environment variable to enable docker related debug logs when building the ballerina
source(s).
Use the "BAL_KUBERNETES_DEBUG=true" environment variable to enable kubernetes related debug logs when building the
ballerina source(s).
Deploy ballerina service directly using kubectl command.
This repository also provides a kubectl plugin which allows to build ballerina programs and deploy their kubernetes
artifacts directly to a kuberetes cluster. The plugin is located at kubernetes-extension/src/main/resources/kubectl-extension/kubectl-ballerina-deploy.
Follow the steps mentioned in "Extend kubectl with plugins"
. Check if the plugin is available using the command kubectl plugin list.
Replacing values with environment variables.
You can replace values in an annotation using environment variables. The replacement is done with a string placeholder
like "$env{ENV_VAR}". As an example lets say that you want to set the namespace field in the @kubernetes:Deployment{}
annotation with a environment variable and the name of the environment variable is K8S_NAMESPACE. Following is how the
annotation would look like:
Note: You cannot use the ballerina/config module to replace values in the annotation. This is because the kubernetes
artifacts are generated during compile time. The ballerina/config module works in the runtime.
How to execute:
$> kubectl ballerina deploy hello_world_k8s.bal
> building ballerina source...
Compiling source
hello_world_k8s.bal
Generating executable
hello_world_k8s.jar
Generating artifacts...
@kubernetes:Service - complete 1/1
@kubernetes:Deployment - complete 1/1
@kubernetes:Docker - complete 2/2
@kubernetes:Helm - complete 1/1
Execute the below command to deploy the Kubernetes artifacts:
kubectl apply -f ./kubernetes
Execute the below command to install the application using Helm:
helm install --name hello-world-k8s-deployment ./kubernetes/hello-world-k8s-deployment
> deploying artifacts...
executing 'kubectl apply -f ./kubernetes'
service/helloworld-svc unchanged
deployment.apps/hello-world-k8s-deployment configured
> deployment complete!
Annotation Usage Sample:
importballerina/http;
importballerina/log;
importballerina/kubernetes;
@kubernetes:Ingress {
hostname:"abc.com"
}
@kubernetes:Service {
name:"hello"
}
listenerhttp:ListenerhelloEP=new(9090);
@kubernetes:Deployment {
livenessProbe:true
}
@http:ServiceConfig {
basePath:"/helloWorld"
}
service helloWorld on helloEP {
resourcefunction sayHello(http:Callercaller, http:Requestrequest) {
http:Responseresponse=new;
response.setTextPayload("Hello, World from service helloWorld ! ");
var responseResult =caller->respond(response);
if (responseResultiserror) {
log:printError("error responding back to client.", err=responseResult);
}
}
}
The kubernetes artifacts will be created in following structure.