混沌工程理论建设和项目实践

混沌工程理论建设和项目实践

  • 1. 背景说明
  • 2. 为什么要做混沌工程
    • 2.1 混沌目标
    • 2.2 演习对象
    • 2.3 影响可用性的主要因素及应对
    • 2.4 可行性论证和控制爆炸半径
  • 3. 如何落地
    • 3.1 安全、有效的实验
    • 3.2 安全:不影响线上业务
      • 3.2.1 爆炸半径
      • 3.2.2 特殊限制与审批
    • 3.3 有效:贴近真实环境
      • 3.3.1 静态:部署环境的一致性
      • 3.3.2 动态:实验流量的逼真度
    • 3.4 高效、全面的发掘风险
    • 3.5 发掘高价值风险
    • 3.6 找全风险
  • 4 自动化
    • 4.1 自动设计
    • 4.2 自动执行
    • 4.3 自动分析
    • 3.8 风险处理
  • 5. 总结与展望
    • 5.1 总结
    • 5.2 更丰富的故障原子建设
    • 5.3 自动化与稳态识别
    • 5.4 支持多类爆炸半径的实验
  • 5. 参考文档

1. 背景说明

混沌工程的出发点是研究与利用混沌动力学系统中的复杂行为。这种研究旨在理解和控制看似随机的、非线性系统中的模式和规律,涉及到数学、物理、工程等多个领域。混沌工程的应用领域包括信息加密、通信系统、生物医学工程等。

2. 为什么要做混沌工程

2.1 混沌目标

混沌工程在目标上更强调发现未知的风险,更关注系统的弹性,不涉及系统外的因素。其中 Netflix 提出的混沌工程五大原则是业界落地实践的普遍共识:

  • 建立稳定状态的假设;
  • 用多样的现实世界事件做验证;
  • 在生产环境中进行实验;
  • 自动化实验以持续运行;
  • 控制最小化爆炸半径。

其中 多样化的事件和控制爆炸半径的方法 ,相对演习有明显差异。也正是控制了爆炸半径,混沌工程里注入故障的强度、复杂度远高于演习能力,能更全面、真实的模拟现网故障,以达到”发现未知风险“的目的。

此前,演习是微信支付容灾验证的重要手段,我们发现演习因为没有系统的爆炸半径控制方法,所以从工具开发、监控稳态识别、事件的多样性、自动化等方面,演习都需要较多的定制开发和人工实时观察,人力投入成本较高。

因此,引入混沌工程体系,通过有效的控制爆炸半径,进而更大幅度的注入异常并适当建设自动化能力,来识别系统薄弱点并推动持续治理来提高可用性,是当前值得探索的方向。

2.2 演习对象

演习通常是有明确的 执行计划和预期,要求注入故障的影响已知且明确。更关注 人的反应和应急响应计划 ,还包括非系统因素都在考量范围。比如验证某个系统失效后的,人为干预流程、机制是否顺畅等。

不仅要演习系统的故障自恢复能力,更要演习应急预案以及执行应急预案的相关人员能力。

2.3 影响可用性的主要因素及应对

为了分析影响可用性的因素,我们对2018 ~ 2021近几年微信支付的故障复盘数据分类,发现软硬件异常导致的故障占比较高(如下图的基础设施、组件、上下游部分)。
在这里插入图片描述

各类引发故障的因素,微信支付采取了相应的应对措施,如

  • 功能/程序缺陷:单元测试,集成测试,UAT 测试,流量回放;
  • 容量不足:常态化压测,自动弹性伸缩;
  • 人为破坏(人因):去登陆 IDC,变更审核,权限控制,模块认证;

但对于软硬件故障,虽然基础组件会涉及一些容错处理,但设计是否全面、开发是否完全实现、真实场景是否有效,没有统一的工具和验收标准,并推动解决。

在这里插入图片描述

如何检验系统具备应对软硬件异常的容灾能力,我们调研了公司和业界的方法,其中演习和混沌工程最为常见和有效。它们都强调在线上实施,目的都是提高系统的可靠性和弹性,但方法和侧重点有所不同(区别两者概念和思路,对实际落地影响较大)。

2.4 可行性论证和控制爆炸半径

落地混沌工程有两大矛盾点:

  • 故障有效,注入的故障贴近实际发生故障环境;
  • 业务安全,注入故障对现网业务无影响或者影响较低。
    在这里插入图片描述

为了贴近真实环境,注入故障离真实环境越近越有效,但这又势必影响业务可用性。且微信支付对可用性要求高,不接受不可预知的风险。如果没有解决业务安全问题,就引入混沌工程“探索未知风险”的期望就较难落地。

在2021年,微信商业支付做了多分区改造,将业务流量路由到不同分区,分区间相互独立、互不影响,分区间环境一致性通过 DevOps 部署保证。在分区隔离的 IDC 环境里注入故障,调配可控的流量,既能贴近生产环境,又能确保故障收敛、控制爆炸半径。这样,微信商户支付落地混沌工程已具备条件和可行性。

在这里插入图片描述

3. 如何落地

从业界落地混沌工程经验来看,基本是围绕 Netflix 提出的5大原则展开。

  • 建立稳定状态的假设:即从用户角度衡量业务健康度,一般业务都有现成的业务监控,大多情况无需额外开发。
  • 用多样的现实世界事件做验证: 即丰富注入故障的类型
  • 自动化实验以持续运行: 即降低人工参与成本

后两者都需要额外开发,但先开发哪些、做到什么程度,可结合业务目标,更多的是开发人力成本和可挖掘到的风险收益之间 ROI 考量。

落地混沌工程的主要难点是:

  • 安全、有效的实验;
  • 高效、全面的发掘风险。

在生产环境中进行实验和控制最小化爆炸半径,是混沌工程的有效性和安全性的两个关键问题。

3.1 安全、有效的实验

不同的技术选型对应的有效性和安全性如下:

最小爆炸半径选择有效性安全性(资源、数据隔离)结论
测试环境不足远离生产环境安全完全隔离不合适
共用线上环境,对特定流量注入受限无法模拟共享的基础设施故障隔离不足负载抢占和数据写脏风险不合适
共用线上环境,扩容金丝雀机器,特定路由受限不能注入组件类的故障隔离不足数据写脏风险不合适同4类似,但非整条链路
独立部署线上无状态服务,和线上共用组件与存储受限不能注入组件类的故障隔离不足数据写脏风险不合适
独立部署线上环境,包括组件与存储有效安全合适成本高,本质等同6
多分区架构上独立混沌分区有效安全合适需解决区外依赖传导

一般来说,有效性和安全性很难同时满足,而且是此消彼长的关系,越是希望真实还原故障,就需要在有业务流量的真实环境中模拟故障,这又会影响业务安全;但若一味追求安全,不能对业务有任务影响,就无法还原故障发生的真实场景,又很难发现问题。可结合实验目标,确定业务能接受最低限度的安全性,来选择有效性最高的方案。

3.2 安全:不影响线上业务

3.2.1 爆炸半径

核心在于,一定要要控制爆炸半径,混沌演习一定在可控的爆炸半径内进行。

爆炸半径的方案选择,在混沌工程实施的不同阶段,也是可以调整的。对系统可用性的信心越足,越是可以贴近真实环境,因此前期可以在有效性低的环境中实验,当实验手段很难发现新问题且发现的问题都已解决时,可以考虑升级到有效性更高的方案。

对微信商业支付,如前文介绍在2021年已经进行了多分区改造,因此我们在多分区架构上,单独规划了分混沌分区路由和4个业务分区,部署的业务逻辑模块、存储、组件等都与生产分区完全一致,前期放入仿真流量到混沌分区后注入故障,当对系统具备足够的信心后,后期在生产分区注入故障。

在这里插入图片描述

由于多分区仅对核心业务做了改造,仍存在外部依赖服务,为了防止混沌实验对外部依赖的影响,对不同场景的风险源做了相应处理:

在这里插入图片描述

3.2.2 特殊限制与审批

考虑”数据篡改“类的故障,可能会导致写脏数据,尤其是篡改业务执行主体(如商户 ID、用户 ID)写脏真实业务数据的风险,因此禁止”篡改执行主体“的故障。

考虑执行的实验的风险,我们对这些场景加了审批:

  • “修改”类的故障加审批。避免写脏异常影响真实环境,由leader二次评估确认。
  • 非资源负责人执行审批。如对他人模块实验(模块混部对母机实验校常见),避免无法发现其它业务异常。
  • 非工作时间实验审批。避免实验异常,干预时间长。

3.3 有效:贴近真实环境

我们主要在隔离的混沌分区实验,实验环境与真实环境一致性越高,真实环境出现类似的问题概率就越大。

3.3.1 静态:部署环境的一致性

部署环境一致性的主要维度如下:

维度一致性需求应对方案
地域同地部署
园区多园区部署,随机选择园区机器实验
机房/交换机/机架对上层相对不透明,且可实验空间较小(爆炸半径过大),项目未要求
机型较少涉及此类差异的故障,线上基本一致,项目未要求
操作系统较少涉及此类差异的故障,线上基本一致,项目未要求
容器一致的容器版本,一致的容器规格
二进制(代码)极高统一部署,完全一致
配置极高统一部署,完全一致

我们将上述高一致性要求的地域、园区、容器、二进制、配置,做到 DevOps 部署工具中,上线模块、发布变更时做到与投产环境一致。

3.3.2 动态:实验流量的逼真度

实验流量与线上接近的目的,一是还原机器/容器负载情况,二是还原业务执行的分支,两者在某些复杂组合场景下,是否会触发未知风险。我们从两个维度来评价流量仿真程度:

流量指标基本要求更高要求
场景覆盖率核心链路覆盖线上所有依赖服务接口
请求并发度平均或峰值 TPS1. 贴近线上各类场景的流量比例2. 贴近线上随时间波动的流量曲线

基于这两个指标,有两个不同方向:

流量类型 建设方法 优点
人造流量 基于业务用例与规则,开发执行脚本

  1. 开发简单

  2. 流量可控性强

流量回放 线上录制,替换并重建资料类数据,mock 边界调用,mock 随机数、时间等系统调用等

流量类型建设方法优点
人造流量基于业务用例与规则,开发执行脚本1. 开发简单2. 流量可控性强
流量回放线上录制,替换并重建资料类数据,mock 边界调用,mock 随机数、时间等系统调用等1. 流量与线上一致性强、丰富度高2. 后期新增场景的投入成本低

考虑前期建设成本和不确定性,我们选择了人造流量方案。

3.4 高效、全面的发掘风险

从0到1建设混沌工程系统和业务落地,我们遇到了这两类问题:

工具业务
零基础,优先做哪些故障原子?先建设故障原子,还是先提升实验效率?如何优先找出高风险?用什么方法找全风险?是否可以少投入,甚至不投入就可以完成混沌实验?
流量回放线上录制,替换并重建资料类数据,mock 边界调用,mock 随机数、时间等系统调用等

我们选择从业务目标出发,优先看高价值的风险点,工具配合业务目标逐步丰富故障原子。根据不同阶段的侧重点,将项目的实施路径拆分两个阶段:

在这里插入图片描述

3.5 发掘高价值风险

前期,人力、工具有限的条件下,如何发掘高价值风险(高 ROI)?

较简单的方法是:随机注入。 工具团队可根据近几年的故障类型,按照优先级开发出对应的故障原子,无差别的注入到目标模块。当前期自动注入、稳态分析不够健全的情况下,仍需人工参与,这种方法有2个局限:

  • 实施的业务团队人力投入大:人工注入故障,人工观察、分析业务监控,以及监控偏离时是否影响业务、是否会扩散风险、是否有其他潜在风险;
  • 工具团队不能做到有的放矢,不能将有效的人力投入到最有价值的原子开发上来。

为了快速找到高价值风险,进而提升大家参与的积极性,我们选了如下2个策略:

  • 实验对象从 高价值 往 低价值 覆盖。根据这个思路,得到了优先实施的模块。1)公共组件:RPC 框架、队列、存储 、缓存,安全认证、日志等;2)生命线业务:收付结退。
    在这里插入图片描述

  • 基于高可用原则拆解,得到工具待开发的原子需求和待注入的资源。
    在这里插入图片描述

设计路径如上图,根据历史故障和常用的高可用要求原则,假设某个组件/业务满足该高可用原则,根据该原则拆解到需注入的故障原子和注入范围(靶点),某个业务或组件待实施的混沌实验计划如下图:
在这里插入图片描述

通过这些策略,我们快速的找到 HTTP 接入模块、事件中心、跨城组件等微信基础组件的多个高风险的共性问题。

3.6 找全风险

后期,如何增强覆盖面,发掘更多未知的黑天鹅风险?

上述方法,只能覆盖到有限的故障域,而实际故障往往是由多个事件同时发生而触发,因此后期加强单原子无差别的注入和组合故障的注入可以发现更多中长尾问题。

对于组合故障,如果也是无差别策略,那么组合空间极大,就以微信支付委托代扣业务为例:

  • 单故障注入:18模块 * 15个故障原子 = 270个,即单原子无差别的注入次数;
  • 2个组合空间为 C2270 = 36315,任一组合空间为2270。

即使工具已经具备自动注入、自动分析的能力,实验周期和消耗资源也将会很高,因此合理的剪枝很有必要,可采用基于相关性由强到弱的多故障组合,如:

  • 模块内构成依赖关联影响(包括三园区容灾设计);
  • 业务内模块间依赖关联影响;
  • 业务间依赖关联影响;
  • 基础设施间依赖关联影响;
  • 潜在依赖关联影响。

总之人力资源有限,抓核心链路,发现核心链路风险是重中之重

4 自动化

从实验流程来看,除了“修复问题”,另外三个流程可以做到一定程度的自动化。

在这里插入图片描述

4.1 自动设计

一个实验任务由4个部分组成:

  • 业务资产:集群、模块、接口;集群是多个模块的总称,如某个存储集群包括接入模块、存储模块、元数据模块;
  • 系统资源:业务资产执行所依赖的机器、容器、网络、CPU、磁盘、进程、文件、内存、共享内存等;
  • 故障类型:针对每种系统资源的有多种故障,如机器包括机器重启、机器时间错误等,如网络包括慢、丢包、乱序等。
  • 故障程度:除个别的像机器重启这类0-1类型故障,其它大多数涉及一定程度的故障,比如网络丢包30%,不同程度下的表现略有不同,一般将故障程度拆解成几档,如丢包有单机内10%、30%、50%、80%、100%,再组合多机情况。

一个实验,首先圈出所包含的业务资产,再整理出其依赖的系统资源(除了磁盘、文件、共享内存这几项,其它一般都包含),再展开系统资源的故障类型,最后确定故障程度,有两种策略:

  • 标记资产类型,如标记为某类存储集群,则套用已设计过的实验模板库生成实验任务;
  • 标记业务所适用的高可用原则,如单机/园区剔除能力、异常防御、分区切换、旁路冗余设计等,裁剪掉全展开的无效程度值,如单机剔除原则只容忍下游单机或单园区机器故障所以不生成多机故障,而做了旁路冗余设计的业务则容许旁路模块的所有机器故障所以生成单机故障的必要性就不大。

因此业务需要做的是:圈定资产范围及依赖的系统资源,并标记资产类型或适用于哪些高可用原则,便可自动生成实验任务。

4.2 自动执行

系统建设不是一蹴而就的,从手工执行到自动化我们经历了三个阶段:

  1. 手动执行单个故障,主要解决0-1的问题,主要精力放在故障原子建设上
  2. 单次批量执行多个故障,采用 yaml 文件记录编排方式,支持串行、并行调度。应用于业务首次实验和定位问题。
  3. 定时执行/事件触发执行,主要用于变更回归和可用性巡检场景,因为定时执行也依赖后续的“自动分析”,所以放在最后。

4.3 自动分析

上述自动执行减少了“点击”操作的工作量,实验要”完全“自动化,还要结合自动分析,即自动判断是否偏离稳态。一是当稳态偏离正常范围及时停止,避免造成次生灾害;二是只有做到自动分析,才能低成本的“定时执行”,否则每次自动执行后都依赖人工分析,不可持续。

我们根据实验的时间(实验开始时间到实验结束后一个周期),自动匹配与之相关的稳态告警:

  • 业务:业务用例维度监控是否触发告警。强优先级,触发后停止实验。
  • 模块:上下游调用关系是否出现告警。中优先级,触发后不停止实验,展示在实验报告中。
  • IP/容器:机器和容器是否出现资源异常告警。中优先级,触发后不停止实验,展示在实验报告中。
  • 业务自定义监控,上述无法自动覆盖的监控,由业务配置后自动收集。

3.8 风险处理

发现的风险的除了负责人处理外,方法:

  • 个性问题:周知组件、业务负责人处理
  • 共性问题,通过 SOA 治理、架构模式化、完善研发流程等手段来大规模消除,达成组织价值最大化。

在这里插入图片描述
对不同时期出现的问题采用不同的策略:

  • 存量:采用了 SOA 治理平台推动修复(SOA 治理是微信支付风险和异常项治理的平台,提供了统一的异常接入、展示、周知、跟进管理的指标数据,在部门内形成了统一的风险治理共识,以快速治理、收敛风险。混沌工程将发现的风险接入 SOA 治理平台,快速治理大面积的共性风险)。
  • 新增:通过 MR 流水线门禁和变更门禁堵住新增,需处理后才能通过。

5. 总结与展望

5.1 总结

本文从业务角度,介绍微信支付实践混沌工程落地的思考,通过多分区的架构来控制最小爆炸半径,首先在高价值的基础组件和微信支付核心业务场景上探索,并基于高可用原则、历史故障分析推导故障原子的开发。发现了多处共性风险,并推动修复和治理。

5.2 更丰富的故障原子建设

有效性和安全性始终是一个权衡取舍的因素,如前文介绍,微信支付在独立的混沌分区架构中实施,前期使用仿真流量,因此除篡改数据类的原子外,在控制请求量的情况下,注入故障的爆炸半径很小、对线上影响极低。

但出于业务安全的思考惯性,我们在建设故障原子时基本是按照演习的思路建设:先摸清组件原理,逐个组件/业务定制原子,导致前期交付周期较长。若在控制爆炸半径的基础上,开放更多故障注入的自由度,注入更多、强度更大的故障,可以低成本的发现更多有价值的风险。

5.3 自动化与稳态识别

自动化包括:注入故障和异常判定,当前系统支持了注入故障的自动化和简单的稳态识别,识别的正确率和召回率还有空间,因此异常判定大多数仍需人工分析。自动异常判定需要较为高级的 AI 能力,很难基于某些特定规则覆盖所有场景。若能做到全面的自动化,其它业务便可低成本落地混沌工程。另外,也可以注入大批量的组合故障,探索更多未知风险。

5.4 支持多类爆炸半径的实验

本文在多分区上部署独立的混沌分区,来控制爆炸半径。而对于非核心支付或者非支付的大多数业务,并没有多分区环境,因此要在其它业务实施混沌工程,仍需结合业务安全和有效性来取舍。

5. 参考文档

  • 微信支付混沌工程实践

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2981569.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

使用BibTeX导入参考文献到Overleaf项目(常用方法)

使用bib为overleaf导入参考文献的好处 整洁的管理: 使用 .bib 文件可以使你的参考文献管理更加整洁和有条理。你可以将所有的参考文献集中存储在一个文件中,而不是在文档中直接引用或复制粘贴。 易于维护和更新: 当你需要添加、删除或修改参考…

WEB攻防-ASP中间件IIS文件上传解析安全漏洞

漏洞原理: 基于文件 IIS6.0默认不解析;号后面的内容,例如1.asp;.jpg会当成1.asp解析,相当于分号截断。 基于文件夹 IIS6.0会将/*.asp/文件夹下的文件当成asp解析。 案例: 写一个木马文件,并改为jpg后缀 GIF89agif8…

报名 | Qt汽车及工业行业解决方案及实战训练 深圳站(5月15日 星期三)

加入我们的Qt技术培训,探索跨平台应用开发的无限可能!本次培训将深入Qt框架,涵盖从基础概念到高级功能的全方位知识,无论您是刚入门的新手还是希望提升技能的资深开发者,都能在此找到适合自己的学习路径。通过实践案例…

python学习笔记(集合)

知识点思维导图 # 直接使用{}进行创建 s{10,20,30,40} print(s)# 使用内置函数set()创建 sset() print(s)# 创建一个空的{}默认是字典类型 s{} print(s,type(s))sset(helloworld) print(s) sset([10,20,30]) print(s) s1set(range(1,10)) print(s1)print(max:,max(s1)) print(m…

OceanBase 开发者大会 - 见闻与洞察

文章目录 前言主论坛见闻技术专场见闻产品技术专场技术生态专场 同行论道启发互动展区写在最后 前言 4 月 20 日,我有幸受邀参加了第二届 OceanBase 开发者大会。 50 余位业界知名数据库大咖和数据库爱好者,与来自全国近 600 名开发者相聚。共同探讨一体…

【01-机器学习入门:理解Scikit-learn与Python的关系】

文章目录 前言Python与机器学习Scikit-learn简介Scikit-learn与Python的关系使用Scikit-learn进行机器学习结语前言 在当今的数据科学和人工智能领域,机器学习已经成为了一个不可或缺的组成部分。而对于那些刚刚踏入这一领域的新手来说,理解机器学习的基本概念和找到合适的工…

Security初探(二)

SpringSecurity初探(一)-CSDN博客 上面介绍了用了在SpringBoot里配置UserDetailsService和PasswordEncoder两个Bean 下面介绍一种替换掉上面两个Bean的方式 看下效果实际是和创建UserDetailsService和PassswordEncoder两个Bean的效果是一样的 还有一种方式混合搭配 当然不推…

【C语言__指针01__复习篇11】

目录 前言 一、什么是指针 二、计算机中常见的单位 三、CPU是怎样找到一块内存空间的 四、如何得到变量的地址 五、指针变量 六、解引用指针变量的作用 七、指针变量的大小 八、指针变量类型的意义 8.1 指针的解引用 8.2 指针-整数 九、void*指针 十、const修饰变…

【算法学习】线段树基础版

一 线段树 1.概念 线段树可以理解为一个二叉树,如果是利用线段树求区间的和,那么每个结点的权值维护的是结点所维护区间的和,再将该区间一分为二,分别交由左右儿子维护。 拿区间1 - 4的和来举例子, 根结点维护的是区…

开发简易复用 SDK(项目加分项)

文章目录 开发 SDK新建项目修改pom文件删除启动类创建配置类复制之前的客户端新建spring.factories打包 开发 SDK 为什么要开发SDK。 减少代码的冗余提高代码的复用 如果实际项目中需要使用到该SDK,在pom.xml中注入就可以了。 类似于maven一样,把需要…

ctfshow——XSS

文章目录 XSS介绍什么是xss&#xff1f;XSS危害XSS的分类常用XSSpayload web316——反射型XSSweb317——过滤<script> web318——过滤script、imgweb319——不止过滤script、imgweb320——过滤空格web321——不止过滤空格web322——不止过滤空格web323web324web 325web32…

618买什么最划算?618买什么东西便宜?必备数码好物清单分享

​只不&#xff0c;马上又到了618购物节咯&#xff0c;数码产品的优惠力度尤为显著&#xff0c;是购买数码产品的绝佳时机。接下来&#xff0c;我将为大家分享几款性价比超高的数码产品&#xff0c;相信总有一款能吸引你的目光。 一、南卡OE MIX开放式蓝牙耳机 在618购物狂欢节…

深兰科技入选2024全国“人工智能+”行动创新案例TOP100

近日&#xff0c;中科院《互联网周刊》联合eNET研究院、德本咨询、中国社会科学院信息化研究中心共同发布了《2024全国“人工智能”行动创新案例TOP100》榜单。经评委会层层遴选&#xff0c;深兰科技专为洛阳市打造的“工业智能化洛阳中心”项目成功入围该榜单。一同入围的还包…

IP-guard getdatarecord 存在任意文件读取

声明 本文仅用于技术交流&#xff0c;请勿用于非法用途 由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;文章作者不为此承担任何责任。 一、产品介绍 IP-guard是由溢信科技股份有限公司开发的一款终端安全管…

案例:SpringBoot集成Sharding-JDBC实现分表分库与主从同步(详细版)

案例&#xff1a;SpringBoot集成Sharding-JDBC实现分表分库与主从同步&#xff1a;详细版 1. 案例分析2. 主从同步2.1 主从数据库准备2.2 简单插点数据 3 案例代码3.1 application.properties配置信息3.2 测试 4. 遇到的坑4.1 水平分表时的属性设置4.2 绑定表的配置 1. 案例分析…

边缘计算是什么?

一、边缘计算是什么&#xff1f; 边缘计算是一种分布式计算范式&#xff0c;它将计算任务和数据存储从中心化的云端推向网络的边缘&#xff0c;即设备或终端&#xff0c;以提高响应速度和降低网络带宽需求。在边缘计算中&#xff0c;数据在源头附近进行处理和分析&#x…

Sectigo证书申请流程及价格介绍

Sectigo 是一家全球知名的数字证书颁发机构&#xff08;Certificate Authority, CA&#xff09;&#xff0c;自1998年起就开始提供 SSL 证书服务&#xff0c;是全球最早的 CA 机构之一。 一 Sectigo证书申请流程 1 确定证书类型 根据自身的需求确定证书的类型&#xff0c;一…

ArrayList 和LinkedList

目录 ArrayListadd自动扩容ArrayList的remove()方法查找 indexof LinkedListLinkedList的add方法LinkedList的remove方法查找 indexof arraylist和linkedlist的区别 ArrayList ArrayList 的底层是数组队列&#xff0c;相当于动态数组。与 Java 中的数组相比&#xff0c;它的容…

政企单位内外网数据交互,如何保障安全性和合规性?

政府内外网隔离是一种网络安全措施&#xff0c;旨在保护政府内部网络的安全性和保密性。根据国家法律要求&#xff0c;涉及国家秘密的计算机信息系统与公共网络之间必须实行物理隔离。这意味着这些系统应该被完全隔离开来&#xff0c;以防止任何未经授权的访问或数据泄露。其次…

hyperf 三十一 极简DB组件

一 安装及配置 composer require hyperf/db php bin/hyperf.php vendor:publish hyperf/db 默认配置 config/autoload/db.php 如下&#xff0c;数据库支持多库配置&#xff0c;默认为 default。 配置项类型默认值备注driverstring无数据库引擎 支持 pdo 和 mysqlhoststringl…