Workflow details
Introduction
In this short section, we'll take a quick look at what happened under the hood, in order to understand:
- How deployment works in Bunnyshell
- What the end result is in Kubernetes
Deployment
The Deployment flow is straightforward:
Queue -> Build (if needed) -> Deployment -> DNS Records -> Running Environment
Once a deployment is triggered, the Environment gets Queued, then, if needed, the images are built.
Note
The build may not be needed if:
- The image was already built (there are no code changes from a previous build)
- The Component is using a public image
The actual Deployment phase is started once all images are available. Bunnyshell creates the Kubernetes manifests for the Environment, and applies them into a dedicated Kubernetes Namespace, isolated from other Namespaces for security purposes.
Bunnyshell will create:
- The Ingress
- A Kubernetes Service for each Component that has at least a port exposed
- A Kubernetes Deployment, which has the default replica number set at 1
- The actual Pod(s)
- Persistent Volume Claims, if needed
Bunnyshell also creates the DNS records for the publicly exposed endpoints.
The replica count can be set from docker-compose.yaml
by setting the property deploy.replicas
for each service.
services:
...
backend:
build:
context: ./backend
target: ${FRONTEND_BUILD_TARGET:-dev}
...
deploy:
replicas: 3
Note
In the situation above, the backend will have 3 Pods created within the Kubernetes ReplicaSet, in the Deployment.
Once the Kubernetes manifests are applied, the flow enters a pending state, in which it waits for the resources to be up and running.
Finally, the Environment enters the Running state and you can use it.
Note
Keep in mind that Bunnyshell provides additional (advanced) mechanisms to handle deployments, by declaring the pod property, which allows the use of Init- and Sidecar- containers.
Building images
The image building process is performed with Kaniko or BuildKit in a Kubernetes cluster.
This cluster can be Bunnyshell's managed cluster, or your own Kubernetes cluster.
The image is pushed either in Bunnyshell's managed Registry, or your own Image Registry.
Build Settings
From the Environment Settings, you can control where and how the build is performed, by choosing:
- The cluster on which the images will be built for the current Environment
- The Image Registry where the image will be pushed after it is built
- The build engine to use, BuildKit (recommended) or Kaniko
- Allocated resources, such as CPU & memory (only when using your own cluster)
Note
The Kubernetes cluster will have access to the same Image Registry, by injecting credentials it as an Image Pull Secret.
Note
Additional information on this subject is available in the Build Settings documentation page.
Kubernetes snapshot
This is how the Environments for the Books Demo App looks like in Kubernetes after applying the generated manifests:
A request comes into the Cluster and goes through the Namespace Ingress, where it is forwarded to either frontend
or backend
.
Both the frontend
and backend
services have their separate Kubernetes Service that handles requests, and forward them to their respective Pods. The Pods are created as part of a Deployment, with a number of 1 replicas for each. This means a single Pod is running for each of them.
The db
service also has a Kubernetes Service, but the Ingress does not forward traffic to it, as it is not publicly exposed, but only available from within the Namespace. It also has a PersistentVolumeClaim, for persistently storing the data.
Updated about 1 month ago