首页 > 其他分享 >混沌工程的入门

混沌工程的入门

时间:2022-09-18 10:25:01浏览次数:90  
标签:架构 入门 工程 混沌 系统 实验 团队

混沌工程的入门

     主要在生产环境中故意破坏东西是混乱工程中的一个咒语。但是当你把你的计划告诉你的工程经理或产品负责人时,你往往会得到一些阻力。他们的担心是有道理的。如果破坏东西是不可逆的呢?终端用户会发生什么?我们的支持票系统会不会变得很忙?这篇文章将帮助你消除这些顾虑,并在你的组织中开始使用混沌工程。

什么是混沌工程?
       关于混沌工程,业界领袖有多种定义。

image-17-1024x446

开始
      混沌实验的目的是了解我们的系统在生产中出现灾难性故障时将如何表现,以及我们的系统的弹性如何。这给了我们一个优化和修复问题的机会。

下面是你如何开始你的混沌工程实践。

从你的经理那里获得购买力
      第一步是得到你的经理的批准,在测试环境中进行实验。通常情况下,混沌实验应该在生产环境中进行--但我建议你采取小步骤。你可以在任何有效的环境中进行混沌实验。如果生产环境不可用,我建议在非生产(或阶段)环境中运行实验。

解释一下你通过执行混沌实验带来的价值,比如说:

识别故障和瓶颈
弹性验证
规模化验证

理解架构
     系统一直在失败。在运行混沌实验之前,彻底了解你的系统架构。与你的开发人员、架构师和SREs进行一次工作会议,对应用架构进行头脑风暴。确保每个人都了解上游/下游组件、依赖关系、时间线、游戏日时间表等。这将有助于你更好地了解你的系统可能出现故障的地方。

撰写假设
      开始写一个假设列表,例如,给定一个Kubernetes部署,删除一个pod不应该增加典型负载下的服务响应时间。另一个例子:负载均衡器必须只将请求路由到健康和运行的节点上。
编写假设时没有对错之分。这是一个迭代的过程。我们的目标不是让我们的假说 "通过 "或 "失败"。测试每个假设将使我们有机会了解我们的系统。

尽量减少爆炸半径
      总是从小处着手。在运行混沌实验时,通过最小化爆炸半径来减少对终端用户的影响,例如,不要删除Kubernetes集群中的部署,而是删除pods并验证弹性。即使你要删除一个部署,也要确保GitOps是有效的,这样GitOps流程会自动创建一个部署。
另一个例子:与其关闭集群中的所有节点,不如去关闭50%的运行节点,或者与其关闭整个区域的电源,不如关闭一个区域。 一旦混乱过程成熟,你的团队处于一个舒适的区域,你可以慢慢增加爆炸半径。

为游戏日做计划
       未雨绸缪,始终为你的 "游戏日 "准备一个B计划。至少在一周前通知你的所有利益相关者,并在Slack(或你公司的协作平台)中启动一个统一的沟通渠道,定期发布更新。我建议在你进行第一次实验时,让你的开发人员或你的DevOps或SRE团队待命。

运行你的第一个实验
      没有人是完美的。如果你在运行你的第一个实验时遇到困难,那也没关系。及时发布更新并通知所有的利益相关者。
运行第一个混乱的实验就像乘坐高难度的过山车。如果情况不妙,确保你能够停止实验,并在DevOps或SRE团队的帮助下恢复基础设施。 在实验过程中,监控你的可观察性仪表盘,观察响应时间、磁盘利用率、通过/失败的事务、健康检查等重要因素。

分析
       一旦实验完成,在电子表格中记录你所有的观察结果,分析它们,并定义你的假设判决。同样,没有通过或失败;这都是学习。

集思广益
       与你的开发人员、架构师和DevOps/SRE团队安排一次会议,讨论你的结论。这将有助于团队理解判决并解决你发现的问题。一旦问题得到解决,你就可以重新进行实验了。
如果你发现系统是有弹性的,你可以尝试增加爆炸半径并重新进行实验。

接下来的步骤
       在运行各种游戏日之后,你可以了解到团队动态、系统性能等。下一步是将混沌实验嵌入到你的开发者工作流程中,这样混沌实验就会自动化,这将给你的团队带来更多的信心。



今天先到这儿,希望对云原生,技术领导力, 企业管理,系统架构设计与评估,团队管理, 项目管理, 产品管理,团队建设 有参考作用 , 您可能感兴趣的文章:
领导人怎样带领好团队
构建创业公司突击小团队
国际化环境下系统架构演化
微服务架构设计
视频直播平台的系统架构演化
微服务与Docker介绍
Docker与CI持续集成/CD
互联网电商购物车架构演变案例
互联网业务场景下消息队列架构
互联网高效研发团队管理演进之一
消息系统架构设计演进
互联网电商搜索架构演化之一
企业信息化与软件工程的迷思
企业项目化管理介绍
软件项目成功之要素
人际沟通风格介绍一
精益IT组织与分享式领导
学习型组织与企业
企业创新文化与等级观念
组织目标与个人目标
初创公司人才招聘与管理
人才公司环境与企业文化
企业文化、团队文化与知识共享
高效能的团队建设
项目管理沟通计划
构建高效的研发与自动化运维
某大型电商云平台实践
互联网数据库架构设计思路
IT基础架构规划方案一(网络系统规划)
餐饮行业解决方案之客户分析流程
餐饮行业解决方案之采购战略制定与实施流程
餐饮行业解决方案之业务设计流程
供应链需求调研CheckList
企业应用之性能实时度量系统演变
Openshift与Kubernetes的区别

如有想了解更多软件设计与架构, 系统IT,企业信息化, 团队管理 资讯,请关注我的微信订阅号:

MegadotnetMicroMsg_thumb1_thumb1_thu[2]

作者:Petter Liu
出处:http://www.cnblogs.com/wintersun/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。 该文章也同时发布在我的独立博客中-Petter Liu Blog。

标签:架构,入门,工程,混沌,系统,实验,团队
From: https://www.cnblogs.com/wintersun/p/16704296.html

相关文章

  • cmake 入门笔记
    以下内容为本人的著作,如需要转载,请声明原文链接微信公众号「englyf」https://www.cnblogs.com/englyf/p/16667896.html1.cmake是什么?这些年大型C/C++工程都纷纷转......
  • 如何结合整洁架构和MVP模式提升前端开发体验(三) - 项目工程化配置、规范篇
    工程化配置还是开发体验的问题,跟开发体验有关的项目配置无非就是使用eslint、prettier、stylelint统一代码风格。formattingandlinteslint、prettier、stylelint怎......
  • 【指北】动态规划从入门到入坟
    前言本【指北】适合正在学习DP的OIer。本【指北】中不仅有简单内容,还有较难内容,总体来讲适合不同水准的选手。本人才疏学浅,请大佬们在评论区中指出错误,我会加以改进......
  • 1.git入门
    第1章Git概述1.分布式版本控制系统2.git工作机制3.代码托管中心=远程库4.代码托管中心局域网:GitLab互联网:GitHub  Gitee码云5.git的版本控制都是在本地库中做的第2......
  • [数据结构10分钟入门] 面向初学者从零实现 -- 单链表
    一、链表是什么链表是一种通过指针串联在一起的线性结构,在内存中是分散存储的(数组在内存中连续分布),链表由一系列节点组成,每个节点都由数据域和指针域组成。主要有三种类......
  • IOC入门
    2.3.2IOC、IOC容器、Bean、DI1.IOC(InversionofControl)控制反转(1)什么是控制反转呢?使用对象时,由主动new产生对象转换为由外部提供对象,此过程中对象创建控制权由程序......
  • 逆向 | frida android hook 入门总结
    逆向|fridaandroidhook入门总结最近在备课,整理到这一块儿了,顺带就把以前的东西整理一下。比较好的参考文章:https://www.jianshu.com/p/0fa6138fafc9#hook重载函......
  • Java Servlet 入门: 问题系列:警告: Web应用程序[ROOT]似乎启动了一个名为[Thread-1]的
    问题:在Java 代码中开了一个线程,死循环定时运行。右键运行项目,再右键停目项目: 发现系统有提示警告:警告:Web应用程序[ROOT]似乎启动了一个名为[Thread-1]的线程,但......
  • 延宕执行,妙用无穷,Go lang1.18入门精炼教程,由白丁入鸿儒,Golang中defer关键字延迟调
    先行定义,延后执行。不得不佩服Golang设计者天才的设计,事实上,defer关键字就相当于Python中的try{...}except{...}finally{...}结构设计中的finally语法块,函数结束时强制......
  • Flink入门
    Flink快速上手1-创建一个Maven项目2-引入依赖版本根据自己的情况和需求进行更改<?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.org/P......