Version: v1.8
Deploy Kubernetes Objects
This section introduces that how you can deploy Kubernetes objects into multi environments and clusters.
KubeVela supports you to render, orchestrate and deploy Kubernetes objects. The common usage type is Deployment+Service. Using customized Workflow, you can deploy an application into multi-cluster in sequence. Hence you’ll get to know:
- Deploy Kubernetes objects.
- Workflow and its usage.
- Multi-env/cluster in application delivery.
- The control loop of application deployment: Rollback, Terminate and Continue.
- Prepare Kubernetes Resources you want to deploy. In this guide, we’ll use a composition of Deployment and Service as example.
Below is a demo application with Kubernetes objects consist of Deployment and Service.
There are two policies and three workflow steps in it:
- The policy means we’re going to deploy into two namespaces as different environments.
- The workflow step means, we will deploy to one environment first, wait for human review after the first step succeeded, then finish the rest step.
apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
name: app-with-k8s-objects
namespace: default
spec:
components:
- name: k8s-demo-service
properties:
objects:
- apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx
spec:
replicas: 2
selector:
matchLabels:
app: nginx
strategy:
type: Recreate
template:
metadata:
labels:
app: nginx
spec:
containers:
- image: nginx
name: nginx
ports:
- containerPort: 80
- apiVersion: v1
kind: Service
metadata:
annotations:
service.beta.kubernetes.io/aws-load-balancer-type: nlb
labels:
app: nginx
name: nginx
namespace: default
spec:
externalTrafficPolicy: Local
ports:
- name: http
port: 80
protocol: TCP
targetPort: 80
selector:
app: nginx
type: LoadBalancer
type: k8s-objects
policies:
- name: topology-default
type: topology
properties:
clusters: ['local']
namespace: default
- name: topology-production
type: topology
properties:
clusters: ['local']
namespace: production
workflow:
steps:
- name: deploy2default
properties:
policies: ['topology-default']
type: deploy
- name: suspend
type: suspend
- name: deploy2production
properties:
policies: ['topology-production']
type: deploy
- More about the topology policy, refer to the detail guide.
- More about the deploy workflow step, refer to the detail guide.
Deploy this application by the following command:
- You may need to create the namespace with the name
production
before deploying the application.
vela up -f https://kubevela.io/example/applications/create-namespace.yaml
- Deploy the demo application.
vela up -f https://kubevela.io/example/applications/app-with-k8s-objects.yaml
- Check the status of the application.
vela status app-with-k8s-objects
You can also check the deployment and service with the kubectl
or any other tools you familiar to check the deployment.
- Approve the workflow if everything looks good.
vela workflow resume app-with-k8s-objects
KubeVela also allows referring Kubernetes objects from Kubernetes cluster or remote URL links, so that you do not need to write Kubernetes objects inside Application directly. Read more about it in ref-objects.
We can do the same process in KubeVela UI Console if you have enabled velaux addon.
In VelaUX, we use Delivery Target to describe the space where the application resources actually delivered. It’s like syntax sugar to topology policy
in UI console.
Refer to targets management doc for details and make sure you have 3 targets: 1 for test and 2 for prod environments for our below example.
After Target was created, we begin to create an application. Same to Deploy First Application, we need to submit basic Infos:
(1) Select type: k8s-objects; NOTE that in one application please maintain at most one Workload type of resource, meaning without more than a Deployment or Statefulset.
(2) We schedule two environments, test and prod. Test environment links to the target for dev and prod environment select the other two targets.
(3) Upload your Yaml file. Note that, the name of the resource you specified must not conflict with existing ones. Also, the editor automatically formats the Yaml file.
After above, click Create
to finish.
Enter the further page, the application has automatically generated 2 environments and 2 workflows. Each environment has its workflow by default. A workflow consists of one or more steps such as deploy2env
.
Firstly let’s switch to the Tab of the test environment, click Deploy on the page. Since we only assigned one target for the test environment, there’s one step for workflow. Looking at the status of its execution in the upper-right, it turns green when succeeded. If it shows red means that workflow went into trouble, you can click on the red sign to look through the detailed reason. Fix it accordingly and the deployment will continue to be regained.
After deployment is finished, refresh the list of instances to see Pods. Click for more if Pod shows abnormality.
As for the test environment, it sure can be updated at any time. When we update the parameters(image, instance), execute the workflow for an upgrade. Note that, choose the workflow for the test environment.
Let’s switch to the Tab of the prod environment. It shows that it’s not deployed yet. So now you can understand one basic thing for KubeVela, different environments in one application are completely dependant on each other, of each is an individual Application CR.
As we have two targets for the prod environment, it’ll execute in sequence. If you hope to set up a manual approval before it gets into the second target, this is where workflow comes in.
we can see two generated workflow. Now we click the Edit
in the workflow of the prod environment, drag out the suspend
into the board at the right. Set up the configuration you needed.
Then we need to orchestrate their sequence. First disconnect existing steps (by clicking the line + delete button), connect the suspend step in the middle. After editing, you need to click the Save button on the upper right to save.
Back to the page of prod environment, click Deploy.
Monitoring the status on the upper right. When the first target finished deploying, a window pops up for you to give out a command.
suspend
has three operations:
- Rollback: the revision reverts to the latest one in history, even with the first Target.
- Terminate: stop the deployment process but it will not change the first Target that already deployed.
- Continue: enter the execution of the next step.
If continued, the deployment goes on. In the list of instances, you can check out all the details.
Now you’ve learned how to deploy Kubernetes objects.
If you want to learn how to distribute resources across multi-clusters, you can refer to this doc.
Last updated on May 6, 2023 by Tianxin Dong