Updated on 2024-09-05 GMT+08:00

Deploying with Helm3

Helm is a Kubernetes package management tool, which is similar to the package manager in Linux, such as yum and APT. Helm can easily deploy packaged YAML files on Kubernetes. Helm 3 is the commonly used and stable version of Helm.

CodeArts Deploy allows you to use Helm to deploy and upgrade Kubernetes clusters.
Table 1 Parameters

Parameter

Description

Action Name

Name of an action displayed in the deployment actions area.

Cluster Type

The default value is Custom.

Kubernetes Service Endpoint

You can select a CCE cluster or your own Kubernetes cluster.

  • Huawei Cloud CCE clusters
    1. Create a CCE cluster.
    2. Create a namespace.
    3. Select the CCE cluster to be deployed.
  • Your own Kubernetes cluster

    Configure the kubeconfig file and select the cluster to be deployed.

Helm Command

install, upgrade, and uninstall are available.

If you select upgrade for Helm Command and the chart name does not exist, the system automatically run install.

Namespace

Enter a namespace.

Chart Name

The custom chart name. You can perform the upgrade operation on the same chart name.

Chart Package Source

Select the source of the chart package to be installed. Artifact and Repo are available.

If you select Repo, you need to specify the code repository and branch.

Chart Package

Enter a directory or GZIP package with a chart file structure.

Values File

Select the values file from Artifact. For example, if you specify Myvalues.yaml, -f Myvalues.yaml will be added to Helm command parameters.

Values

Set values in the CLI. If you specify key1=val1,key2=val2 (separate values with commas), -set key1=val1,key2=val2 will be added to Helm command parameters.

Helm Command Parameters

Add other content to Helm command parameters.

For details, see Helm Install, Helm Upgrade, and Helm Uninstall.

Control Options

Continue the task even if this action fails.

Environment Preparation for Helm3 Deployment Example

This section uses the chart directory as an example to describe how to prepare the environment for the following three examples. Use the following template to deploy a CCE cluster and create the following directories in the code repository of CodeArts Repo.

Segment in configmap.yaml

metadata:
  name: {{ .Values.configmapname }}

Segment in deployment.yaml

spec:
  template:
    spec:
      containers:
        - image: '{{ .Values.imagename }}:{{ .Values.imagetag }}'

Segment in values.yaml

configmapname: valuesfromfile
imagename: httpd
imagetag: latest

{{.Values.xxxx}} corresponds to the variable defined in the values.yaml file in the chart.

The following three examples are based on this section.

  1. Example 1: Using the Chart Package or Chart File Structure Directory for Deployment

    If the default values file exists in the chart, you do not need to specify the values file in Artifact. You can directly deploy the default values file.

    The deployment result is as follows:

    The corresponding ConfigMap generated on the CCE console is as follows:

    The corresponding Deployment generated on the CCE console is as follows:

  2. Example 2: Deploying Helm3 by Specifying the Values File in CodeArts Artifact

    This example demonstrates how to deploy Helm3 by specifying the Values file in Artifact.

    The values defined in the external values file will overwrite the values defined in the Values file in the chart.

    Segment of an external Values file. In this example, the file is named values123.yaml.

    configmapname: valuesfile-releasenman
    imagename: nginx
    imagetag: stable

    As shown in the following figure, for Values File, select the Values file in Artifact.

    The deployment result is as follows:

    The corresponding ConfigMap generated on the CCE console is as follows:

    The corresponding Deployment generated on the CCE console is as follows:

  3. Example 3: Deploying Helm3 by Configuring Values

If Values is set, it has the highest priority and overwrites the values set in the values file of Chart and the values set in the external values file.

The following figure describes how to configure the image version:

Segment of the Values File in Chart Package:

imagetag: latest

Segment of Values File in Artifact:

imagetag: stable

When setting Values, enter the following information:

imagetag=perl

The deployment result is as follows:

The corresponding Deployment generated on the CCE console is as follows: