什么是微服务架构?主流的微服务如何实现?

作者&投稿:苏贾 (若有异议请与网页底部的电邮联系)
什么是微服务架构啊?~

微服务(Microservices Architecture)是一种架构风格,一个大型复杂软件应用由一个或多个微服务组成。系统中的各个微服务可被独立部署,各个微服务之间是松耦合的。每个微服务仅关注于完成一件任务并很好地完成该任务。
微服务是指开发一个单个 小型的但有业务功能的服务,每个服务都有自己的处理和轻量通讯机制,可以部署在单个或多个服务器上。
微服务也指一种种松耦合的、有一定的有界上下文的面向服务架构。也就是说,如果每个服务都要同时修改,那么它们就不是微服务,因为它们紧耦合在一起;如果你需要掌握一个服务太多的上下文场景使用条件,那么它就是一个有上下文边界的服务。
微服务架构的优点:
每个微服务都很小,这样能聚焦一个指定的业务功能或业务需求。
微服务能够被小团队单独开发,这个小团队是2到5人的开发人员组成。
微服务是松耦合的,是有功能意义的服务,无论是在开发阶段或部署阶段都是独立的。
微服务能使用不同的语言开发。
微服务易于被一个开发人员理解,修改和维护,这样小团队能够更关注自己的工作成果。无需通过合作才能体现价值。
微服务允许你利用融合最新技术。
微服务只是业务逻辑的代码,不会和HTML,CSS 或其他界面组件混合。
微服务架构的缺点:
微服务架构可能带来过多的操作。
需要DevOps技巧 (http://en.wikipedia.org/wiki/DevOps)。
可能双倍的努力。
分布式系统可能复杂难以管理。
因为分布部署跟踪问题难。
当服务数量增加,管理复杂性增加。
微服务适合哪种情况:
当需要支持桌面,web,移动智能电视,可穿戴时都是可以的。
甚至将来可能不知道但需要支持的某种环境。

微服务是指开发一个单个 小型的但有业务功能的服务,每个服务都有自己的处理和轻量通讯机制,可以部署在单个或多个服务器上.
微服务也指一种种松耦合的、有一定的有界上下文的面向服务架构.也就是说,如果每个服务都要同时修改,那么它们就不是微服务,因为它们紧耦合在一起;如果你需要掌握一个服务太多的上下文场景使用条件,那么它就是一个有上下文边界的服务,这个定义来自DDD领域驱动设计.

简单地说,微服务架构就是以业务域或业务功能为边界,将一个大而全的应用拆分为可以独立开发,独立部署,独立测试,独立运行的一组小的应用,并且使用轻量级,通用的机制在这组应用间进行通信。
主流的微服务包括:
1、SpringCloud

Spring Cloud , 来自Spring,具有Spring 社区的强大支撑,还有Netflix强大的后盾与技术输出。Netflix作为一家成功实践微服务架构的互联网公司在几年前就把几乎整个微服务框架栈开源贡献给了社区,这些框架开源的整套服务架构套件是Spring Cloud的核心。

- Eureka:服务注册发现框架;

- Zuul:服务网关;

- Karyon:服务端框架;

- Ribbon:客户端框架;

- Hystrix:服务容错组件;

- Archaius:服务配置组件;

- Servo:Metrics组件;

- Blitz4j:日志组件;

2、Dubbo

Dobbo是一个分布式服务框架,是阿里开放的微服务化治理框架,致力于提高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。其核心部分(官网)

- 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式;

- 集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持;

- 自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

Dubbo 也是采用全 Spring 配置方式,透明化接入应用,对应用没有任何 API 侵入,只需用 Spring 加载 Dubbo的配置即可,Dubbo 基于 Spring 的 Schema 扩展进行加载。当然也支持官方不推荐的 API 调用方式。

3、lstio

lstio 作为用于微服务聚合层管理的新锐项目,是Google、IBM、Lyft(海外共享出行公司、Uber劲敌),首个共同联合开源的项目,提供了统一的连接,安全,管理和监控微服务的方案。

目前首个测试版是针对Kubernetes环境的,社区宣称在未来几个月内会为虚拟机和Cloud Foundry 等其他环境增加支持。lstio将 流量管理添加到微服务中,并为增值功能(如安全性、监控、路由、连接管理和策略)创造了基础。

- HTTP、gRPC 和 TCP 网络流量自动负载均衡;

- 提供了丰富的路由规则,实现细颗粒度的网络流量行为控制;

- 流量加密、服务件认证,以及强身份声明;

- 全范围(Fleet-wide)的策略执行;

- 深度遥测和报告。

微服务架构,主要是中间层分解,将系统拆分成很多小应用(微服务),微服务可以部署在不同的服务器上,也可以部署在相同的服务器不同的容器上。当应用的故障不会影响到其他应用,单应用的负载也不会影响到其他应用,其代表框架有 Spring cloud、Dubbo 等。
微服务 Microservices 之父,马丁.福勒,对微服务大概的概述如下:就目前而言,对于微服务业界并没有一个统一的、标准的定义(While there is no precise definition of this architectural style ) 。但通常在其而言,微服务架构是一种架构模式或者说是一种架构风格,它提倡将单一应用程序划分成一组小的服务,每个服务运行独立的自己的进程中,服务之间互相协调、互相配合,为用户提供最终价值。服务之间采用轻量级的通信机制互相沟通(通常是基于 HTTP 的 RESTful API ) 。每个服务都围绕着具体业务进行构建,并且能够被独立地部署到生产环境、类生产环境等。另外,应尽量避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据业务上下文,选择合适的语言、工具对其进行构建,可以有一个非常轻量级的集中式管理来协调这些服务。可以使用不同的语言来编写服务,也可以使用不同的数据存储。
六种常见的微服务架构模式:
1、聚合器微服务设计模式
聚合器调用多个服务实现应用程序所需的功能。它可以是一个简单的Web页面,将检索到的数据进行处理展示。它也可以是一个更高层次的组合微服务,对检索到的数据增加业务逻辑后进一步发布成一个新的微服务,这符合DRY原则。另外,每个服务都有自己的缓存和数据库。如果聚合器是一个组合服务,那么它也有自己的缓存和数据库。聚合器可以沿X轴和Z轴独立扩展。
代理微服务设计模式
这是聚合模式的一个变种,在这种情况下,客户端并不聚合数据,但会根据业务需求的差别调用不同的微服务。代理可以仅仅委派请求,也可以进行数据转换工作。
3、链式微服务设计模式
这种模式在接收到请求后会产生一个经过合并的响应,在这种情况下,服务A接收到请求后会与服务B进行通信,类似地,服务B会同服务C进行通信。所有服务都使用同步消息传递。在整个链式调用完成之前,客户端会一直阻塞。因此,服务调用链不宜过长,以免客户端长时间等待。
4、分支微服务设计模式
这种模式是聚合器模式的扩展,允许同时调用两个微服务链。
5、数据共享微服务设计模式
自治是微服务的设计原则之一,就是说微服务是全栈式服务。但在重构现有的“单体应用(monolithic application)”时,SQL数据库反规范化可能会导致数据重复和不一致。因此,在单体应用到微服务架构的过渡阶段,可以使用这种设计模式,在这种情况下,部分微服务可能会共享缓存和数据库存储。不过,这只有在两个服务之间存在强耦合关系时才可以。对于基于微服务的新建应用程序而言,这是一种反模式。
6、异步消息传递微服务设计模式
虽然REST设计模式非常流行,但它是同步的,会造成阻塞。因此部分基于微服务的架构可能会选择使用消息队列代替REST请求/响应。
谐云微服务治理平台,就是基于Istio的Mesh方案完全透明支持Dubbo和SpringCloud等平台框架,无侵入、无开发语言限制的完整服务治理,整理功能上覆盖微服务总览、注册中心、配置中心、API网关和ServiceMesh的同时,还从多维度立体覆盖了微服务的运维监控。并能从服务拆分方法、技术选型与问题解决等方面指导客户开发微服务应用。


微服务与传统单一服务架构的区别
1.如何理解微服务,简要说明您所理解的微服务是什么?微服务,这个词语其实是一次听说,我search了下定义,然后恍然明白,其实所谓的微服务,用更通俗接地气的词语来定义和描述的话,就是敏捷+模块的服务架构体系,如何解释敏捷,原来的亚马逊CEOBezos提出来的2pizza就是微服务系统架构的鼻祖,2pizza意思就是...

微服务包括哪些
微服务包括哪些?下面让我们一起来了解一下吧。微服务(或微服务架构)是一种云原生架构方法 ,其中单个应用程序由许多松散耦合且可独立部署的较小组件或服务组成。这些服务通常 1、有自己的堆栈,包括数据库和数据模型;2、通过REST API,事件流和消息代理的组合相互通信;3、它们是按业务能力组织的,分隔...

分布式系统架构有哪些
一、分布式客户端-服务器架构 这种架构是常见的分布式系统架构之一。它将服务和数据存储集中在一台或多台服务器上,客户端通过网络请求访问这些服务。这种架构具有良好的扩展性和灵活性,适用于处理大量并发请求和分布式数据处理场景。此外,客户端可以根据需要灵活地扩展和部署。二、微服务架构 微服务架构是一...

主流的微服务架构有哪些
微服务架构是一项在云中部署应用和服务的新技术。大部分围绕微服务的争论都集中在容器或其他技术是否能很好的实施微服务,而红帽说API应该是重点。微服务可以在“自己的程序”中运行,并通过“轻量级设备与HTTP型API进行沟通”。关键在于该服务可以在自己的程序中运行。通过这一点我们就可以将服务公开与微服务...

有哪些架构
常见的架构包括:客户端-服务器架构、分布式架构、微服务架构、云架构等。一、客户端-服务器架构 客户端-服务器架构是最常见的网络架构之一。在这种架构中,服务器负责处理数据和请求,而客户端则负责用户的交互界面。用户通过客户端软件发送请求到服务器,服务器处理请求后返回结果。这种架构适用于大量用户...

架构模式有哪些
2. 事件驱动架构模式 事件驱动架构模式是一种基于事件的软件架构。在这种模式中,系统由一系列事件和事件处理器组成。当某个事件发生时,相应的事件处理器会被触发并执行相应的操作。这种模式适用于需要实时响应和处理大量事件的场景,如金融交易系统、实时通信系统等。3. 微服务架构模式 微服务架构模式是一...

soa和微服务的区别
SOA,全称为Service-Oriented Architecture,是一种设计策略,它将复杂的应用分解为一系列独立的服务。这些服务作为独立的单元运行在操作系统中,通过网络进行通信和协作,以实现特定的功能。SOA强调的是服务的封装和松耦合,旨在提高系统的灵活性和可重用性。相比之下,微服务架构是对SOA的进一步发展。它倡导将...

淘宝用的微服务是什么
微服务架构将单体应用,按照业务领域拆分为多个高内聚低耦合的小型服务,每个小服务运行在独立进程,由不同的团队开发和维护。服务间采用轻量级通信机制,如HTTPRESTfulAPI,或者RPC,独立自动部署,可以采用不同的语言及存储。淘宝用的微服务是什么?微服务架构将单体应用,按照业务领域拆分为多个高内聚低耦合的...

微服务架构的核心组件有哪些?
微服务架构,这个革命性的技术,以其卓越的灵活性和可扩展性,正在重构软件世界的格局。它犹如一幅清晰的蓝图,涵盖了多个核心组件,包括:Docker、容器编排、容器管理工具、API网关、负载均衡、服务发现等,每一个都是构建微服务生态系统的基石。Docker,作为应用容器化的领航者,它简化了应用程序的打包和...

1、软件架构有什么?我们目前的软件开发架构是基于什么的?2、资源分 ...
单体架构(MonolithicArchitecture):单体架构是将整个应用构建为一个单一的、紧密耦合的单元。所有的功能模块都集中在一起,通常以单一的代码库进行管理。这种架构的优点是简单易懂,但在大型和复杂应用中可能难以维护和扩展。微服务架构(MicroservicesArchitecture):微服务架构是一种将应用拆分为小型、自治的...

陆丰市15871779704: 微服务架构有什么特性? -
菜弦丽珠: 从字面上理解当然是“微”这个特性了.微是说明量小,轻.粒度小,另外还有的一个重要特性就是独立,每一个微服务都是独立的,相互之间不影响,哪个需要修改、迭代就针对这一个服务修改、迭代即可,不会牵扯过多的服务.

陆丰市15871779704: 什么是微服务架构? -
菜弦丽珠: 试读结束,如需阅读或下载,请点击购买> 原发布者:和合文化 微服务架构技术交流大庆金桥信息技术工程有限公司2018年7月24日目录一、二、微服务架构模式SpringCloud三、四、五、SpringBoot微服务平台简介微服务平台示例单体架构(...

陆丰市15871779704: 互联网架构?
菜弦丽珠: 一、单体架构 早期互联网产品用户量少,并发量低,数据量小,多数只需要单个应用服务器可以满足需要,而数据库和文件服务部署在外部单个服务器上,这就是最早互联网架构,架构单体架构的优点是容易开发、部署和测试,其缺点是系统耦...

陆丰市15871779704: SOA和微服务架构的区别 -
菜弦丽珠: 微服务是一个新概念,但这绝不是一个全新架构,更不是一个包治百病的架构.由于有服务二字,很容易让人联想到面向服务架构(SOA),其实微服务架构属于应用技术架构,和以B/S为代表的三层架构相对应,强调将巨石型应用拆分为由...

陆丰市15871779704: JAVA软件开发工程师要学哪些技术 -
菜弦丽珠: 第一阶段:JAVASE基础 打好扎实的JAVASE基础、学会用程序员思维来解决现实问题!掌握JAVA面向对象核心思想(接口、抽象类、继承、多态、封装) 了解JAVA高级功能及最新特性(多线程、IO、网络编程、反射机制、注解、JAVA8.0...

陆丰市15871779704: 微服务架构有哪几种常用的设计模式 -
菜弦丽珠: 自治是微服务的设计原则之一,就是说微服务是全栈式服务.但在重构现有的“单体应用(monolithic application)”时,SQL数据库反规范化可能会导致数据重复和不一致.因此,在单体应用到微服务架构的过渡阶段,可以使用这种设计模式,

陆丰市15871779704: 微服务架构有哪些优势? -
菜弦丽珠: 独立开发 – 所有微服务都可以根据各自的功能轻松开发独立部署 – 基于其服务,可以在任何应用程序中单独部署它们故障隔离 – 即使应用程序的一项服务不起作用,系统仍可继续运行混合技术堆栈 – 可以使用不同的语言和技术来构建同一应用程序的不同服务粒度缩放 – 单个组件可根据需要进行缩放,无需将所有组件缩放在一起

陆丰市15871779704: 无服务架构和微服务器架构的区别 -
菜弦丽珠: 微服务架构中有两个阵营,一是坚持微服务是无状态的HTTP API服务,另一阵营认为微服务本身就要求把整个系统当做一个完整的分布式应用来对待,而不是原来那种把各种组件堆积在一起,“拼接”系统的做法.无服务架构就是原来那种把各种组件堆积在一起,拼接系统的做法.

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网