微服务架构一直火,为什么服务化要搞懂?

  • 时间:
  • 浏览:0
  • 来源:大发快3_快3在线稳定计划_大发快3在线稳定计划

微服务架构,这 5 年左右经常被认可,是软件架构的未来方向。需要许多人 理解的是,为哪此需要服务化。比如微服务架构对企业来说,带来哪此价值?有啥弊端?

这里浅谈一下微服务架构,主要还是在理解 Why :为哪此需要服务化?

1.1 微服务架构

微服务架构,主这样来越多 多了个 “微”。亚马逊有个粗粗的定义:四个微服务应用工程的所有开发、测试、运维加起来离米 6 到 8 我每各人,只需要四个披萨就能否 聚餐了。

反例:也有四个 Service 类组成的应用工程,发布成服务这样来越多 微服务。另四个分的太小,理解微服务就很片面。杭州某金融大厂,另四个分的很细,造成了运维测试成本巨大。开使英语 分了合,折腾...

1.2 为啥需要微服务?

由 SOA 架构 -> 微服务架构的转变,得理解为哪此微服务架构被广泛提到并实践。它处里了哪此问题图片,带来了哪此价值?

传统企业如果这样来越多企业的软件,大多不止一套系统,也有各个独立大系统的堆砌。整体存在的问题图片是:

  • 扩展性差
  • 可靠性不高
  • 维护成本还很大
  • 重复轮子这样来越多

这样哪此问题图片,能否 想到的处里方案这样来越多 :

  • 组件化
  • 服务化

微服务架构,将各个组件如果模块分散到各个服务中,对整个系统实现解耦。那微服务架构强调的重中之重这样来越多 业务系统需要完善的组件化和服务化。哪此是组件化?

组件化,即将四个大系统,按照一定的业务如果技术维度关注形式,拆分成独立的组件。目的是为了分而治之,为了可重用,为了减少耦合度。比如按照技术维度:搜索组件、缓存组件;按照业务维度:用户中心、支付中心等

组件化是也有特别中台的意思?阿里巴巴提出 大中台,小前台;这样来越多 把组件化、插件化、服务化处里方案到极致。通过产品线公共业务如果技术下沉,形成各种技术如果业务中台

(图来自漫画守护系统进程员小灰)

2.1 这样服务化,不代表也有分布式或集群

分布式,这样来越多 多个实例提供相同的服务。比如多个地方动车站里面,多个机器提供取票服务。多个地方,北京上海等,这样来越多 多机房,多个取票服务一起去组成了集群,形成分布式服务。那啥是服务化?

服务化,强调 “化”!核心这样来越多 不同服务之间的通信。是有一种以服务为中心的处里方案:

  • 服务注册
  • 服务发布
  • 服务调用
  • 服务监控
  • 服务负载均衡
  • 等等

2.2 这样服务化的架构问题图片

这样服务化前,举个例子,会更形象:

假设有个取票服务、买票服务、改座服务都需要验证下用户身份真实性,这样会存在下面的问题图片:

  • 取票服务 -> 调用用户DB代码 -> 用户DB
  • 买票服务 -> 调用用户DB代码 -> 用户DB
  • 改座服务 -> 调用用户DB代码 -> 用户DB

明显的问题图片是:

  • 代码重复:不同业务相同访问 DB 的 userDAO 代码逻辑。如果每个服务这块代码是不同人维护的。
  • 可维护性低:不同人维护;不同地方维护;每次 DB 字段改变如果迁库,全部业务也有修改
  • DB 访问耦合

自然也有处里方案是:lib。维护四个 user-DAO-lib 1.0.0 release 包,给各个业务方。

处里了问题图片,引入了新的问题图片,lib 升级是巨大而又漫长的问题图片。比如小李是维护 user-DAO-lib 的人,有一次写了隐蔽的 bug 。user-lib 升级到了 1.0.1 release,花了 1 个月左右时间,推几四个业务方升级完毕。如果或多或少 bug 运行了几天冒出了,考虑升级fix如果回滚也有巨大的成本

基于服务化,就能否 完美处里问题图片。

如图 Post 文章服务调用 Video 视频服务,需要通过最上层的 Service 之间相互调用。服务化明显改变:

  • DB 隔离:另四个底层细节设计能否 屏蔽,后续加进去去或多或少存储 Cache 等对业务调用方无感知。
  • 通过 Service 之间通信:具体协议能否 RPC / HTTP 等

服务化后的好处:

  • 调用简单:不想写相同的访问用户服务代码,调用四个服务即可
  • 代码复用:跟 lib 形式的代码复用有所区别在于,服务化通过通信的最好的办法处里
  • 业务隔离
  • 数据库解耦
  • 等等

1、有一种不大的系统,业务不繁杂的系这样来越多统 需要微服务架构。微服务架构会带来一定的繁杂性,是一套全部的服务治理方案

2、多个模块数据库,分布式事务是四个挑战

3、开发过程,增加了测试等一定的繁杂性

有利必有弊,具体场景具体选泽

本小结,也有讲how,讲的是 why。只有懂 why ,并能更好地 do。从为啥服务化?到为啥微服务架构这样流行:

  • 微服务扩展性高
  • 微服务可靠性高
  • 微服务 维护成本小
  • 微服务几乎这样重复轮子
  • 微服务直接调用调用简单
  • 微服务业务隔离
  • 微服务数据库解耦
  • 等等

参考资料

  • 精华资料 原文链接 http://www.bysocket.com/technique/architecture/2423.html
  • 互联网架构,究竟为啥要做服务化?https://mp.weixin.qq.com/s/S6ga8y88qaAjbKjuKMrowQ
  • https://zh.wikipedia.org/zh-sg/%E5%BE%AE%E6%9C%8D%E5%8B%99

该文章通过 https://openwrite.cn/ 工具创造并群发。

猜你喜欢

微软发布Office 2019正式版,吸引未升级365的用户

IT之家9月25日消息微软在今天早些然后正式发布了Office2019forWindowsandMac。此次更新,是对过去三年在Office365里所有功能进行整合,包括对Wo

2020-01-23

CFC赫塔VSSC斯塔肯免费视频直播,CFC赫塔VSSC斯塔肯比赛集锦,CFC赫塔VSSC斯塔肯录像,CFC赫塔VSSC斯塔肯首发阵容

首页新闻视频直播数据APP懂球号直播君广告合作协议协议 CFC赫塔08-1820:00德高联赛1-5已现在刚刚刚刚开始SC斯塔肯直播君|分析|集锦暂无数据近期比赛亚特兰大意甲

2020-01-22

Spring Boot WebFlux 增删改查完整实战 demo

前言上一篇基于功能性端点去创建另5个 简单服务,实现了Hello。這個篇用SpringBootWebFlux的注解控制层技术创建另5个 CRUDWebFlux应用,让开发更

2020-01-22

住建部关于中国建筑业发展环境的分析

中国建筑业发展环境分析住房和城乡建设部建筑市场监管司住房和城乡建设部政策研究中心一、宏观经济环境(一)中国特色社会主义进入新时代2017年10月18日,中国共产党第十九次全国代

2020-01-22

星巴克外卖已覆盖2000家门店 通过阿里覆盖6亿会员

《星巴克外卖已覆盖60 0家门店通过阿里覆盖6亿会员》文章由于归档,不再展示相关内容,编辑建议你查看最新于此相关的内容:阿里巴巴LOGO设计者盛一飞:互联网的美工师对占据

2020-01-22