微服务架构是什么?现在国内能落地吗?

微服务架构是什么?现在国内能落地吗?,第1张

微服务与SOA架构

微服务

维基上对其定义为:一种软件开发技术- 面向服务的体系结构(SOA)架构样式的一种变体,它提倡将单一应用程序划分成一组小的服务,服务之间互相协调、互相配合乎兄,为用户提供最终价值。每个服务运行在其独立的进程中,服务与服务间采用轻量级的通信机制互相沟通(通常是基于HTTP的RESTful API)。每个服务都围绕着具体业务进行构建,并且能够独立地部署到生产环境、类生产环境等。另外,应尽量避免统一的信扮、集中式的服务管理机制,对具体的一个服务而言,应根据上下文,选择合适的语言、工具对其进行构建。

微服务概念的由来是怎么样的呢,参考维基百科英文版,简单梳理后的微服务出现的 历史 :

顺便说一句,这几个人都是大名鼎鼎的,名字可能陌生,但是摆出他们的作品,相信多少是有些了解的。 Martin Flower是《重构》、《UML 精粹》的作者;Robert Martin,人称 Bob 大叔,敏捷专家,《代码整洁之道》、《架构整洁之道》的作者。 既然微服务是SOA架构的一种变体,那么,谈微服务,SOA就是一个跨不过去的一个话题。

SOA

SOA的全称是“Service Oriented Architecture”,中文翻译是“面向服务架构”,1996年,由Gartner公司最早提出SOA概念。它的诞生是有其 历史 背景的。

同时,基于这样的背景,Gartner公司提出了SOA的概念,并且还给了一个预言,它预言在2008年,SOA会成为一种最流行的、且占有绝对优势的软件工程实践办法。

SOA架构

很多时候,我们认为SOA已经消失在江湖,实际上并非如此,许多传统行业,比如物流、仓储行业的系统都是采用SOA架构来构建的。

对于SOA,从图中可以看到,它的每一项业务功能都是一个服务,都需要对外提供服务的能力,来完成企业所需的各项业务功能,也就意味着它具有对外提供开放的能力,这些能力无需定制化就可以实现。为什么无需定制化呢,核心就在于ESB。

看到ESB的功能,是不是觉得它的功能有点似曾相识?是的,它就是微服务所需要的基础服务。

微服务架构

简而言之,微服务架构风格 ,是一种 将单个应用程序开发为一组小服务 的方法,每个小服务都 在自己的进程中运行并与轻量级机制(通常是 HTTP 资源 API)进行通信 。 这些服务是围绕业务能力构建的,并且 可以通过全自动部署机制独立部署 。 这些服务的集中管理最少,可以用不同的编程语言编写并使用不同的数据存储技术。

上面一段话是Martin Fowler关于微服务架构论文中的核心片段,从上述片段中,我们提炼出微服务架构的核心有三点:

其一是“ 小服务 ”,将应用拆分为一组小服务;

其二是“ 在自己的进程中运行并与轻量级机制(通常是 HTTP 资源 API)进行通信 ”,微服务是由独立进程且进程之间通过轻量级机制进行通信;

其三是“ 可以通过全自动部署机制独立部署 ”,也就是说每个微服务可以快速独立部署。

其实这已经非常精确、精准的描述出了微服务的基本特征。完全可以作为在微服务架构实践中落地的三个参考依据与检验标准。

微服务与SOA对比

对比维度

微服务

SOA

举例

技术本质

Smart endpoints and dumb pipes

Smart pipes and dumb endpoints

应用场景

互联网行业

传统行业或企业内部

SOA,企业OA;微服务,电商平台

服务粒度

较粗

服务通信

标准化,轻量级

重量级

SOA,ESB;微服务,HTTP,RCP

服务交付

快速

较慢

微服务,服务小容易升级;SOA功能集中,较难升级

应用架构的演化

最初的应用都是单体架构,所谓单体架构就是将一系列功能全部集中在一个大的应用中,比如传统行业一般整个财务就做一个系统,将费用管理、账务管理、薪滑顷灶资结算等等都集中在一起,这种架构的局限性非常明显,不适合大规模项目的建设。

随着软件架构的发展,出现SOA架构,SOA将单体架构做了拆分,拆分成粗粒度的服务,同时将部分公共功能独立出来形成ESB,它的优点是

但是由于SOA架构需要一个统一的通信交互(ESB), 导致了接口开发增加工作量。

更进一步发展,微服务架构出现,对服务进一步的拆分,拆分成更细粒度的服务;进一步提供了架构选择的多样性,微服务架构主要优点是

正是因为微服务将服务拆分的更小,它同样也带来了一些挑战,比如多服务运维难度增大、服务通信成本变高、数据一致性保持更难、性能监控要求提升等等。

所以业务在选择架构的时候,应从多方面考量选择更合适的架构。

顺便说一句,这里的架构演化是指整个架构的发展 历史 ,并不是说你的服务就一定要经过这个演化过程,只是更多的架构模式提供更多的选择。我们在做架构演进的时候,更多的是将单体应用演进到SOA架构或者演进到微服务架构。

面向中小企业的微服务产品提供自动应答菜单、微网站生成与管理、微信CRM系统服务、微信公众平台客服服务等综合性的运营管理标准化服务,是多功能的微信运营管理平台。

微信管家是将企业微信公众账号通过技术平台接入、运营管理等方式,帮助企业向微信用户提供更完备服务信息、用户互动体验、营销效果等企业应用解决方案。

为企业客户提供基于微信平台的客户服务、产品推介、互动营销、市场调查、产品订单等运营与系统功能

你好,很开心收到邀请来回答你的问题。

除了云计算、大数据和人工智能三大热门技术之外,Java被称为“编程开发的灵魂”,而微服务架构作为以Java为基础的高阶技能,同样不可忽视。

按照传统的软件开发模式,在开发项目时,通常我们会把项目创造成一个庞然大物,这个庞然大物包括一系列的小模块,比如“用户模块、订单模块、商品模块、支付模块”,一旦有模块掉了链子,整个项目都将Game Over!

为了解决这个问题,我们将一个大项目拆分成许多独立的小项目,每一个独立的小项目被称为服务。服务之间通过接口互相访问。即使某些服务挂掉,也不会影响其它服务的运行。这种项目架构称为微服务架构。

微服架构是整个互联网的框架核心,掌控了整个互联网的主心骨,一个好的架构就能搭建一个完美的互联网平台。因此,具有微服专业能力的架构师人才备受重视。

今年上半年,猎聘发布了《猎聘 2019 上半年中高端人才就业现状大数据报告》,在分领域热招数据统计中,架构师平均达到惊人的 4.28 万元,成为热门领域岗位薪资之最。

微服务架构系统灵活性,健壮性,扩展性好,特别适合需求变化迅速的场景。但系统复杂度高,部署,管理难度大。微服务除了开发期框架之外,还有需要一系列的运行期中间件支撑,如API网关,服务注册中心,统一配置中心等。 目前国内比较成熟的吧,东软有一支团队在做,他们网站是 https://platform.neusoft.com/

国内商业级RestCloud微服务架构

1、作为企业API调用的统一出口和权限认证中心2、作为轻量级的企业级服务总线替换企业原有的ESB系统3、实现所有API接口的标准化、可视化、统一化管控4、作为微服务架构的核心API网关,集成到企业微服务架构中5、作为企业与供应链及合作伙伴的能力输出接口构建OpenAPI门户6、作为企业调用第三方API(京东、淘宝)等的统一API接入平台7、打通企业内部业务系统与外部业务系统之间的通道8、实现企业已有RestAPI、WebService、Dubbo、Kafka、MQTT等接口的注册和协议转换

微服务架构是一项在云中部署应用和服务的新技术。

大部分围绕微服务的争论都集中在容器或其他技术是否能很好的实施微服务,而红帽说API应该是重点。

微服务架构相关介绍:

微服务可以在“自己的程序”中运行,并通过“轻量级设备与HTTP型API进行沟通”。关键在于该服务可以在自己的程序中运行。通过这一点我们就可以将服务公开与微服务架构(在现有系统中分布一个API)区分开来。

在服务公开中,许多服务都可以被内部独立进程所限制。如果其中任何一个服务需要增加某种功能,那么就必须缩小进程范围。在微服务盯判架构中,只需要在特定的某种服务中增加所需功能,而不影响整体进程的架构。

微服务不需要像普通服务那样成为一种独立的功能或者独立的资源。定义中称,微服务是需要与业务能力相匹配,这种说法完全正确。不幸的是,仍然意味着,如果能力模型粒度的设计是错误的,那么,我们就必须付出很多代价。

如果你阅读了Fowler的整篇文章,你会发现,其中的指导建议是非常实用的。在决定将所有组件组合到一起时,开发人员需要非常确信这些组件都会有所改变,并且规模也会发生变化。服务粒度越粗,就越难以符合规定原则。

服务粒度越细,就越能够灵活地降低变化和负载凯裤改所带来的影响。然而,利弊之间的纯亏权衡过程是非常复杂的,我们要在配置和资金模型的基础上考虑到基础设施的成本问题。

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

主流的微服务包括:

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)的策略执行;

- 深度遥测和报告。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12456875.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存