本篇文档描述如何在生产环境安装 Chaos Mesh。

环境准备

在安装之前,请先确保环境中已经安装 Helm

如要查看 Helm 是否已经安装,请执行如下命令:

  1. helm version

以下是预期输出:

  1. version.BuildInfo{Version:"v3.5.4", GitCommit:"1b5edb69df3d3a08df77c9902dc17af864ff05d1", GitTreeState:"dirty", GoVersion:"go1.16.3"}

如果你的实际输出与预期输出一致,表示 Helm 已经成功安装。

:::note 注意

本文中的命令将会使用 Helm v3 来操作 Chaos Mesh。如果你的环境中 Helm 的版本为 v2,请参考将 Helm v2 迁移到 v3或按照 v2 的格式进行修改。

:::

使用 Helm 安装

第 1 步:添加 Chaos Mesh 仓库

在 Helm 仓库中添加 Chaos Mesh 仓库:

  1. helm repo add chaos-mesh https://charts.chaos-mesh.org

第 2 步:查看可以安装的 Chaos Mesh 版本

执行如下命令显示可以安装的 charts:

  1. helm search repo chaos-mesh

:::note 注意

上述命令会输出最新发布的 chart,如需安装历史版本,请执行如下命令查看所有的版本:

  1. helm search repo chaos-mesh -l

:::

在上述命令完成后,接下来开始安装 Chaos Mesh。

第 3 步:创建安装 Chaos Mesh 的命名空间

推荐将 Chaos Mesh 安装在 chaos-testing 命名空间下,也可以指定任意命名空间安装 Chaos Mesh:

  1. kubectl create ns chaos-testing

第 4 步:在不同环境下安装

由于不同容器运行时的守护进程所监听的 socket path 不同,在安装时需要设置不同的值,可以根据不同的环境来运行如下的安装命令。

Docker

  1. # 默认为 /var/run/docker.sock
  2. helm install chaos-mesh chaos-mesh/chaos-mesh -n=chaos-testing

containerd

  1. helm install chaos-mesh chaos-mesh/chaos-mesh -n=chaos-testing --set chaosDaemon.runtime=containerd --set chaosDaemon.socketPath=/run/containerd/containerd.sock

K3s

  1. helm install chaos-mesh chaos-mesh/chaos-mesh -n=chaos-testing --set chaosDaemon.runtime=containerd --set chaosDaemon.socketPath=/run/k3s/containerd/containerd.sock

:::note 注意

如要安装特定版本的 Chaos Mesh,请在 helm install 后添加 --version xxx 参数,如 --version v2.0.0

:::

验证安装

运行 Chaos 实验

升级 Chaos Mesh

如要升级 Chaos Mesh,请执行如下命令:

  1. helm upgrade chaos-mesh chaos-mesh/chaos-mesh

:::note 注意

如要升级至特定版本的 Chaos Mesh,请在 helm upgrade 后添加 --version xxx 参数,如 --version v2.0.0

:::

:::note 注意

如在非 Docker 环境下进行升级,需如在不同环境下安装所述添加相应的参数。

:::

如要修改配置,请根据需要设置不同的值。例如,如下命令会升级并卸载 chaos-dashboard

  1. helm upgrade chaos-mesh chaos-mesh/chaos-mesh -n=chaos-testing --set dashboard.create=false

:::note 注意

如果想了解更多的值及其相关的用法,请参考所有的值

:::

:::caution 警告

目前,Helm 在升级时不会应用最新的 CustomResourceDefinition (CRD),这可能会导致一些错误的发生。为了避免这种情况,请手动应用最新的 CRD:

curl -sSL https://mirrors.chaos-mesh.org/latest/crd.yaml | kubectl apply -f -

:::

卸载 Chaos Mesh

如要卸载 Chaos Mesh,请执行以下命令:

  1. helm uninstall chaos-mesh -n chaos-testing

常见问题解答

如何安装最新版本的 Chaos Mesh

Chaos Mesh 仓库中的 helm/chaos-mesh/values.yaml 定义了最新版本(master 分支)的镜像。若想安装最新版本的 Chaos Mesh,请执行以下命令:

  1. # 克隆仓库
  2. git clone https://github.com/chaos-mesh/chaos-mesh.git
  3. cd chaos-mesh
  4. helm install chaos-mesh helm/chaos-mesh -n=chaos-testing

如何关闭安全模式

安全模式是默认启用的。如需关闭,请在安装或升级时指定 dashboard.securityModefalse

  1. helm install chaos-mesh helm/chaos-mesh -n=chaos-testing --set dashboard.securityMode=false