如何在物理机上运行混沌试验?

如何在物理机上运行混沌试验?

译文
作者:布加迪 2021-09-28 08:00:00

云计算 借助开源Chaos Mesh,您可以模拟种种故障,并使用Chaos Dashboard这个Web UI直接管理混沌试验。

[[426176]]

【51CTO.com快译】Chaos Mesh®是一个云原生混沌工程(Chaos Engineering)平台,负责编排Kubernetes环境中的混沌。借助Chaos Mesh,您可以模拟种种故障,并使用Chaos Dashboard这个Web UI直接管理混沌试验。自开源以来,Chaos Mesh已被许多公司采用,以确保其系统的弹性和稳健性。但在过去的一年,我们常听到社区的要求,询问服务没有部署在Kubernetes上时如何运行混沌试验。

什么是chaosd?

chaosd是一个增强的工具包,可满足物理机上的混沌测试日益增长的需求。您可能会觉得这个名字很熟悉!那是由于它是从Chaos Mesh中的一个关键组件chaos-daemon演变而来的。

在TiDB黑客马拉松2020上,我们重构了chaosd,使其不仅仅是一个命令行工具。现在有了chaosd v1.0.1,您可以模拟针对物理机的特定错误,然后像什么没发生一样撤消混沌试验。

chaosd的功能特性

chaosd的最新升级版拥有广泛的功能,以下是最突出的几项:

  • 易于使用:可以使用chaosd 命令轻松创建和管理混沌试验。
  • 多种故障类型:可以在不同级别模拟物理机上注入的故障,包括进程故障、网络故障、Java虚拟机(JVM)应用程序故障、压力场景、磁盘故障和主机故障。
  • 多种工作模式:可以将chaosd 用作命令行工具或服务。

事不宜迟,不妨试一试。

如何使用chaosd?

这部分将逐步介绍如何使用chaosd注入网络故障。您的Linux内核版本必须是v2.17或更高版本。

1.下载并解压chaosd

要下载chaosd,请运行以下命令: 

  1. curl -fsSL -o Chaosd-v1.0.1-linux-amd64.tar.gz https://mirrors.chaos-mesh.org/chaosd-v1.0.1-linux-amd64.tar.gz 

解压缩文件。它含有两个文件夹:

  • chaosd含有chaosd的工具入口。
  • tools含有进行混沌试验所需的工具,包括stress-ng(模拟压力场景)、Byteman(模拟JVM应用程序故障)和PortOccupyTool(模拟网络故障)。

2. 创建混沌试验

在这个混沌试验中,服务器将无法访问chaos-mesh.org。

运行以下命令:

  1. sudo ./chaosd attack network loss --percent 100 --hostname chaos-mesh.org --device ens33 

示例输出:

  1. Attack network successfully, uid: c55a84c5-c181-426b-ae31-99c8d4615dbe 

在该模拟中,ens33网络接口卡无法向chaos-mesh.org发送网络数据包或无法从chaos-mesh.org接收数据包。之所以要使用sudo命令,是由于混沌试验修改了网络规则,这需要root权限。

另外,别忘了保存混沌试验的uid。您稍后将在恢复过程中输入该信息。

3. 验证结果

使用ping命令查看服务器是否可以访问chaos-mesh.org:

  1. ping Chaos-mesh.org 
  2. PING Chaos-mesh.org (185.199.109.153) 56(84)  bytes of data. 

执行该命令后,该网站很可能不会响应。按CTRL+C组合键以停止ping进程。您应该可以看到ping命令的统计信息:100% packet loss(100%丢包)。

示例输出:

  1. 2 packets transmitted, 0 received, 100% packet loss, time 1021ms 

4. 恢复试验

要恢复试验,运行以下命令:

  1. sudo ./chaosd recover c55a84c5-c181-426b-ae31-99c8d4615dbe 

示例输出:

  1. Recover c55a84c5-c181-426b-ae31-99c8d4615dbe successfully 

这一步还需要使用sudo命令,因为需要root权限。完成恢复试验后,再次尝试ping chaos-mesh.org,以验证连接。

下几步

1.支持仪表板Web

如您所见,chaosd易于使用。但是我们可以让它变得更简单——面向chaosd的仪表板Web目前正在积极开发中。

我们将继续增强其可用性,并实现更多的功能,比如管理使用chaosd运行的混沌试验以及使用Chaos Mesh运行的混沌试验。这将为Kubernetes和物理机上的混沌测试提供一致且统一的用户体验。

下面的架构只是一个简单的例子:

图1. Chaos Mesh的优化后架构

2.添加更多的故障注入类型

目前,chaosd提供六种故障注入类型。我们计划开发得到Chaos Mesh支持的更多类型,包括HTTPChaos和IOChaos。

如果您有兴趣帮助我们改进chaosd,欢迎选择一个问题单,开始入手!

试一试!

如果您有兴趣使用chaosd,并想探索更多,请查看文档。如果您在运行chaosd时遇到问题,或者有功能请求,请随时创建问题单。我们很想听到您的声音!

原文标题:How to Run Chaos Experiments on Your Physical Machine,作者:Xiang Wang

【51CTO译稿,合作站点转载请注明原文译者和出处为51CTO.com】

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/230595.html<

(0)
运维的头像运维
上一篇2025-04-19 07:34
下一篇 2025-04-19 07:36

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注