【新版】系统架构设计师 - 软件架构的演化与维护

news2025/1/6 20:45:27

在这里插入图片描述

个人总结,仅供参考,欢迎加好友一起讨论

文章目录

  • 架构 - 软件架构的演化与维护
  • 考点摘要
  • 软件架构演化和定义
  • 面向对象软件架构演化
    • 对象演化
    • 消息演化
    • 复合片段演化
    • 约束演化
  • 软件架构演化方式
    • 静态演化
    • 动态演化
  • 软件架构演化原则
  • 软件架构演化评估方法
  • 大型网站架构的演化
    • 第一阶段:单体架构
    • 第二阶段:垂直架构
    • 第三阶段:使用缓存改善网站性能
    • 第四阶段:使用服务集群改善网站并发处理能力
    • 第五阶段:数据库读写分离
    • 第六阶段:使用反向代理和CDN加速网站响应
    • 第七阶段:使用分布式文件系统和分布式数据库系统
    • 第八阶段:使用NoSQL和搜索引擎
    • 第九阶段:业务拆分
    • 第十阶段:分布式服务
  • 软件架构维护
    • 软件架构知识管理
    • 架构修改管理
    • 架构版本管理

架构 - 软件架构的演化与维护

考点摘要

  • 软件架构演化和定义(★)
  • 面向对象软件架构演化(★★)
  • 软件架构演化方式(★★)
  • 软件架构演化原则(★★)
  • 软件架构演化评估(★★)
  • 大型网站架构演化(★★)
  • 软件架构维护(★)

第二版架构新教材里新增加内容,对应第10章,新增的内容是关于架构的演化和维护阶段,偏理论多,而且不像架构风格、质量属性那块容易出题。个人认为会出几个选择题,甚至到案例题中有内容涉及。

软件架构一般会经历初始设计、实际使用、修改完善和退化弃用的过程,其中修改完善的过程实际上就是软件架构的演化和维护过程,演化和维护的目的就是为了使软件能够适应环境的变化而进行的纠错性修改和完善性修改等。软件架构的演化和维护过程是一个不断迭代的过程,通过演化和维护,软件架构逐步得到完善,以满足用户需求。

软件架构演化和定义

软件架构的演化就是软件整体结构的演化,演化过程涵盖软件架构的全生命周期,包括软件架构需求的获取、软件架构建模、软件架构文档、软件架构实现以及软件架构维护等阶段。

软件架构演化的重要性体:

  • 架构是整个系统的骨架,是软件系统具备诸多好的特性的保障
  • 软件架构作为软件蓝图为人们宏观管控软件系统的整体复杂性和变化性提供了一条有效途径。

软件架构的演化能降低软件演化的成本的原因:

  • 对系统的软件架构进行的形式化、可视化表示提高了软件的可构造性,便于软件演化。
  • 软件架构设计方案涵盖的整体结构信息、配置信息、约束信息等有助于开发人员充分考虑未来可能出现的演化问题、演化情况和演化环境。
  • 架构设计时对系统组件之间的耦合描述有助于软件系统的动态调整。

软件架构的定义包含组件、连接件、约束三大要素,这类软件架构演化主要关注的就是这三者之间的添加、修改和删除等。

面向对象软件架构演化

假设软件架构对应到具体的架构风格或模式,我们就可以讨论演化的各种具体操作了。面向对象软件架构,结合UML顺序图来进一步讨论各种演化操作。

对象演化

在顺序图中,组件的实体为对象。组件本身包含了众多的属性,如接口、类型、语义等,这些属性的演化是对象自身的演化,对于描述对象之间的交互过程并无影响。因此,会对架构设计的动态行为产生影响的演化只包括AddObject(AO)和DeleteObject(DO)两种。

  • AO表示在顺序图中添加一个新的对象。这种演化一般是在系统需要添加新的对象来实现某种新的功能,或需要将现有对象的某个功能独立以增加架构灵活性的时候发生。
  • DO删除顺序图中现有的一个对象。这种演化一般在系统需要移除某个现有的功能,或需要合并某些对象及其功能来降低架构的复杂度的时候发生。

消息演化

消息是顺序图中的核心元素,包含了名称、源对象、目标对象、时序等信息。消息演化是将消息演化分为AddMessage(AM)、DeleteMessage(DM)、SwapMessageOrder(SMO)、OverturnMessage(OM)、ChangeMessageModule(CMM)5种。

  • AM增添一条新的消息,产生在对象之间需要增加新的交互行为的时候。
  • DM删除当前的一条消息,产生在需要移除某个交互行为的时候,是AM的逆向演化。
  • SMO交换两条消息的时间顺序,发生在需要改变两个交互行为之间关系的时候。
  • OM反转消息的发送对象与接收对象,发生在需要修改某个交互行为本身的时候。
  • CMM改变消息的发送或接收对象,发生在需要修改某个交互行为本身的时候。

复合片段演化

复合片段演化是对象交互关系的控制流描述,表示可能发生在不同场合的交互,与消息同属于连接件范畴。复合片段的演化分为AddFragment(AF)、DeleteFragment(DF)、FragmentTypeChange(FTC)和FragmentConditionChange(FCC)。

  • FCC改变复合片段内部执行的条件,发生在改变当前控制流的执行条件时。自动机中与控制流执行条件相对应的转移包括两个,一个是符合条件时的转移,另一个是不符合条件时的转移,因此每次发生FFC 演化时会同时修改这两个转移的触发事件。
  • AF在某几条消息上新增复合片段,发生在需要增添新的控制流时。复合片段所产生的分支是不同类型的。
  • DF删除某个现有的复合片段,发生在需要移除当前某段控制流时。DF与AF互为逆向演化过程。
  • FTC改变复合片段的类型,发生在需要改变某段控制流时。类型演化意味着交互流程的改变,一般伴随着条件、内部执行序列的同时演化,可以视为复合片段的删除与添加的组合。

约束演化

约束演化是直接对约束信息进行添加和删除。

  • Add Constraint(AC)直接添加新的约束信息,会对架构设计产生直接的影响,需要判断当前设计是否满足新添加的约束要求。
  • Delete Constraint(DC)直接移除某条约束信息,发生在去除某些不必要条件的时候,一般而言架构设计均会满足演化后的约束。

软件架构演化方式

3种典型的分类方法:

  • 按照软件架构的实现方式和实施粒度分类:基于过程和函数的演化、面向对象的演化、基于组件的演化和基于架构的演化。
  • 按照研究方法将软件架构演化方式分为4类:第1类是对演化的支持,如代码模块化的准则、可维护性的指示(如内聚和祸合)、代码重构等;第2类是版本和工程的管理工具;第3类是架构变换的形式方法,包括系统结构和行为变换的模型,以及架构演化的重现风格等;第4类是架构演化的成本收益分析,决定如何增加系统的弹性。
  • 针对软件架构的演化过程是否处于系统运行时期,可以将软件架构演化分为静态演化和动态演化。

软件架构演化时期:

  • 设计时演化
  • 运行前演化
  • 有限制运行时演化
  • 运行时演化

静态演化

软件架构静态演化主要是在设计时演化以及运行前演化。与此相对应的维护方法有3类:更正性维护、适应性维护和完善性维护。

软件的静态演化一般包括如下5个步骤:

  • 软件理解:查阅软件文档,分析软件架构,识别系统组成元素及其之间的相互关系,提取系统的抽象表示形式。
  • 需求变更分析:静态演化往往是由于用户需求变化、系统运行出错和运行环境发生改变等原因所引起的,需要找出新的软件需求与原有的差异。
  • 演化计划:分析原系统,确定演化范围和成本,选择合适的演化计划。
  • 系统重构:根据演化计划对系统进行重构,使之适应当前的需求。
  • 系统测试:对演化后的系统进行测试,查找其中的错误和不足之处

架构演化的可维护性度量基于组件图表示的软件架构。

架构演化的可靠性评估基于用例图、部署图和顺序图。

动态演化

动态演化是在系统运行期间的演化,需要在不停止系统功能的情况下完成演化,较之静态演化更加困难。

架构的动态演化主要来自两类需求:

  • 软件内部执行所导致的体系结构改变,例如,许多服务器端软件会在客户请求到达时创建新的组件来响应用户需求。
  • 软件系统外部的请求对软件进行的重配置,例如,操作系统在升级时无须重新启动,在运行过程中就完成对体系结构的修改。

软件的动态性分为3个级别:

  1. 交互动态性,要求数据在固定的结构下动态交互。
  2. 结构动态性,允许对结构进行修改,通常的形式是组件和连接件实例的添加和删除,这种动态性是研究和应用的主流。
  3. 架构动态性,允许软件架构的基本构造的变动,即结构可以被重定义,如新的组件类型的定义。

根据所修改的内容不同,软件的动态演化主要包括以下4个方面:

  • 属性改名:目前所有的ADL都支持对非功能属性的分析和规约,而在运行过程中,用户可能会对这些指标进行重新定义(如服务响应时间)。
  • 行为变化:在运行过程中,用户需求变化或系统自身服务质量的调节都将引发软件行为的变化。
  • 拓扑结构改变:如增删组件,增删连接件,改变组件与连接件之间的关联关系等。
  • 风格变化:一般软件演化后其架构风格应当保持不变,如果非要改变软件的架构风格,也只能将架构风格变为其衍生风格,如两层C/S到三层C/S。

实现软件架构动态演化的技术主要有两种:

  • 采用动态软件架构(DSA):DSA是指在运行时刻会发生变化的系统框架结构,允许在运行过程中通过框架结构的动态演化实现对架构的修改。

    DSA实施动态演化大体遵循以下4 步:①捕捉并分析需求变化;②获取或生成体系结构演化策略;③根据步骤2得到的演化策略,选择适当的演化策略并实施演化;④演化后的评估与检测。

  • 进行动态重配置(DR):DR从组件和连接件的配置入手,允许在运行过程中增删组件,增删连接件,修改连接关系等操作。主要是指在软件部署之后对配置信息的修改,常常被用于系统动态升级时需要进行的配置信息修改。

    动态重配置可能涉及的修改有:①简单任务的相关实现修改;②工作流实例任务的添加和删除;③组合任务流程中的个体修改;④任务输入来源的添加和删除;⑤任务输入来源的优先级修改;⑥组合任务输出目标的添加和删除;⑦组合任务输出目标的优先级修改等。

    动态重配置模式:主从模式、中央控制模式、客户端/服务器模式、分布式控制模式。

软件架构演化原则

  1. 演化成本控制原则

    演化成本要控制在预期的范围之内,也就是演化成本要明显小于重新开发成本。

    用于判断架构演化的成本是否在可控范围内,以及用户是否可接受。

  2. 进度可控原则

    架构演化要在预期时间内完成,也就是时间成本可控。

    根据该原则可以规划每个演化过程的任务量;体现一种迭代、递增(持续演化)的演化思想。

  3. 风险可控原则

    架构演化过程中的经济风险、时间风险、人力风险、技术风险和环境风险等必须在可控范围内。

    用于判断架构演化过程中各种风险是否易于控制。

  4. 主体维持原则

    保证软件系统主体行为稳定。

    用于判断架构演化是否导致系统主体行为不稳定。

  5. 系统总体结构优化原则

    架构演化要遵循系统总体结构优化原则,使得演化之后的软件系统整体结构(布局)更加合理。

    用于判断系统整体结构是否合理,是否最优。

  6. 平滑演化原则

    在软件系统的生命周期里,软件的演化速率趋于稳定,如相邻版本的更新率相对固定。

    用于判断是否存在剧烈架构演化。

  7. 目标一致原则

    架构演化的阶段目标和最终目标要一致。

    用于判断每个演化过程是否达到阶段目标,所有演化过程结束是否能达到最终目标。

  8. 模块独立演化原则

    软件中各模块(相同制品的模块,如Java的某个类或包)自身的演化最好相互独立,或者至少保证对其他模块的影响比较小或影响范围比较小。

    用于判断每个模块自身的演化是否相互独立。

  9. 影响可控原则

    软件中一个模块如果发生变更,其给其他模块带来的影响要在可控范围内,也就是影响范围可预测。

    用于判断是否存在对某个模块的修改导致大量其他修改的情况。

  10. 复杂性可控原则

    架构演化必须要控制架构的复杂性,从而进一步保障软件的复杂性在可控范围内。

    用于判断演化之后的架构是否易维护、易扩展、易分析、易测试等。

  11. 有利于重构原则

    架构演化要遵循有利于重构原则,使得演化之后的软件架构更便于重构。

    用于判断架构易重构性是否得到提高。

  12. 有利于重用原则

    架构演化最好能维持,甚至提高整体架构的可重用性。

    用于判断整体架构可重用性是否遭到破坏。

  13. 设计原则遵从性原则

    架构演化最好不能与架构设计原则冲突。

    用于判断架构设计原则是否遭到破坏(架构设计原则是好的设计经验总结,要保障其得到充分使用)。

  14. 适应新技术原则

    软件要独立于特定的技术手段,这样才能够让软件运行于不同平台。

    用于判断架构演化是否存在对某种技术依赖过强的情况。

  15. 环境适应性原则

    架构演化后的软件版本能够比较容易适应新的硬件环境与软件环境。

    用于判断架构在不同环境下是否仍然可使用,或者容易进行环境配置。

  16. 标准侬从性原则

    架构演化不会违背相关质量标准(国际标准、国家标准、行业标准、企业标准等)。

    用于判断架构演化是否具有规范性,是否有章可循;而不是胡乱或随意地演化。

  17. 质量向好原则

    通过演化使得所关注的某个质量指标或某些质量指标的综合效果变得更好或者更满意,例如可靠性提高了。

    用于判断架构演化是否导致某些质量指标变得很差。

  18. 适应新需求原则

    架构演化要很容易适应新的需求变更;架构演化不能降低原有架构适应新需求的能力;架构演化最好可以提高适应新需求的能力。

    用于判断演化之后的架构是否降低了架构适应新需求的能力。

软件架构演化评估方法

根据演化过程是否已知可将评估过程分为:演化过程已知的评估和演化过程未知的评估。

  • 演化过程己知的评估其目的在于通过对架构演化过程进行度量,比较架构内部结构上的差异以及由此导致的外部质量属性上的变化,对该演化过程中相关质量属性进行评估。

    基于度量的架构演化评估方法,其基本思路在于通过对演化前后的软件架构进行度量,比较架构内部结构上的差异以及由此导致的外部质量属性上的变化。具体包括:架构修改影响分析、监控演化过程、分析关键演化过程。

  • 当演化过程未知时,我们无法像演化过程已知时那样追踪架构在演化过程中的每一步变化,只能根据架构演化前后的度量结果逆向推测出架构发生了哪些改变,并分析这些改变与架构相关质量属性的关联关系。

大型网站架构的演化

解决庞大用户访问,海量数据和高并发问题

第一阶段:单体架构

应用程序、数据库、文件等所有资源都在一台服务器上。

在这里插入图片描述

第二阶段:垂直架构

将应用和数据分离。应用和数据分离后整个网站使用3台服务器:应用服务器、文件服务器和数据库服务器。这3台服务器对硬件资源的要求各不相同:

  • 应用服务器需要处理大量的业务逻辑,因此需要更快更强大的处理器速度。
  • 数据库服务器需要快速磁盘检索和数据缓存,因此需要更快的磁盘和更大的内存。
  • 文件服务器需要存储大量用户上传的文件,因此需要更大容量的硬盘

在这里插入图片描述

第三阶段:使用缓存改善网站性能

缓存可以分为两种:缓存在应用服务器上的本地缓存和缓存在专门的分布式缓存服务器上的远程缓存。

在这里插入图片描述

第四阶段:使用服务集群改善网站并发处理能力

在这里插入图片描述

系统演变到这里,将会出现下面几个问题:

  • 用户的请求由谁来转发到具体的应用服务器
  • 用户如果每次访问到的服务器不一样,那么如何维护session的一致性

相关负载均衡问题,可以参考:案例分析 - 架构设计<Web架构>中的负载均衡和session有无状态的等相关技术。

第五阶段:数据库读写分离

改善数据库负载压力,可以实现数据库读写分离。

应用服务器在写数据的时候,访问主数据库,主数据库通过主从复制机制将数据更新同步到从数据库,这样当应用服务器读数据的时候,就可以通过从数据库获得数据。为了便于应用程序访问读写分离后的数据库,通常在应用服务器端使用专门的数据访问模块,使数据库读写分离对应用透明。

在这里插入图片描述

相关主从复制问题,可以参考:案例分析 - 数据库设计中的数据库主从复制等相关技术。

第六阶段:使用反向代理和CDN加速网站响应

由于区域的差别使得网络环境异常复杂,不同地区的用户访问网站时,速度差别也极大。网站需要加速网站访问速度。主要手段有使用CDN和反向代理。 CDN和反向代理的基本原理都是缓存。

在这里插入图片描述

CDN部署在网络提供商的机房,使用户在请求网站服务时,可以从距离自己最近的网络提供商机房获取数据。

反向代理则部署在网站的中心机房,当用户请求到达中心机房后,首先访问的服务器是反向代理服务器,如果反向代理服务器中缓存着用户请求的资源,就将其直接返回给用户。

使用CDN和反向代理的目的都是尽早返回数据给用户,一方面加快用户访问速度,另一方面也减轻后端服务器的负载压力。

第七阶段:使用分布式文件系统和分布式数据库系统

数据库经过读写分离后,从一台服务器拆分成两台服务器,但是随着网站业务的发展依然不能满足需求,这时需要使用分布式数据库。文件系统也一样,需要使用分布式文件系统。

在这里插入图片描述

第八阶段:使用NoSQL和搜索引擎

随着网站业务越来越复杂,对数据存储和检索的需求也越来越复杂,网站需要采用一些非关系数据库技术如NoSQL和非数据库查询技术如搜索引擎。

在这里插入图片描述
相关NoSQL问题,可以参考:案例分析 - 数据库设计中的NoSQL和Redis等相关技术。

第九阶段:业务拆分

大型网站为了应对日益复杂的业务场景,通过使用分而治之的手段将整个网站业务分成不同的产品线。如大型购物交易网站都会将首页、商铺、订单、买家、卖家等拆分成不同的产品线,分归不同的业务团队负责。

具体到技术上,也会根据产品线划分,将一个网站拆分成许多不同的应用,每个应用独立部署。应用之间可以通过一个超链接建立关系(在首页上的导航链接每个都指向不同的应用地址),也可以通过消息队列进行数据分发,当然最多的还是通过访问同一个数据存储系统来构成一个关联的完整系统。

在这里插入图片描述

第十阶段:分布式服务

大型网站的架构演化到这里,基本上大多数的技术问题都得以解决,诸如跨数据中心的实时数据同步和具体网站业务相关的问题也都可以通过组合改进现有技术架构解决。

在这里插入图片描述

软件架构维护

软件架构维护过程一般分为:架构知识管理、架构修改管理和架构版本管理。

软件架构知识管理

软件架构知识管理是对架构设计中所隐含的决策来源进行文档化表示,进而在架构维护过程中帮助维护人员对架构的修改进行完善的考虑,并能够为其他软件架构的相关活动提供参考。

架构知识的定义:架构知识 = 架构设计+架构设计决策,即需要说明在进行架构设计时采用此种架构的原因。

架构知识管理侧重于软件开发和实现过程所涉及的架构静态演化,从架构文档等信息来源中捕捉架构知识,进而提供架构的质量属性及其设计依据以进行记录和评价。

架构修改管理

在软件架构修改管理中,一个主要的做法就是建立一个隔离区域保障该区域中任何修改对其他部分的影响比较小,甚至没有影响。需要明确修改规则、修改类型,以及可能的影响范围和副作用等。

架构版本管理

软件架构版本管理为软件架构演化的版本演化控制、使用和评价等提供了可靠的依据,并为架构演化量化度量奠定了基础。

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

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

相关文章

JVM对象创建与内存分配机制

对象的创建 对象创建的主要流程: ​ 1.类加载检查 虚拟机遇到一条new指令时,首先将去检查这个指令的参数是否能在常量池中定位到一个类的符号引用,并且检查这个符号引用代表的类是否已被加载、解析和初始化过。如果没有,那必须先执行相应…

如何在Python中捕获异常

1. 写在前面 本文主要介绍 Python 捕获异常的各种技术。首先,回顾 Python 的异常处理机制,然后深入研究并学习如何识别捕获的异常内容,以及忽略异常。 公众号: 滑翔的纸飞机 2. Python 异常处理机制 Python 代码在运行的过程中&…

5-1.(OOP)初步分析MCV架构模式

组成:模型(model)、视图(view)、控制器(controller) view:界面、显示数据 model:数据管理、负责在数据库中存取数据以及数据合法性验证 controller:负责转…

uni-app:顶部标题栏的部分相关设置(标题更改, 加载效果)

一、标题更改 效果 方法一:在pages.json中进行修改 {"path": "pages/index/index","style": {"navigationBarTitleText": "自定义标题"} }, 方法二:在页面直接进行修改 onLoad() {// 设置页面的标…

Spring Boot 如何配置 CORS 支持

Spring Boot 如何配置 CORS 支持 跨域资源共享(CORS)是一种重要的网络安全策略,用于限制浏览器在不同域之间的HTTP请求。Spring Boot提供了简单而强大的方法来配置CORS支持,以确保您的应用程序能够与其他域的资源进行安全交互。本…

某高校的毕设

最近通过某个平台接的单子,最后Kali做的测试没有公开可以私聊给教程。 下面是规划与配置 1.vlan方面:推荐一个vlan下的所有主机为一个子网网段 连接电脑和http客户端的接口配置为access接口 交换机与交换机或路由器连接的接口配置为trunk接口---也可以…

电商项目高级篇-02 elasticsearch-下

电商项目高级篇-02 elasticsearch-下 4.2、QueryDSL返回指定字段 4.2、QueryDSL 返回指定字段 返回单个字段 GET bank/_search {"query": {"match_all": {}}, "sort": [{"balance": {"order": "desc"}}], &quo…

IoTDB 在国际数据库性能测试排行榜中位居第一?测试环境复现与流程详解第一弹!...

最近我们得知,Apache IoTDB 多项性能表现位居 benchANT 时序数据库排行榜(Time Series: DevOps)性能排行第一名!(榜单地址:https://benchANT.com/ranking/database-ranking) benchANT 位于德国&…

计算机竞赛 深度学习卫星遥感图像检测与识别 -opencv python 目标检测

文章目录 0 前言1 课题背景2 实现效果3 Yolov5算法4 数据处理和训练5 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 **深度学习卫星遥感图像检测与识别 ** 该项目较为新颖,适合作为竞赛课题方向,学长非常推荐…

【Vue】动态树与数据表格分页查询实现

目录 一、动态树 1.1 准备工作 1.1.1 准备数据库 1.1.2 准备好后台服务接口,Moudel查询,和Book查询(支持分页) 1.1.3 修改mock.js测试环境 1.1.4 配置请求路径 1.2 构建导航菜单 1.2.1 通过接口获取数据 1.2.2 通过后台获…

【LFU缓存机制】+双哈希表解法+排序解法

文章目录 Tag题目来源题目解读解题思路方法一:排序解法方法二:双哈希表 知识回顾双向链表的操作 写在最后 Tag 【LFU缓存】【哈希表】【设计数据结构】【2023-09-25】 题目来源 460. LFU 缓存 题目解读 为 LFU 缓存算法设计并实现数据结构。 LRU 缓存…

k8s集群安装v1.20.9后-2-改造部署自己的服务k8sApp,增加istio

1.环境准备: K8s集群,已经实现了k8s-app小例子,可以正常访问。(已包含docker) 在此基础上对项目进行改进,实现istio流量切换。 2.安装部署istio 2.1 安装go 官网下载go和istio的安装包,上传到k8s集群虚拟机上(三个机器都安装) [root@node1 ~]# cd /root/Public/i…

CSS实现围绕按钮边框转圈的光线效果

CSS实现围绕按钮边框转圈的光线效果&#xff0c;可以自由改变按钮的光线渐变颜色和按钮边框颜色&#xff0c;背景色等。 效果图&#xff1a; 实现完整代码&#xff1a; <template><view class"btnBlock"><view class"btnBian"></vi…

MySQL MHA 高可用

目录 1 MySQL MHA 1.1 什么是 MHA 1.2 MHA 的组成 1.3 MHA 的特点 2 搭建 MySQL MHA 2.1 Master、Slave1、Slave2 节点上安装 mysql5.7 2.2 修改 Master、Slave1、Slave2 节点的主机名 2.3 修改 Master、Slave1、Slave2 节点的 Mysql主配置文件/etc/my.cnf 2.4 在 Mast…

现代架构设计:构建可伸缩、高性能的分布式系统

文章目录 第1节&#xff1a;引言第2节&#xff1a;架构设计的关键原则2.1 微服务架构2.2 异步通信2.3 数据分区和复制2.4 负载均衡 第3节&#xff1a;代码示例3.1 创建产品服务3.2 创建消息队列3.3 创建产品更新服务 第4节&#xff1a;性能优化和监控4.1 建立性能基准4.2 水平扩…

国内大语言模型的相对比较:ChatGLM2-6B、BAICHUAN2-7B、通义千问-6B、ChatGPT3.5

一、 前言 国产大模型有很多&#xff0c;比如文心一言、通义千问、星火、MOSS 和 ChatGLM 等等&#xff0c;但现在明确可以部署在本地并且开放 api 的只有 MOOS 和 ChatGLM。MOOS 由于需要的 GPU 显存过大&#xff08;不量化的情况下需要80GB&#xff0c;多轮对话还是会爆显存…

Spring整合RabbitMQ——生产者(利用配置类)

1.生产者配置步骤 2.引入依赖 3.编写配置 配置RabbitMQ的基本信息&#xff0c;用来创建连接工厂的 编写启动类 编写配置类 4. 编写测试类

C#(CSharp)入门教程

目录 C#的第一个程序 变量 折叠代码 变量类型和声明变量 获取变量类型所占内存空间&#xff08;sizeof&#xff09; 常量 转义字符 隐式转换 显示转换 异常捕获 运算符 算术运算符 布尔逻辑运算符 关系运算符 位运算符 其他运算符 字符串拼接 …

unity lua开发体系搭建

在前面的文章里面我们已经介绍了怎么样在unity里面配置lua的开发环境&#xff0c;我们可以通过C#代码装载lua的脚本并执行相应的处理&#xff0c;这次我们一步步搭建下lua的开发体系。 1.基于c#体系所有的类都继承MonoBehaviour在这里lua环境下我们也需要创建一个类似于这个类的…

Stm32_标准库_呼吸灯_按键控制

Stm32按键和输出差不多 PA1为LED供给正电&#xff0c;PB5放置按键&#xff0c;按键一端接PB5,另一端接负极 void Key_Init(void){RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE); //APB2总线连接着GPIOBGPIO_InitStructur.GPIO_Mode GPIO_Mode_IPU;GPIO_InitStructur.…