配置开发环境
本页面由 PageTurner AI 翻译(测试版)。未经项目官方认可。 发现错误? 报告问题 →
本文档介绍如何为 Chaos Mesh 配置本地开发环境。
Chaos Mesh 的大多数组件仅支持 Linux 环境,因此建议您将开发环境配置在 Linux 系统上运行。例如使用虚拟机或 WSL 2,并选用 VSCode Remote 作为编辑器。
本文档默认您使用 Linux 系统,且不受特定发行版的限制。若您坚持使用 Windows/macOS,可能需要额外技巧才能正常运行(例如部分 make 目标可能因环境差异而失败)。
环境要求
开始配置前,建议安装以下开发工具,其中大部分可能已在您的环境中就绪:
可选工具:
编译 Chaos Mesh
完成安装后,请按以下步骤编译 Chaos Mesh。
-
将 Chaos Mesh 仓库克隆到本地服务器:
git clone https://github.com/chaos-mesh/chaos-mesh.gitcd chaos-mesh -
确保 Docker 已安装并运行:
信息Chaos Mesh 依赖 Docker 构建容器镜像,以保持与生产环境的一致性。
-
编译 Chaos Mesh:
UI=1 make image技巧UI=1表示同时编译 Chaos Dashboard 用户界面,若无需此功能可省略该环境变量。技巧如需指定镜像标签,可使用
UI=1 make IMAGE_TAG=dev image。编译完成后将生成以下容器镜像:
ghcr.io/chaos-mesh/chaos-dashboard:latestghcr.io/chaos-mesh/chaos-mesh:latestghcr.io/chaos-mesh/chaos-daemon:latest
在本地 minikube Kubernetes 集群运行 Chaos Mesh
完成编译后,您可在本地 Kubernetes 集群中运行 Chaos Mesh。
-
使用 minikube 启动本地 Kubernetes 集群:
minikube start -
将容器镜像加载至 minikube:
minikube image load ghcr.io/chaos-mesh/chaos-dashboard:latestminikube image load ghcr.io/chaos-mesh/chaos-mesh:latestminikube image load ghcr.io/chaos-mesh/chaos-daemon:latest -
通过 Helm 安装 Chaos Mesh:
helm upgrade --install chaos-mesh-debug ./helm/chaos-mesh -n=chaos-mesh-debug --create-namespace
minikube image load 命令会耗费大量时间,这里提供一个技巧可避免开发过程中反复加载镜像:使用 minikube 节点内的 Docker 而非宿主机 Docker:
minikube start --mount --mount-string "$(pwd):$(pwd)"
eval $(minikube -p minikube docker-env)
UI=1 make image
在本地环境中调试 Chaos Mesh
我们可以使用 delve 配合远程调试功能在本地环境中调试 Chaos Mesh。
-
使用
DEBUGGER=1编译 Chaos Mesh:UI=1 DEBUGGER=1 make image -
将容器镜像加载到 minikube 中:
minikube image load ghcr.io/chaos-mesh/chaos-mesh:latestminikube image load ghcr.io/chaos-mesh/chaos-daemon:latestminikube image load ghcr.io/chaos-mesh/chaos-dashboard:latest -
安装 Chaos Mesh 并启用远程调试:
helm upgrade --install chaos-mesh-debug ./helm/chaos-mesh -n=chaos-mesh-debug --create-namespace --set chaosDlv.enable=true --set controllerManager.leaderElection.enabled=false备注为保证高可用性,Chaos Mesh 默认开启
leader-election功能并创建 3 个chaos-controller-manager副本。此处使用controllerManager.leaderElection.enabled=false确保仅创建单实例chaos-controller-manager以便调试。更多细节请参阅在不同环境中安装 Chaos Mesh。
-
配置端口转发和 IDE 远程调试连接:
可通过
kubectl port-forward将 delve 调试服务器转发至本地端口。例如调试
chaos-controller-manger时执行:kubectl -n chaos-mesh-debug port-forward chaos-controller-manager-766dc8488d-7n5bq 58000:8000此时可通过
127.0.0.1:58000访问远程 delve 调试服务器。信息我们在 Pod 中固定使用
8000端口运行 delve 调试服务器,此约定可在 Helm 模板文件中查看。随后在常用 IDE 中配置远程调试连接,示例如下:
- Goland 用户请参阅调试器附加到运行中的 Go 进程#附加到远程机器进程
- VSCode 用户请参阅vscode-go - 调试#远程调试
更多详细信息请参阅容器镜像 chaos-dlv 的 README.md。
后续步骤
完成上述准备工作后,可尝试添加新的混沌实验类型。
常见问题解答
在 MacOS 上运行 make 失败并报错 error obtaining VCS status: exit status 128
该问题与 https://github.blog/2022-04-12-git-security-vulnerability-announced/ 有关,建议先阅读此文。
Chaos Mesh 在您调用 make 时,会以当前用户身份启动容器(dev-env 或 build-env)。您可以在 get_env_shell.py#L81C10-L81C10 中找到对应的 --user 标志参数。因此当 Git 在寻找顶级 .git 目录时,如果目录遍历过程中所有权从当前用户发生变更,该过程将会终止。
目前的临时解决方案是注释掉 --user 参数所在的那行代码。