Lifecycle of Application
Configure the basic information
Applications page, click
New Application button, you can see the basic application configuration page.
Choose your application(component) type
Currently we only support one component for one application in VelaUX, so the application type here is actually component type.
There're many component types supported in KubeVela including cloud resources and container based service type. New component types can be easily extended by KubeVela addons or component definition.
- We recommend to use
webservicefor your container based application.
- For helm packages, you can choose
Configure the component
After you choose component type well, KubeVela will render the configuration page according to the component type.
Different component types are different significantly, you can fill in the forms with the help of UI. For example, below is the configuration page for
Submit your application
After you finished configuring the application, click "Submit" to create the application. This means the application configuration was saved.
Bind Application with Environment
We can specify bind with one or more environments before deploy.
After we have created application and configured the baseline well, we can bind an application with environment to deploy.
You can bind with one environment as
dev environment for develop and debug. When everything works well, you can bind with the production environment.
The operation likes below:
As the picture shows, in the application management page, click
Bind Environment, choose the environment prepared.
If there's no environment, you can click the
Create new environment for creation.
After choose well, click the
submit button, it will show the new environment created on the right side of the baseline config as a tab.
KubeVela will automatically generate the deploy workflow for the newly created environments.
In the environment tab, you can click
Deploy button to deploy the application.
After application created and bond with an environment, you can deploy the application instance.
First time deploy
You can view the application detail page by click the application name or the UI card.
The tabs on the right side of the
Baseline Config are environments which bond by the application. Choose one of the environment you want to deploy. Click that tab, you'll see the picture below.
If this is the first time deploy, you'll see the Deploy button in the middle of the environment page, just click the
Deploy button to deploy.
Then the workflow start to running, you can see the workflow status on the top right corner.
If you have configured a suspend workflow step, it will run and stop in that state. It will wait until you have checked your application well and click the approve button.
If there's something wrong with the workflow step, the workflow node will become red. Move your mouse to hover that area, you'll see the error reason.
Upgrade the application
Deploy button on the top right corner, you can click that for deploy. On the right side of the button, there's detail button, you can choose which workflow to run if there's multiple environments configured.
You can upgrade the application in any state, as KubeVela is a declarative system. There will be a kindly reminder for you if the workflow is running when you want to upgrade.
Check Application State
Different tabs of environment will show different application instances inside.
By default, it will display all instances deployed in the environment, you can filter the status by select targets.
As the picture shows, check the application pod details by click the expand button("+") on the left. You can view the pod status including the events and error message about it.
For cloud resources, there will be a link to the cloud console for management.
View Application Logs
You can view the logs of application in the environment tab.
By default, the logs will refresh every 5s. If your logs didn't have timestamp, you can click the
Show timestamps to see.
You can also view logs from command line:
vela logs <app_name> -n <namespace>
Select a workload to view the logs.
Expose your application for public access
You can configure your application for public access.
There're mainly three ways to expose your service.
webserviceType and configure the service type to be
gatewaytrait, it works for
gatewaytrait must configure a domain and works only for HTTP/HTTPs protocols.
- Case by case component configurations.
Expose service for
webservice typed component
You can modify
ExposeType to choose the way, and you should configure the
Service Ports to listen the ports and turn on the
gateway trait requires you have
Ingress Controller available in your cluster. You can add this trait to expose your service and configure a domain.
As the picture shows, the
Domain field configure your domain, please configure your DNS for domain to route to the Kubernetes cluster gateway IP.
Http section, you can configure the routing rules. For example, set
80 means the domain index page will route to the port
80. You can configure this rule as you need.
Other component types can also be able to configure the service expose, but they're usually case by case, especially for helm charts.
Get the service endpoint
After the application deployed with service exposed configuration, you can see a
Service Endpoint button on the left of the
Recycle button. You'll see the endpoint when hover your mouse there.
List Resources Created
If you want to learn the resources created by the applications, you can open the environment status page.
There're three kinds of information including
Component Status. The
Applied Resources are all resources created by the applications.
You can also list resources from command line:
$ vela status <app_name> -n <namespace> --tree
Recycle Application Instance
When you want to delete the application instance in some environment, you can click the
Recycle button in that environment.
It will delete the whole application instance with related resources.
Note that recycle means delete an application, data can't be recovered automatically. Please make sure you have back up all the important data of this instance before recycle it.
After all application instance were recycled, you can click
Remove for deletion.
As the picture shows, the
Remove button is hidden in the application detail.
Now you have learned the basic lifecycle of an application.