0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

微服务优缺点解析

lhl545545 来源:电子发烧友网 2018-02-09 09:01 次阅读

前言

首先,微服务不是一个名字,而是一个架构的概念,就像Restful不仅仅是描述api的格式,而更多的是描述基于Restful API的架构是一样的。微服务架构(MSA)是对原来的大型系统而言的,通过横向或者纵向、业务或者架构切分,将一个大型的系统分散成很多微型小系统。当系统复杂到一定程度时,几十号人共同维护一个系统的效率很低,而且出问题的风险也很高。

这时候就需要对系统进行切分,很早之前提出的SOA系统,和微服务的架构理念不谋而合。大家现在使用的基于RPC框架(dubbo、thrift等)的架构也可以视为一种微服务。微服务到现在为止还没有确切的边界和定义,貌似计算机上很多概念都定义不出来边界。但是,我理解微服务之间的通信是http通信,传统rpc调用方式并不是严格的微服务,因为他不能自理,需要依赖,比如可能必须某个rpc服务Producer存在的情况下,rpc服务的Consumer才能启动起来。所以,下文中的讨论,我都以微服务之间以http通信为前提。

微服务有什么好处

解耦:对于我们底层程序员而言,看得见的好处就是解耦。我要实现一个功能,可能并不需要很深入的了解别人的代码,因为程序员嘛,可能都觉得别人的代码是个渣渣([哭笑不得])。我可以新作一个微服务,这个服务为其他功能提供服务,又不依赖于原来已有的功能,至于业务逻辑,可以一边上手一边熟悉 内聚,可以独立部署:意思就是我维护的这个微服务,可以独立部署,对其他服务不会是强依赖,不会存在因为其他服务不存在而造成我自己的服务不能启动或者不可用的问题。

分布式:微服务架构下不存在一个特别大的系统包含很多中心功能,这样也能提高容错性,一个服务的瘫痪并不会让整个系统瘫痪 权限验证:微服务是高度内聚的服务,我自己的这个服务,我可以定制任意合理规则,而这个规则又只适用于我自己的服务。相比于dubbo RPC调用,http微服务调用的权限验证可以更直接更严格更定制化,而rpc调用时的权限验证,我个人始终觉得不能做的很优雅 数据分开治理,自带分库属性:原来的大系统使用一个数据库,当数据很多流量很大时,就会涉及到分库分表。

而微服务下,每个服务是否使用数据库,数据库是和其他服务公用还是自建,都有很大灵活性,即我觉得微服务自带分库分表属性 系统不会被长期限制在某个技术栈上,在微服务的架构下,整个系统不会受限于java或者nodejs 或者go,而是大家协同不冲突,全部http协议,json格式 各个模块的单元测试容易自动化 等

微服务面临的挑战

通信,http请求速度慢,通常一个操作可能会涉及到多个微服务的相互调用,如果为了完成一个操作而多次从服务端调用不同的微服务,http请求的耗时可能会成为瓶颈,如图1所示。

微服务优缺点解析

客户端与服务端的通信需要一个 API GateWay:通常情况下,客户端和微服务们不在一起,而各个微服务会集中部署在一个机房,那微服务之间的互相调用是很快速的,但是客户端和微服务之间的调用会是耗时的。而且,用户的一个动作不能在客户端进行多次连续调用,这样一来速度慢,二来会有泄漏系统架构的风险。正常情况下,在客户端和微服务架构之间会有一个API GateWay。

如图1变成图2所示,GateWay最重要的作用是为客户端提供后台服务的聚合,提供一个统一的服务出口,解除他们之间的耦合,为了解决API Gateway单点故障点或者性能瓶颈,通常Gateway也是一个集群,而且客户端的访问控制、账号管理、登录管理等切面通常会在这里处理

微服务优缺点解析

微服务很多时,整个链路可能很长,调用失败的风险高,而且e2e自动化测试会成为一个问题 服务注册和服务发现,我司有自己的服务管理系统。我推荐etcd。Google开源的Kubernetes(k8s)貌似也是使用的这个。 分布式事务,这个是微服务系统的大难点,可能需要根据自己系统的情况和业务需求进行定制了,我推荐补偿性分布式事务和基于消息的分布式事务。(下次有时间介绍一下常用的集中分布式事务要怎么做)

基于微服务架构和架构实施过程中存在的优点和缺点:

采用微服务架构的优点

采用微服务架构可以更好的实现DevOps开发运维一体化,同时因为微服务架构下各个微服务模块相对独立和松耦合,因此在后续业务变更的分析和处理中往往能够更加敏捷快速的响应,同时相对影响也最小。

整个业务系统水平扩展更加容易,单体应用要扩展往往数据库是大问题,而在微服务架构下实现了单体应用的垂直拆分,可以更加容易的通过廉价的X86服务器资源来实现水平扩展。

通过微服务架构可以更好的提升各个模块的可复用性和可组装性。通过微服务架构更好的实现了原单体应用内部各个组件或模块的彻底解耦,通过解耦本身也降低了原单体应用内部的复杂度。

可以使研发过程根据敏捷和小团队化,包括和敏捷软件开发最佳实践更好的匹配,每个微服务模块都可以形成独立的敏捷小团队进行开发和部署上线。

进一步在传统单体应用内部实施SOA参考架构思想,体现业务能力组件化,组件能力服务化,同时也可以更好贯彻各个能力中心和前端应用组件的分离,实现共性能力下沉和复用。

采用微服务架构的缺点或困难

微服务架构需要开发团队本身具备较强的团队管理能力,软件研发技能,因为管控的粒度单位已经从原有业务系统变化为了微服务模块。

微服务架构本身会提升开发难度和工作量,特别是上层的跨多个微服务模块或组件的功能应用的实现,往往需要在前端进行服务组合而不是传统方式在数据库层做SQL关联。

由于各个微服务模块完全相对独立和松耦合,因此对于跨多模块业务带来的分布式事务问题是必须解决或找寻替代方案。特别是在微服务架构下数据库已经进行了垂直拆分,对于跨库访问本身的分布式事务一致性问题是最需要和重视的问题。

服务的治理将成为实施微服务架构中重点问题,包括了服务全生命周期管理,服务后期的运维和监控,性能分析,服务链监控等。如果企业本身的IT治理和SOA管控治理能力弱,那么及时开始正常实施了微服务架构,到了后期的运维管控也很难做的很好。其核心原因还是管控的粒度更加细,需要管控的微服务模块,服务接口都会呈现指数级增加。

集成复杂度增加,任何彻底的分解都将带来集成的复杂度,即模块在集成时候需要外部微服务模块更多的配合。

部署复杂度增加,由于微服务模块需要独立部署,往往涉及到多达上100个容器的安装和部署和集成等相关工作,这也是需要和Docker集成并实现自动部署的一个原因。

微服务很多时,整个链路可能很长,调用失败的风险高,而且e2e自动化测试会成为一个问题 服务注册和服务发现,我司有自己的服务管理系统。我推荐etcd。Google开源的Kubernetes(k8s)貌似也是使用的这个。 分布式事务,这个是微服务系统的大难点,可能需要根据自己系统的情况和业务需求进行定制了,我推荐补偿性分布式事务和基于消息的分布式事务。(下次有时间介绍一下常用的集中分布式事务要怎么做)

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 微服务
    +关注

    关注

    0

    文章

    137

    浏览量

    7352
收藏 人收藏

    评论

    相关推荐

    宝藏级微服务架构工具合集

    宝藏级热门微服务架构工具包含Spring Boot、Eclipse Vert.X、Kubernetes、Tyk、RabbitMQ、Apache Kafka等。其中,Spring Boot简化了微服务
    的头像 发表于 12-21 16:33 149次阅读

    通用型企业云服务器的优缺点

    通用型企业云服务器是一种基于云计算技术的服务器解决方案,它通过虚拟化技术将计算资源、存储资源和网络资源提供给用户,具有多种优势和一定的局限性。主机推荐小编为您整理发布通用型企业云服务优缺点
    的头像 发表于 12-17 09:57 83次阅读

    不同类型UPS电源的优缺点

    不间断电源(UPS)是为关键设备提供稳定、不间断电力供应的重要设备。根据设计和功能的不同,UPS可以分为几种类型,每种类型都有其独特的优缺点。以下是一些常见的UPS类型及其优缺点的概述: 在线式
    的头像 发表于 10-28 10:45 533次阅读

    微服务架构与容器云的关系与区别

    微服务架构与容器云密切相关又有所区别。微服务将大型应用拆分为小型、独立的服务,而容器云基于容器技术,为微服务提供构建、发布和运行的平台。区别在于,
    的头像 发表于 10-21 17:28 228次阅读

    入门级攻略:如何容器化部署微服务

    第一步理解容器化基础,第二步创建Dockerfile,第三步构建推送镜像,第四步部署微服务,第五步管理微服务、第六步优化更新。容器化部署微服务是现代软件开发中的一种高效方法,可提供良好的可移植性、可扩展性和管理性。容器化部署
    的头像 发表于 10-09 10:08 156次阅读

    雪崩晶体管有哪些优缺点

    雪崩晶体管作为一种特殊的半导体器件,在电子领域具有其独特的优缺点
    的头像 发表于 09-23 18:05 305次阅读

    采用OpenUSD和NVIDIA NIM微服务创建精准品牌视觉

    全球领先的创意和制作服务机构率先采用 OpenUSD 和 NVIDIA NIM 微服务来创建精准的品牌视觉。
    的头像 发表于 08-01 14:33 427次阅读

    AI大模型与小模型的优缺点

    在人工智能(AI)的广阔领域中,模型作为算法与数据之间的桥梁,扮演着至关重要的角色。根据模型的大小和复杂度,我们可以将其大致分为AI大模型和小模型。这两种模型在定义、优缺点及应用场景上存在着显著的差异。本文将从多个维度深入探讨AI大模型与小模型的特点,并分析其各自的优缺点
    的头像 发表于 07-10 10:39 2753次阅读

    远程连接路由器:方法大全与优缺点解析

    远程连接路由器的方式主要有以下几种,以下是每种方式的详细说明及其优缺点: 1、使用Web浏览器登录 方法:通过配置路由器的远程管理功能,允许用户通过互联网浏览器访问路由器的管理界面。用户只需输入
    的头像 发表于 06-11 12:05 662次阅读
    远程连接路由器:方法大全与<b class='flag-5'>优缺点解析</b>

    nbiot和lora的优缺点是什么?

    nbiot和lora的优缺点
    发表于 06-04 06:37

    日本大带宽服务优缺点分析

    日本大带宽服务器是很多用户的选择,那么日本大带宽服务优缺点都是什么?Rak部落小编为您整理发布日本大带宽服务优缺点分析。
    的头像 发表于 03-22 10:08 469次阅读

    DHCP服务器的优缺点简介

    DHCP服务器在自动化配置、减少IP地址冲突、灵活性和安全性等方面具有显著优点,但也存在单点故障、配置复杂性、性能瓶颈和安全问题等缺点。在实际应用中,需要根据网络规模和需求来权衡这些优缺点,并采取相应的措施来确保网络的稳定性和安
    的头像 发表于 03-21 10:19 1150次阅读

    【算能RADXA微服务器试用体验】Radxa Fogwise 1684X Mini 规格

    通过网络可以了解到,算能RADXA微服务器的具体规格: 处理器:BM1684X 算力:高达32Tops INT8峰值算力 内存:16GB LPDDR4X 内存 存储:64GB eMMC 编程框架
    发表于 02-28 11:21

    Java微服务随机掉线排查过程简析

    我们的业务共使用 11 台(阿里云)服务器,使用 SpringcloudAlibaba 构建微服务集群, 共计 60 个微服务, 全部注册在同一个 Nacos 集群。
    的头像 发表于 01-13 17:41 943次阅读
    Java<b class='flag-5'>微服务</b>随机掉线排查过程简析

    电动机调速方式的优缺点

    电动机调速方式的优缺点  电动机调速是指根据负载的要求调整电动机转速的过程,可分为机械调速和电子调速两种方式。机械调速主要使用机械装置来调整电动机的速度,而电子调速则利用电子器件对电动机进行精确
    的头像 发表于 01-04 11:26 1369次阅读