微服务架构10个最重要的设计模式,带你了解,完全熟悉

news2024/11/26 0:50:57

自从软件开发的早期(1960年代)以来,解决大型软件系统中的复杂性一直是一项艰巨的任务。多年来,软件工程师和架构师为解决软件系统的复杂性进行了许多尝试:David Parnas的模块化和信息隐藏(1972),Edsger W. Dijkstra的关注分离(1974),面向服务的体系结构(1998)。

img

他们所有人都使用了久经考验的成熟技术来解决大型系统的复杂性:分而治之。自2010年代以来,这些技术不足以解决Web规模应用程序或现代大型企业应用程序的复杂性。结果,架构师和工程师开发了一种新方法来解决现代软件系统的复杂性:微服务架构。它也使用了相同的旧"分而治之"技术,尽管采用了新颖的方式。

软件设计模式是解决软件设计中常见问题的通用,可重用的解决方案。设计模式可帮助我们共享通用词汇,并使用经过实战检验的解决方案,而不是重新发明轮子。今天描述的是一组设计模式,以帮助您实现这些最佳实践。

本文主要内容:

· 微服务架构

· 微服务架构的优势

· 微服务架构的缺点

· 何时使用微服务架构

· 微服务架构设计模式

请注意,此清单的大多数设计模式都有几种上下文,可以在非微服务体系结构中使用。但是我将在微服务架构的背景下对其进行描述。

微服务架构

**微服务体系结构:**简要概述以及为什么要在下一个项目中使用它以及模块化单片软件体系结构真的死了吗?

我的微服务架构定义是:

微服务架构旨在将大型,复杂的系统垂直(按功能或业务要求)划分为较小的子系统,这些子系统属于流程(因此可独立部署),并且这些子系统之间通过与语言无关的轻量级网络通信相互通信(例如REST,gRPC)或异步(通过消息传递)方式。

这是具有微服务架构的业务Web应用程序的组件视图:

img

> Microservice Architecture by Md Kamaruzzaman

微服务架构的重要特征

· 整个应用程序分为多个单独的进程,每个进程可以包含多个内部模块。

· 与模块化Monoliths或SOA相反,微服务应用程序是垂直拆分的(根据业务能力或领域)微服务边界是外部的。结果,微服务通过网络调用(RPC或消息)相互通信。

· 由于微服务是独立的流程,因此它们可以独立部署。他们以轻巧的方式交流,不需要任何智能交流渠道。

微服务架构的优势

· 更好的开发规模。

· 更高的发展速度。

· 支持迭代或增量现代化。

· 充分利用现代软件开发生态系统(云,容器,DevOps,无服务器)的优势。

· 支持水平缩放和粒度缩放。

· 由于尺寸较小,它降低了开发人员的认知复杂度。

微服务架构的缺点

· 大量的活动部件(服务,数据库,流程,容器,框架)。

· 复杂性从代码转移到基础架构。

· RPC调用和网络流量的激增。

· 管理整个系统的安全性具有挑战性。

· 设计整个系统比较困难。

· 介绍分布式系统的复杂性。

何时使用微服务架构:

· Web规模应用程序开发。

· 当多个团队处理应用程序时,进行企业应用程序开发。

· 长期收益优先于短期收益。

· 该团队拥有能够设计微服务架构的软件架构师或高级工程师。

微服务架构的设计模式

每个微服务独占数据库

一旦公司用许多较小的微服务替换了大型的单片系统,它面临的最重要的决定就是关于数据库。在整体架构中,使用大型中央数据库。许多架构师都喜欢保留数据库原样,即使他们转向微服务架构也是如此。尽管它提供了一些短期好处,但它是一种反模式,尤其是在大规模系统中,因为微服务将紧密耦合在数据库层中。转向微服务的整个目标将失败(例如,团队授权,独立开发)。

更好的方法是为每个微服务都提供自己的数据存储,以使数据库层中的服务之间不存在强耦合。在这里,我使用数据库一词来表示数据的逻辑分离,即微服务可以共享同一物理数据库,但是它们应该使用单独的架构/集合/表。它还将确保根据域驱动设计正确隔离微服务。

img

> Database per Microservice by Md Kamaruzzaman

优点:

· 数据对服务的完全所有权。

· 开发服务的团队之间的松耦合。

缺点:

· 在服务之间共享数据变得充满挑战。

· 提供应用程序范围的ACID事务保证变得更加困难。

· 将Monolith数据库分解为较小的零件需要仔细设计,这是一项艰巨的任务。

每个微服务何时使用数据库:

· 在大型企业中的应用。

· 当团队需要其微服务的完全所有权以进行开发扩展和提高开发速度时。

什么时候不使用每个微服务的数据库:

· 在小型应用中。

· 如果一个团队开发所有微服务。

启用技术示例

所有SQL和NoSQL数据库都提供逻辑上的数据分离(例如,分离的表,集合,模式,数据库)。

事件源 Event Sourcing

在微服务架构中,尤其是在每个微服务使用数据库的情况下,微服务需要交换数据。对于有弹性,高度可扩展和容错的系统,它们应通过交换事件进行异步通信。

在这种情况下,可能需要进行原子操作,例如,更新数据库并发送消息。如果您有SQL数据库,并且希望为大量数据分配分布式事务,则不能使用两阶段锁定(2PL),因为它无法扩展。

如果使用NoSQL数据库并希望具有分布式事务,则不能使用2PL,因为许多NoSQL数据库不支持两阶段锁定。

在这种情况下,请结合使用基于事件的体系结构和事件源。在传统数据库中,具有当前"状态"的业务实体被直接存储。在事件源中,将存储任何状态更改事件或其他重要事件,而不是实体。

这意味着业务实体的修改将保存为一系列不可变的事件。通过在给定时间重新处理该业务实体的所有事件,可以扣除该业务实体的状态。因为数据存储为一系列事件,而不是通过直接更新数据存储来存储,所以各种服务可以从事件存储中重播事件以计算其各自数据存储的适当状态。

img

> Event Sourcing by Md Kamaruzzaman

优点:

· 为高度可扩展的系统提供原子性。

· 实体的自动历史记录,包括时间旅行功能。

· 松散耦合和事件驱动的微服务。

缺点:

· 从事件存储中读取实体变得具有挑战性,通常需要额外的数据存储(CQRS模式)

· 系统的整体复杂性增加,通常需要域驱动设计。

· 系统需要处理重复事件(幂等)或丢失事件。

· 迁移事件模式变得具有挑战性。

何时使用事件来源:

· 具有SQL数据库的高度可扩展的事务系统。

· 带有NoSQL数据库的事务系统。

· 高度可扩展且具有弹性的微服务架构。

· 典型的消息驱动或事件驱动系统(电子商务,预订和预订系统)。

何时不使用事件来源:

· 具有SQL数据库的低伸缩性事务系统。

· 在简单的微服务架构中,微服务可以同步交换数据(例如,通过API)。

启用技术示例

· **事件存储:**EventStoreDB,Apache Kafka,Confluent Cloud,AWS Kinesis,Azure事件中心,GCP发布/订阅,Azure Cosmos DB,MongoDB,Cassandra。Amazon DynamoDB,

· **框架:**Lagom,Akka,Spring,akkatecture,Axon,Eventuate

命令查询职责隔离(CQRS)

如果我们使用事件源,那么从事件存储中读取数据将变得充满挑战。要从数据存储中获取实体,我们需要处理所有实体事件。另外,有时我们对读写操作有不同的一致性和吞吐量要求。

在这种用例中,我们可以使用CQRS模式。在CQRS模式中,系统的数据修改部分(命令)与数据读取(查询)部分分开。CQRS模式有两种形式:简单和高级,这导致软件工程师之间产生一些混淆。

以简单的形式,不同的实体或ORM模型用于读取和写入,如下所示:

img

> CQRS (simple) by Md Kamaruzzaman

它有助于实施"单一责任原则"和"关注点分离",从而使设计更简洁。

在其高级形式中,不同的数据存储区用于读取和写入操作。高级CQRS与事件来源一起使用。根据使用情况,使用不同类型的写入数据存储和读取数据存储。写入数据存储区是"记录系统",即整个系统的黄金来源。

img

> CQRS (advanced) by Md Kamaruzzaman

对于重读应用程序或微服务体系结构,将OLTP数据库(任何提供ACID事务保证的SQL或NoSQL数据库)或分布式消息平台用作写存储。对于繁重的写程序(高写可伸缩性和吞吐量),使用了水平可写伸缩的数据库(公共云全局数据库)。规范化的数据保存在写入数据存储中。

为搜索(例如Apache Solr,Elasticsearch)或读取(键值数据存储,文档数据存储)而优化的NoSQL数据库用作读取存储。在许多情况下,在需要SQL查询的地方使用可伸缩的SQL数据库。归一化和优化的数据将保存在读取存储中。

数据从写入存储异步复制到读取存储。结果,读存储区滞后于写存储区,并且最终保持一致。

优点:

· 在事件驱动的微服务中更快地读取数据。

· 数据的高可用性。

· 读写系统可以独立扩展。

缺点:

· 读取数据存储弱一致性(最终一致性)

· 系统的整体复杂性增加。货运培训CQRS可能会严重危害整个项目。

何时使用CQRS:

· 在使用事件源的高度可扩展的微服务体系结构中。

· 在读取数据需要查询到多个数据存储区的复杂域模型中。

· 在读写操作具有不同负载的系统中。

何时不使用CQRS:

· 在微事件数量微不足道的微服务体系结构中,使用事件存储快照来计算实体状态是更好的选择。

· 在读写操作具有相似负载的系统中。

启用技术示例

· **写存储:**EventStoreDB,Apache Kafka,Confluent Cloud,AWS Kinesis,Azure Event Hub,GCP发布/订阅,Azure Cosmos DB,MongoDB,Cassandra。亚马逊DynamoDB

· **阅读商店:**Elastic Search,Solr,Cloud Spanner,Amazon Aurora,Azure Cosmos DB,Neo4j

· **框架:**Lagom,Akka,Spring,akkatecture,Axon,Eventuate

SAGA

如果您将微服务体系结构与每个微服务的数据库一起使用,那么通过分布式事务管理一致性就具有挑战性。您不能使用传统的两阶段提交协议,因为它无法扩展(SQL数据库)或不被支持(许多NoSQL数据库)。

您可以将Saga模式用于Microservice Architecture中的分布式事务。Saga是一种旧模式,于1987年开发,作为SQL数据库中长期运行的数据库事务的概念替代方案。但是,这种模式的现代变体对于分布式事务也非常有效。Saga模式是一个本地事务序列,其中每个事务在单个微服务中更新数据存储中的数据并发布事件或消息。传奇中的第一个事务由外部请求(事件或操作)启动。一旦本地事务完成(数据存储在数据存储中,并且发布消息或事件),发布的消息/事件将触发Saga中的下一个本地事务。

img

> Saga by Md Kamaruzzaman

如果本地事务失败,则Saga执行一系列补偿事务,以撤消先前本地事务的更改。

Saga交易协调主要有两种变体:

· 分散的协调,每个微服务生成并收听其他微服务的事件/消息,并决定是否应该采取措施。

· 统筹协调,协调器告诉协调的微服务哪些本地事务需要执行。

优点:

· 通过高度可扩展的或松散耦合的,事件驱动的微服务架构中的事务来提供一致性。

· 通过使用没有2PC支持的NoSQL数据库的微服务体系结构中的事务来提供一致性。

缺点:

· 需要处理短暂故障,并应提供幂等性。

· 难以调试,并且随着微服务数量的增加,复杂性也随之增加。

何时使用

· 在使用事件源的高度可扩展的,松散耦合的微服务架构中。

· 在使用分布式NoSQL数据库的系统中。

什么时候不使用

· 具有SQL数据库的低伸缩性事务系统。

· 在服务之间存在循环依赖性的系统中。

启用技术示例:

Axon,Eventuate,Narayana

前端的后端(BFF)

在现代业务应用程序开发中,尤其是在微服务体系结构中,前端和后端应用程序是分离的和独立的服务。它们通过API或GraphQL连接。如果应用程序还具有Mobile App客户端,则对Web和Mobile客户端使用相同的后端微服务将成为问题。移动客户端的API要求通常与Web客户端不同,因为它们具有不同的屏幕大小,显示,性能,能源和网络带宽。

后端的后端模式可用于每个UI都有为特定UI定制的单独后端的场景。它还提供了其他优势,例如充当下游微服务的外观,从而减少了UI与下游微服务之间的闲聊通信。同样,在高度安全的情况下,下游微服务部署在DMZ网络中,BFF用于提供更高的安全性。

img

> Backends for Frontends by Md Kamaruzzaman

优点:

· BFF之间的关注点分离。我们可以针对特定的UI优化它们。

· 提供更高的安全性。

· 减少UI与下游微服务之间的交流。

缺点:

· BFF之间的代码重复。

· 如果使用其他许多UI(例如,智能电视,Web,移动设备,台式机),BFF的数量也会激增。

· BFF不应包含任何业务逻辑,而应仅包含特定于客户的逻辑和行为,因此需要仔细设计和实施。

何时将后端用于前端:

· 如果应用程序具有多个具有不同API要求的UI。

· 如果出于安全原因在UI和下游微服务之间需要额外的一层。

· 如果在UI开发中使用微前端。

何时不使用后端作为前端:

· 如果应用程序具有多个UI,但是它们使用相同的API。

· 如果未在DMZ中部署核心微服务。

启用技术示例:

任何后端框架(Node.js,Spring,Django,Laravel,Flask,Play等)都支持它。

API网关

在微服务架构中,UI通常与多个微服务连接。如果微服务是细粒度的(FaaS),则客户端可能需要连接许多微服务,这变得很繁琐且具有挑战性。而且,服务(包括其API)可以发展。大型企业还希望拥有其他跨领域的问题(SSL终止,身份验证,授权,限制,日志记录等)。

解决这些问题的一种可能方法是使用API网关。API网关位于客户端APP和后端微服务之间,并充当外观。它可以用作反向代理,将客户端请求路由到适当的后端微服务。它还可以支持将客户端请求的扇出扩展到多个微服务,然后将汇总的响应返回给客户端。它还支持基本的跨领域关注。

img

> API Gateway by Md Kamaruzzaman

优点:

· 提供前端和后端微服务之间的松散耦合。

· 减少客户端和微服务之间的往返呼叫次数。

· 通过SSL终止,身份验证和授权实现高安全性。

· 集中管理的跨领域问题,例如日志记录和监视,节流,负载平衡。

缺点:

· 可能导致微服务架构中的单点故障。

· 由于额外的网络呼叫,延迟增加了。

· 如果不进行扩展,它们很容易成为整个企业的瓶颈。

· 额外的维护和开发成本。

何时使用API网关:

· 在复杂的微服务架构中,这几乎是强制性的。

· 在大型公司中,必须使用API网关来集中安全性和跨领域问题。

何时不使用API网关:

· 在安全性和中央管理不是最高优先级的私人项目或小型公司中。

· 如果微服务的数量很小。

启用技术示例:

Amazon API Gateway,Azure API管理,Apigee,Kong,WSO2 API管理器

扼杀者

如果要在棕地项目中使用微服务架构,则需要将旧版或现有的Monolithic应用程序迁移到微服务。将现有的大型生产单片式应用程序迁移到微服务中具有很大的挑战性,因为这可能会破坏应用程序的可用性。

一种解决方案是使用Strangler模式。Strangler模式意味着通过逐步用新的微服务替换特定功能,将Monolithic应用程序逐步迁移到微服务架构。此外,新功能仅在微服务中添加,绕过了传统的Monolithic应用程序。然后将Facade(API网关)配置为在旧版Monolith和微服务之间路由请求。一旦功能从Monolith迁移到微服务,Facade就会拦截客户端请求并路由到新的微服务。一旦所有旧版Monolithic功能都已迁移,旧版Monolithic应用程序将被"勒死",即退役。

img

> Strangler by Md Kamaruzzaman

优点:

· 将Monolithic应用程序安全迁移到微服务。

· 迁移和新功能开发可以并行进行。

· 迁移过程可以有自己的进度。

缺点:

· 在现有的Monolith和新的微服务之间共享数据存储变得充满挑战。

· 添加外观(API网关)将增加系统延迟。

· 端到端测试变得困难。

何时使用Strangler:

将大型后端单片应用程序增量迁移到微服务。

何时不使用Strangler:

· 如果后端整体组件较小,则批量替换是一个更好的选择。

· 如果客户端对旧版Monolithic应用程序的请求无法被拦截。

推动技术:

带有API网关的后端应用程序框架。

断路器

在微服务体系结构中,微服务进行同步通信,微服务通常调用其他服务来满足业务需求。由于瞬态故障(网络连接速度慢,超时或时间不可用),对另一个服务的调用可能会失败。在这种情况下,重试呼叫可以解决此问题。但是,如果存在严重问题(微服务完全失败),则微服务将长时间不可用。在这种情况下,重试是没有意义的,并且浪费了宝贵的资源(线程被阻塞,浪费了CPU周期)。同样,一项服务的故障可能会导致整个应用程序级联故障。在这种情况下,立即失败是一种更好的方法。

对于此类用例,可以使用断路器模式。微服务应通过代理来请求另一个微服务,该代理的工作方式类似于断路器。代理应该计算最近发生的故障数,并使用它来决定是允许操作继续进行还是直接返回异常。

img

> Circuit Breaker by Md Kamaruzzaman

断路器可以具有以下三种状态:

· **已关闭:**断路器将请求发送到微服务,并计算给定时间段内的故障数。如果在一定时间内的故障数量超过阈值,则它将跳闸并进入"打开状态"。

· **打开:**来自微服务的请求立即失败,并返回异常。超时后,断路器进入半开状态。

· **半开放式:**仅允许来自微服务的有限数量的请求通过并调用该操作。如果这些请求成功,则断路器将进入闭合状态。如果任何请求失败,则断路器进入"打开"状态。

优点:

· 提高微服务架构的容错性和弹性。

· 停止将故障级联到其他微服务。

缺点:

· 需要复杂的异常处理。

· 记录和监视。

· 应该支持手动重置。

何时使用断路器:

· 在紧密耦合的微服务体系结构中,微服务进行同步通信。

· 一个微服务是否依赖于多个其他微服务。

何时不使用断路器:

· 松散耦合的,事件驱动的微服务架构。

· 微服务是否不依赖于其他微服务。

推动技术:

API网关,服务网格,各种断路器库(Hystrix,Reselience4J,Polly。

外部化配置

每个业务应用程序都有许多用于各种基础结构的配置参数(例如,数据库,网络,连接的服务地址,凭据,证书路径)。同样,在企业环境中,应用程序通常部署在各种运行时中(本地,开发,生产)。实现此目标的一种方法是通过内部配置,这是一种致命的不良做法。由于很容易破坏生产凭据,因此可能导致严重的安全风险。另外,配置参数的任何更改都需要重建应用程序。在微服务架构中,这一点尤为重要,因为我们可能拥有数百种服务。

更好的方法是外部化所有配置。结果,将构建过程与运行时环境分开。此外,由于生产配置文件仅在运行时或通过环境变量使用,因此将安全风险降到最低。

优点:

· 生产配置不是代码库的一部分,因此可以最大程度地减少安全漏洞。

· 无需重新构建即可更改配置参数。

缺点:

我们需要选择一个支持外部化配置的框架。

何时使用外部化配置:

任何重要的生产应用程序都必须使用外部配置。

何时不使用外部化配置:

在概念发展的证明。

**推动技术:**几乎所有企业级的现代框架都支持外部化配置。

消费者驱动的合同测试

在微服务架构中,通常由独立的团队开发许多微服务。这些微服务一起工作来满足业务需求(例如,客户请求),并且彼此同步或异步地通信。消费者微服务的集成测试具有挑战性。通常,在这种情况下使用TestDouble可以进行更快,更便宜的测试。但是TestDouble通常并不代表真正的提供程序微服务。另外,如果提供者微服务更改了其API或消息,则TestDouble无法确认这一点。另一个选择是进行端到端测试。虽然在生产之前必须进行端到端测试,但它脆弱,缓慢,昂贵,并且不能替代集成测试(测试金字塔)。

消费者驱动的合同测试可以在这方面为我们提供帮助。此处,消费者微服务所有者团队编写了一个测试套件,其中包含针对特定提供者微服务的请求和预期响应(用于同步通信)或预期消息(用于异步通信)。这些测试套件称为显式合同。对于提供商微服务,其使用者的所有合同测试套件都添加到了自动测试中。在执行针对特定提供程序微服务的自动测试时,它将运行自己的测试,合同并验证合同。通过这种方式,合同测试可以帮助以自动化的方式维护微服务通信的完整性。

优点:

· 如果提供者意外更改了API或消息,则会在很短的时间内自动找到它。

· 更少的惊喜和更高的健壮性,尤其是包含大量微服务的企业应用程序。

· 改善团队自主权。

缺点:

· 由于合同测试可能使用完全不同的测试工具,因此需要进行额外的工作才能**·** 在合同商微服务中开发和集成合同测试。

· 如果合同测试与实际服务消耗不匹配,则可能导致生产失败。

何时使用消费者驱动的合同测试:

在大型企业业务应用程序中,通常,不同的团队开发不同的服务。

何时不使用消费者主导的合同测试:

· 一个团队开发所有微服务的相对简单,较小的应用程序。

· 提供者微服务是否相对稳定且未处于积极开发中。

推动技术:

契约,邮递员,Spring Cloud合同

结论

在现代的大型企业软件开发中,微服务体系结构可以帮助扩展规模并带来许多长期利益。但是微服务架构并不是可以在每个用例中使用的"银弹"。

如果在错误的应用程序类型中使用它,则微服务架构会带来更多的麻烦。

想要采用微服务体系结构的开发团队应遵循一组最佳实践,并使用一组可重复使用的,经过严格实践的设计模式。

微服务架构中最重要的设计模式是每个微服务的数据库。实施此设计模式具有挑战性,并且需要其他几个紧密相关的设计模式(事件源,CQRS和Saga)。

在具有多个客户端(Web,移动,台式机,智能设备)的典型业务应用程序中,客户端与微服务之间的通信可能会比较混乱,可能需要具有附加安全性的中央控制。在这种情况下,前端的设计模式和API网关非常有用。

同样,断路器模式可以极大地帮助处理此类应用程序中的错误情况。将旧的Monolithic应用程序迁移到微服务中具有很大的挑战性,而Strangler模式可以帮助迁移。

消费者驱动的合同测试是微服务集成测试的工具模式。同时,外部化配置是任何现代应用程序开发中的强制性模式。

该列表并不全面,并且取决于您的用例,您可能需要其他设计模式。但是此列表将为您提供有关微服务体系结构设计模式的出色介绍。

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

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

相关文章

关于ElasticSearch日期格式不一致的异常,可以这么解决

最近壹哥的一个学生,在利用spring-data-elasticsearch访问ElasticSearch(ES)时,遇到了一个关于日期类型的BUG,困扰了很久。然后他就找壹哥给他解决,接下来壹哥就把解决的过程给大家复现一下,希望本文可以给遇到同样问题…

构建灵活订单系统,B2B撮合管理系统提升光伏企业订单管理效率

光伏系统是利用半导体光生伏特效应将太阳能转化为电能的发电系统。过去20年,我国光伏制造业快速发展,由弱变强。经过20年高速发展,我国在硅片、电池片、组件制造等多领域处于世界领先水平,我国已经成为全球第一大光伏生产国、消费…

深度学习Week9-YOLOv5-C3模块实现(Pytorch)

🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍦 参考文章:Pytorch实战 | 第P8天:YOLOv5-C3模块实现(训练营内部成员可读)🍖 原作者:K同学啊|接辅导、项目定制了解C3的结构,方便…

前端Gitee + Jenkins自动化实战(转)

# 前端Gitee Jenkins自动化实战 当我们熟悉了Jenkins 的使用后,接下来我们来配置一个基于 vue-element-admin 的实战项目,来感受一下自动化流程带给我们的优势。 首先我们需要创建一个 git 项目,至于代码仓库可以自选,这里为了…

RocketMq: Windows环境-单机部署和多种主从集群场景部署

关于默认端口 broker的默认端口有3个,10911, 10912, 10909。 10911是remotingServer使用的监听端口,remotingServer主要处理以下三类消息: producer发送的消息 conumser在消费失败或者消费超时发送的消息 consumer拉取消息10912是主broker用于监听从broker请求…

HTML学生个人网站作业设计:公益专题扫黑除恶(HTML+CSS)

🎉精彩专栏推荐 💭文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业: 【📚毕设项目精品实战案例 (10…

扩散模型Diffusion轻松入门

如果要问最近模型领域什么东西最火,应该非扩散模型莫属,火得我觉得不系统学习一下都不行! 本文是我的学习笔记,只能叫入门文章,因为扩散模型的严谨数学推导公式很多,还没有研究透彻,不敢说一文…

c语言:关键字(二)

关键字一.声明的关键词—extern二.最名不符实的关键字—static一.声明的关键词—extern 首先这里问两个问题 1.变量可以跨文件访问吗? 2.函数可以跨文件访问吗? 答案是都可以 那么什么是跨文件呢? 我在game.c里定义show函数,但…

Vue2基础篇-01-Vue2 入门概述

1. 概述 该教程站在小白的角度,去帮助理解和使用,达到入门的效果;该教程覆盖面比较浅,更多详情请查阅 Vue2文档 ,目前最新是Vue3文档,但是Vue2是公司目前大多数使用的;欢迎大家一起指正并下方留…

Unity 符号表

目录 前言 关于Unity符号表 正文 程序crash日志: 解析 后记 记一次 Bugly 崩溃查找过程 unity-il2cpp: 前言 关于Unity符号表 关于项目真机调试时的崩溃问题,一般可以 logcat 或 xcode 看到相关的crash日志,拿到崩溃时的堆…

Python均匀分布和三角形分布

文章目录均匀分布三角形分布均匀分布和三角形分布之间的关系函数备注triangular(left, mode, right)三角形分布uniform([low, high])均匀分布 均匀分布 所谓均匀分布,就是在事件空间中,所有事件的概率都是相等的连续分布,其概率密度为 f(x)1…

麻省理工人工智能实验室新研究!有远见的机器学习方法:能预知未来行为的AI智能体

原创/文 BFT机器人 近日,麻省理工学院的研究人员开发出一种新技术,让AI智能体能够思考更远的未来,寻找更合适的合作与竞争长期解决方案。 想象一个游戏规则:两支足球队在球场上PK,玩家们可以选择相互合作合作来实现目…

[附源码]Python计算机毕业设计Django学生宿舍管理系统

项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等等。 环境需要 1.运行环境:最好是python3.7.7,…

web前端期末大作业:云南旅游网页主题网站设计——云南城市旅游5页HTML+CSS+JavaScript

👨‍🎓静态网站的编写主要是用 HTML DⅣV CSSJS等来完成页面的排版设计👩‍🎓,一般的网页作业需要融入以下知识点:div布局、浮动定位、高级css、表格、表单及验证、js轮播图、音频视频Fash的应用、uli、下拉…

c + linux + cmake + arm + MQTT

先给你们看个最终代码结构吧,因为我改过的代码会加密,所以我只能放一部分源码,另外一部分源码我会直接贴在博客,具体使用我会在博客里面说明! 1.MQTTPacket源码库(MQTTPacket源码地址) 2.MQTTClient.c /*********************************************************************…

Linux中线程池的制作

一.介绍 1.1概念 一种线程使用模式。线程过多会带来调度开销,进而影响缓存局部性和整体性能。线程池维护着多个线程,等待着监督管理者分配可并发执行的任务。这避免了在处理短时间任务时创建与销毁线程的代价。线程池不仅能够保证内核的充分利用&#x…

如何从github上克隆库、跑库

第一步:在Github上找到想要的库,以YOLOv3项目为例。 第二步:拷贝这个库到自己的电脑上,下载到本地。 方法一:在GitHub上,Code -> Download ZIP(有的时候会有一些问题,不建议&…

DBW*的trace文件过大的bug

问题描述: 近期某现场发现trace目录下的dbw*文件达到了大几G的大小导致/oracle目录占用率突增,删除这些trace文件,几天后又重新生成较大的dbw*的trace 11G Dec 4 10:38 rb_dbw0_2086848.trc 3.6G Dec 4 10:38 rb_dbw1_2086852.trc 4.4G De…

前端工程师常考手写面试题指南

实现 add(1)(2)(3) 函数柯里化概念: 柯里化(Currying)是把接受多个参数的函数转变为接受一个单一参数的函数,并且返回接受余下的参数且返回结果的新函数的技术。 1)粗暴版 function add (a) { return function (b) …

码云线上误删主项目文件夹的恢复

码云线上误删主项目文件夹的恢复前言描述解决办法解决问题前言描述 本来某个项目即将上线,然后同事不知道怎么的,直接打开了自己的码云,在网站上把主项目目录删除了。。。。是的,删除了!!!&…