type
status
date
slug
summary
tags
category
icon
password
什么是微服务?
微服务(英语:Microservices)是一种软件架构风格,它是以专注于单一责任与功能的小型功能区块 为基础,利用模块化的方式组合出复杂的大型应用程序,各功能区块使用与语言无关,而且复杂的服务背后是使用简单 URI 来开放接口,任何服务,任何细粒都能被开放。这个设计在 HP 的实验室被实现,具有改变复杂软件系统的强大力量。
要理解微服务,首先需要理解软件架构的演变。
单体式架构
微服务的一个对比是单体式应用程序,简单来说,就是把所有的功能都写在一起。单体式应用表示一个应用程序内包含了所有需要的业务功能,并且使用像主从式架构(Client/Server)或是多层次架构(N-tier)实现,虽然它也是能以分布式应用程序来实现,但是在单体式应用内,每一个业务功能是不可分割的。若要对单体式应用进行扩展则必须将整个应用程序都放到新的运算资源(如:虚拟机) 内,但事实上应用程序中最吃耗费资源、需要运算资源的仅有某个业务部分(例如跑分析报表或是数学算法分析),但因为单体式应用无法分割该部分,因此无形中会有大量的资源浪费的现象。
单体式架构会有一下几个缺点:
(1)所有功能耦合在一起,互相影响,最终难以管理。
(2)哪怕只修改一行代码,整个软件就要重新构建和部署,成本非常高。
(3)因为软件做成了一个整体,不可能每个功能单独开发和测试,只能整体开发和测试,导致必须采用瀑布式开发模型。
面向服务架构
为了解决上面这些问题,很早就有人提出来,必须打破代码的耦合,拆分单体架构,将软件拆分成一个个独立的功能单元。
互联网的出现之后,功能单元可以用远程"服务"的形式提供,就诞生出了"面向服务架构"(service-oriented architecture,简称 SOA)。面向服务的体系结构,就是一个组件模型,它将应用程序的不同功能单元(称为服务)通过这些服务之间定义良好的接口和契约联系起来。接口是采用中立的方式进行定义的,它应该独立于实现服务的硬件平台、操作系统和编程语言。这使得构建在各种这样的系统中的服务可以以一种统一和通用的方式进行交互。
所谓服务(service),就是在后台不间断运行、提供某种功能的一个程序。最常见的服务就是 Web 服务,通过80端口向外界提供网页访问。
"面向服务架构"就是把一个大型的单体程序,拆分成一个个独立服务,也就是较小的程序。每个服务都是一个独立的功能单元,承担不同的功能,服务之间通过通信协议连在一起。
这种架构有很多的优点:
(1)每种服务功能单一,相当于一个小型软件,便于开发和测试。
(2)各个服务独立运行,简化了架构,提高了可靠性。
(3)鼓励和支持代码重用,同一个服务可以用于多种目的。
(4)不同服务可以单独开发和部署,便于升级。
(5)扩展性好,可以容易地加机器、加功能,承受高负载。
(6)不容易出现单点故障。即使一个服务失败了,不会影响到其他服务。
缺点:
SOA 早期均使用了总线模式,这种总线模式是与某种技术栈强绑定的,比如:J2EE。这导致很多企业的遗留系统很难对接,切换时间太长,成本太高,新系统稳定性的收敛也需要一些时间,最终 SOA 看起来很美,但却成为了企业级奢侈品,中小公司都望而生畏。
此外,实施SOA时会遇到很多问题,比如通信协议(例如SOAP)的选择、第三方中间件如何选择、服务粒度如何确定等,目前也存在一些关于如何划分系统的指导性原则,但其中有很多都是错误的。SOA并没有告诉你如何划分单体应用成微服务,所以在实施SOA时会遇到很多问题。
微服务
2014年,Docker 出现了,彻底改变了软件开发的面貌。它让程序运行在容器中,每个容器可以分别设定运行环境,并且只占用很少的系统资源。
显而易见,可以用容器来实现"面向服务架构",每个服务不再占用一台服务器,而是占用一个容器。
这样就不需要多台服务器了,最简单的情况下,本机运行多个容器,只用一台服务器就实现了面向服务架构,这在以前是做不到的。这种实现方式就叫做微服务。
微服务运用了以业务功能的设计概念,应用程序在设计时就能先以业务功能或流程设计先行分割,将各个业务功能都独立实现成一个能自主执行的个体服务,然后再利用相同的协议将所有应用程序需要的服务都组合起来,形成一个应用程序。若需要针对特定业务功能进行扩展时,只要对该业务功能的服务进行扩展就好,不需要整个应用程序都扩展,同时,由于微服务是以业务功能导向的实现,因此不会受到应用程序的干扰,微服务的管理员可以视运算资源的需要来配置微服务到不同的运算资源内,或是布建新的运算资源并将它配置进去。
简单说,微服务就是采用容器技术的面向服务架构。它依然使用"服务"作为功能单元,但是变成了轻量级实现,不需要新增服务器,只需要新建容器(一个进程),所以才叫做"微服务"。它的特点与面向服务架构是一样的,但因为更轻量级,所以功能的解耦和服务化可以做得更彻底。而且,它可以标准化,同样的容器不管在哪里运行,结果都是一样的。
一个微服务框架的应用程序有下列特性:
- 每个服务都容易被取代。
- 服务是以能力来组织的,例如用户界面、前端、推荐系统、账单或是物流等。
- 由于功能被拆成多个服务,因此可以由不同的编程语言、数据库实现。
- 架构是对称而非分层(即生产者与消费者的关系)。
一个微服务框架:
- 适用于具持续交付(Continuous Delivery)的软件开发流程。
- 与服务导向架构(Service-Oriented Architecture)不同,后者是集成各种业务的应用程序,但微服务只属于一个应用程序。
微服务可以用不同的编程语言实现,也可以使用不同的基础设施。因此,最重要的技术选择是微服务之间的通信方式(同步、异步、UI集成)以及用于通信的协议(RESTful HTTP、消息、GraphQL……)。而在传统系统中,大多数技术选择,如编程语言,都会影响整个系统。
SOA和微服务的区别
- 规模和粒度:
- SOA 更倾向于大型、复杂的企业级系统。它通常将系统划分为多个服务,每个服务可能包含多个功能。这些服务通常以较粗的粒度提供,并且可能涵盖多个业务功能。
- 微服务更注重小型、独立的服务单元。每个微服务通常专注于一个特定的业务功能,并且以较细的粒度提供。微服务架构更适合于将系统拆分为许多小型、自治的服务。
- 技术栈:
- SOA 没有明确规定要使用特定的技术栈。它通常使用诸如SOAP(Simple Object Access Protocol)和WSDL(Web Services Description Language)等标准来定义服务接口,但在实践中也可能使用其他技术。
- 微服务通常采用更现代的技术栈,如RESTful API、JSON、HTTP等,以及容器化技术(如Docker)和容器编排工具(如Kubernetes)等来构建和管理服务。
- 部署和管理:
- SOA 的服务通常可以以多种方式部署,包括在本地服务器上、私有云中或公有云上。
- 微服务更倾向于采用容器化和云原生技术,服务通常以独立的容器运行,并由容器编排工具进行管理和调度。
- 自治性:
- SOA 中的服务通常更为集中管理,它们可能受到中央治理机构的监督,并且可能共享基础设施和技术组件。
- 微服务架构强调每个服务的自治性,每个微服务都可以独立开发、部署和扩展,服务之间的交互通常通过轻量级的通信机制进行,如HTTP API。
微服务的优点和缺点
1、微服务的优点:
关键点:复杂度可控,独立按需扩展,技术选型灵活,容错,可用性高
①它解决了复杂性的问题。它会将一种怪异的整体应用程序分解成一组服务。虽然功能总量 不变,但应用程序已分解为可管理的块或服务。每个服务都以RPC或消息驱动的API的形式定义了一个明确的边界。微服务架构模式实现了一个模块化水平。
②每个服务都能够由专注于该服务的团队独立开发。开发人员可以自由选择任何有用的技术。然而,这种自由意味着开发人员不再有义务使用在新项目开始时存在的可能过时的技术。在编写新服务时,他们可以选择使用当前的技术。此外,由于服务相对较小,因此使用当前技术重写旧服务变得可行。
③微服务架构模式使每个微服务都能独立部署。开发人员不需要协调部署本地服务的变更。这些变化可以在测试后尽快部署。
④每个服务都可以独立调整。可以仅部署满足其容量和可用性限制的每个服务的实例数。此外,可以使用最符合服务资源要求的硬件。
2、微服务的缺点
关键点:多服务运维难度,系统部署依赖,服务间通信成本,数据一致性,系统集成测试,重复工作,性能监控等
①一个缺点是名称本身。术语microservice过度强调服务规模。但重要的是要记住,这是一种手段,而不是主要目标。微服务的目标是充分分解应用程序,以便于敏捷应用程序开发和部署。
②另一个主要缺点是分布式系统而产生的复杂性。开发人员需要选择和实现基于消息传递或RPC的进程间通信机制。此外,他们还必须编写代码来处理部分故障,因为请求的目的地可能很慢或不可用。
③微服务器的另一个挑战是分区数据库架构。更新多个业务实体的业务交易是相当普遍的。但是,在基于微服务器的应用程序中,您需要更新不同服务所拥有的多个数据库。使用分布式事务通常不是一个选择,而不仅仅是因为CAP定理。许多今天高度可扩展的NoSQL数据库都不支持它们。你最终不得不使用最终的一致性方法,这对开发人员来说更具挑战性。
④测试微服务应用程序也更复杂。服务类似的测试类将需要启动该服务及其所依赖的任何服务(或至少为这些服务配置存根)。再次,重要的是不要低估这样做的复杂性。
⑤另一个主要挑战是实现跨越多个服务的更改。例如,我们假设您正在实施一个需要更改服务A,B和C,其中A取决于B和B取决于C。在单片应用程序中,您可以简单地更改相应的模块,整合更改,并一次性部署。相比之下,在Microservice架构模式中,您需要仔细规划和协调对每个服务的更改。例如,您需要更新服务C,然后更新服务B,然后再维修A。幸运的是,大多数更改通常仅影响一个服务,而需要协调的多服务变更相对较少。
⑥部署基于微服务的应用程序也更复杂。单一应用程序简单地部署在传统负载平衡器后面的一组相同的服务器上。每个应用程序实例都配置有基础架构服务(如数据库和消息代理)的位置(主机和端口)。相比之下,微服务应用通常由大量服务组成。例如,每个服务将有多个运行时实例。更多的移动部件需要进行配置,部署,扩展和监控。此外,您还需要实现服务发现机制,使服务能够发现需要与之通信的任何其他服务的位置(主机和端口)。
常见的微服务框架
Java语言相关微服务框架
Spring Boot
Spring Boot的设计目的是简化新Spring应用初始搭建以及开发过程,2017年有64.4%的受访者决定使用Spring Boot,可以说是最受欢迎的微服务开发框架。利用Spring Boot开发的便捷度简化分布式系统基础设施的开发,比如像配置中心、注册、负载均衡等方面都可以做到一键启动和一键部署。
- 优点:
- 快速启动:Spring Boot 提供了快速启动的能力,可以轻松创建独立的、基于 Spring 的应用程序。
- 自动化配置:Spring Boot 提供了自动化配置的功能,简化了开发者对配置的需求,减少了样板代码的编写。
- 生态系统:Spring Boot 生态系统庞大,有大量的文档、教程和社区支持。
- 缺点:
- 过度自动化:有时自动化配置可能会导致开发者失去对应用程序的控制,特别是在需要定制化和优化的情况下。
Spring Cloud
Spring Cloud是一个系列框架的合计,基于HTTP(s)的RETS服务构建服务体系,Spring Cloud能够帮助架构师构建一整套完整的微服务架构技术生态链。
- 优点:
- 微服务支持:Spring Cloud 提供了丰富的微服务功能,如服务发现、负载均衡、断路器等。
- 集成性:Spring Cloud 可以与 Spring Boot 很好地集成,为构建分布式系统提供了便利。
- 社区支持:Spring Cloud 有一个庞大的活跃社区,提供了大量的文档和示例代码。
- 缺点:
- 复杂性:使用 Spring Cloud 构建微服务架构可能会增加系统的复杂性,特别是在涉及大量微服务的情况下。
Dubbo
Dubbo是由阿里巴巴开源的分布式服务化治理框架,通过RPC请求方式访问。Dubbo是在阿里巴巴的电商平台中逐渐探索演进所形成的,经历过复杂业务的高并发挑战,比Spring Cloud的开源时间还要早。目前阿里、京东、当当、携程、去哪等一些企业都在使用Dubbo。
- 优点:
- 高性能:Dubbo 是一个高性能的 RPC 框架,具有低延迟和高吞吐量的特点。
- 可靠性:Dubbo 提供了负载均衡、容错、服务治理等功能,可以保证系统的可靠性和稳定性。
- 配置管理:Dubbo 提供了丰富的配置管理功能,可以灵活地配置服务的各种参数。
- 缺点:
- 生态较窄:相比于 Spring而言,Dubbo 的生态系统相对较小,可能缺乏一些常见的功能和工具。
Drop wizard
Dropwizard将Java生态系统中各个问题域里最好的组建集成于一身,能够快速打造一个Rest风格的后台,还可以整合Dropwizard核心以外的项目。国内现在使用Dropwizard还很少,资源也不多,但是与Spring Boot相比,Dropwizard在轻量化上更有优势,同时如果用过Spring,那么基本也会使用Spring Boot。
- 优点:
- 简单易用:Dropwizard 提供了简单而直观的方式来构建 RESTful 服务,减少了开发者的工作量。
- 生产就绪:Dropwizard 集成了许多常见的库和工具,如Jetty、Jackson、Metrics等,使得构建生产就绪的服务变得更加容易。
- 模块化:Dropwizard 的组件是相互独立的,可以根据需要进行定制和扩展。
- 缺点:
- 限制性:Dropwizard 是一个相对轻量级的框架,可能不适用于所有类型的应用程序。
- 生态相对较小:相比于 Spring而言,Dropwizard 的生态系统可能较小,可能缺乏一些常见的功能和工具。
Akka
Akka是一个用Scala编写的库,可以用在有简化编写容错、高可伸缩性的Java和Scala的Actor模型,使用Akka能够实现微服务集群。
这四种框架主要用于响应式微服务开发,响应式本身和微服务没有关系,更多用于提升性能上,但是可以和微服务相结合,也可以提升性能。
- 优点:
- 并发性:Akka 是一个基于 Actor 模型的框架,提供了强大的并发支持,能够处理大规模并发的情况。
- 弹性和容错性:Akka 提供了弹性和容错的机制,能够自动处理系统中的故障,并进行恢复。
- 分布式支持:Akka 支持分布式计算,可以在集群中运行 Actor,并实现分布式系统的构建。
- 缺点:
- 复杂性:Akka 的设计相对复杂,可能不适用于所有类型的应用程序,特别是对于简单的 CRUD 应用程序而言
.Net相关微服务框架
.NET Core
.NET Core是专门针对模块化微服务架构设计的,是跨平台应用程序开发框架,是微软开发的第一个官方版本。
- 优点:
- 跨平台:.NET Core 是一个跨平台的开发框架,可以在 Windows、Linux 和 macOS 等多种操作系统上运行。
- 性能优化:.NET Core 具有优化的性能,包括更快的启动时间、更高的吞吐量和更低的内存消耗。
- 大型社区:.NET Core 拥有庞大的开发者社区和丰富的生态系统,提供了大量的工具、库和文档支持。
- 缺点:
- 生态相对较小:相比于传统的 .NET Framework,.NET Core 的生态系统可能相对较小,某些功能和工具可能不够成熟。
- 迁移成本:对于现有的 .NET Framework 应用程序来说,迁移到 .NET Core 可能需要一些工作,并且可能涉及一些不兼容性问题。
Service Fabric
Service Fabric是微软开发的一个微服务框架,基于Service Fabric构建的很多云服务被用在了Azure上。
- 优点:
- 高可用性:Service Fabric 提供了强大的高可用性和容错性能力,可以自动处理节点故障和服务迁移。
- 分布式部署:Service Fabric 支持分布式部署,可以轻松部署和管理大规模的分布式系统。
- 微服务支持:Service Fabric 提供了对微服务架构的原生支持,包括服务发现、负载均衡等功能。
- 缺点:
- 运维复杂性:虽然 Service Fabric 提供了强大的功能,但它的运维可能相对复杂,特别是对于大规模的分布式系统而言。
Surging
Surging是基于RPC协议的分布式微服务技术框架,基于.NET Core而来。
- 优点:
- 轻量级:Surging 是一个轻量级的微服务框架,具有快速启动和部署的优势。
- 支持多种通信协议:Surging 支持多种通信协议,包括 HTTP、TCP、WebSocket 等,具有良好的灵活性和扩展性。
- 高性能:Surging 具有优化的性能,能够处理大量的并发请求。
- 缺点:
- 社区支持相对较小:相比于一些主流的框架,Surging 的社区支持可能相对较小,可能缺乏一些成熟的工具和文档支持。
- 功能相对有限:虽然 Surging 提供了基本的微服务功能,但其功能相对于一些主流框架来说可能相对有限。
Microdot Framework
Microdot Framework用于编写定义服务逻辑代码,不需要解决开发分布式系统的挑战,能够很方便的进行MicrosoftOrleans集成。
- 优点:
- 微服务支持:Microdot Framework 是一个专注于微服务的框架,提供了丰富的微服务功能,包括服务发现、负载均衡、断路器等。
- 高可扩展性:Microdot Framework 具有高度可扩展性,可以根据需要灵活地扩展和定制。
- 高性能:Microdot Framework 具有优化的性能,能够处理大规模的微服务系统。
- 缺点:
- 社区支持相对有限:虽然 Microdot Framework 的社区在不断壮大,但相对于一些主流框架来说,其社区支持可能还有待提升。
Go相关微服务框架
Go-Kit
Go-Kit是分布式开发的工具合集,适合用于大型业务场景下构建微服务。
- 优点:
- 高度可定制:Go-Kit 提供了一系列独立的库,开发者可以根据需要选择和定制所需的功能模块,从而实现高度定制化的微服务。
- 适用于分布式系统:Go-Kit 提供了一些有用的功能,如服务发现、负载均衡、熔断器等,适用于构建分布式系统。
- 社区支持:Go-Kit 有一个活跃的社区,提供了大量的文档、示例和工具,方便开发者使用和学习。
- 缺点:
- 生态系统相对较小:相比于其他一些框架,Go-Kit 的生态系统可能相对较小,可能缺乏一些常见的功能和工具。
Goa
Goa是用Go语言构建的微服务框架。
- 优点:
- 设计简洁:Goa 提供了简洁而直观的方式来定义 API 和服务,减少了开发者的工作量。
- 自动生成文档:Goa 可以自动生成 API 文档,减少了手动编写文档的工作,提高了开发效率。
- 集成测试:Goa 提供了集成测试的支持,可以方便地测试生成的代码,保证代码质量和稳定性。
- 缺点:
- 生态系统相对较小:相比于一些主流的框架,Goa 的生态系统可能相对较小,可能缺乏一些常见的功能和工具。
- 定制性受限:Goa 提供了一种特定的设计范式,可能对于一些特定的需求和场景不够灵活。
Dubbo-go
Dubbo-go是和阿里巴巴开源的Dubbo能够兼容的Golang微服务框架。
- 优点:
- 高性能:Dubbo-go 是 Dubbo 在 Go 语言上的实现,具有高性能的特点,适用于构建性能要求较高的分布式系统。
- 分布式支持:Dubbo-go 提供了丰富的分布式功能,如服务发现、负载均衡、熔断器等,适用于构建复杂的分布式系统。
- 生态系统丰富:Dubbo-go 是 Dubbo 生态系统的一部分,可以充分利用 Dubbo 生态系统的功能和工具。
- 缺点:
- 配置复杂:Dubbo-go 的配置相对较复杂,需要对 Dubbo 的各种配置参数和功能有一定的了解
Python相关微服务框架
Python相关的微服务框架非常少,用的比较多的是Nameko。Nameko让实现微服务变得更简单,同时也提供了很丰富的功能,比如支持负载均衡、服务发现还支持依赖自动注入等,使用起来很方便,但是有限速、超时和权限机制不完善等缺点。
- 优点:
- Nameko 是一个基于 Python 的微服务框架,适用于 Python 开发者构建微服务应用。
- 简单易用:Nameko 提供了简单而直观的方式来定义和编写微服务,减少了开发者的工作量。
- 分布式支持:Nameko 支持分布式计算,可以在集群中运行服务,并实现分布式系统的构建。
- 缺点:
- 生态相对较小:相比于一些主流的微服务框架,Nameko 的生态系统可能相对较小。
- 性能问题:由于是基于 Python 的框架,Nameko 可能在处理大规模并发时性能较差。
- Author:Serendipity
- URL:https://serendipity565.netlify.app//article/%E5%BE%AE%E6%9C%8D%E5%8A%A1
- Copyright:All articles in this blog, except for special statements, adopt BY-NC-SA agreement. Please indicate the source!