农业资讯网
当前位置: 首页 农业百科

微服务介绍(每日分享什么是微服务)

时间:2023-05-27 作者: 小编 阅读量: 1 栏目名: 农业百科

这样有效避免了服务之间争用数据库和缓存资源所带来的问题。微服务与面向服务架构SOA的区别SOA是什么样子呢?可以是下面这样的WebService:也可以是下面这样的ESB企业服务总线:总之,SOA架构强调的是异构系统之间的通信和解耦合,而微服务架构强调的是系统按业务边界做细粒度的拆分和部署。

喜欢就关注下呗,又不让你背锅

单体架构的痛点

缺点一:项目过于臃肿

当大大小小的功能模块都集中在同一项目的时候,整个项目必然会变得臃肿,让开发者难以维护。

缺点二:资源无法隔离

就像刚刚小灰的经历一样,整个单体系统的各个功能模块都依赖于同样的数据库、内存等资源,一旦某个功能模块对资源使用不当,整个系统都会被拖垮。

缺点三:无法灵活扩展

当系统的访问量越来越大的时候,单体系统固然可以进行水平扩展,部署在多台机器上组成集群:

但是这种扩展并非灵活的扩展。比如我们现在的性能瓶颈是支付模块,希望只针对支付模块做水平扩展,这一点在单体系统是做不到的。

什么是微服务?

微服务(Microservice Architecture)是近几年流行的一种架构思想,关于它的概念很难一言以蔽之。

究竟什么是微服务呢?我们在此引用 ThoughtWorks 公司的首席科学家 Martin Fowler 的一段话:

In short, the microservice architectural style is an approach to developing a single application as a suite of small services, each running in its own process and communicating with lightweight mechanisms, often an HTTP resource API. These services are built around business capabilities and independently deployable by fully automated deployment machinery. There is a bare minimum of centralized management of these services, which may be written in different programming languages and use different data storage technologies.

谷歌翻译如下:

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

说了这么多概念,微服务有什么样的具体特点呢?

1.独立部署,灵活扩展

传统的单体架构是以整个系统为单位进行部署,而微服务则是以每一个独立组件(例如用户服务,商品服务)为单位进行部署。

用一张经典的图来表现,就是下面这个样子:

图中左边是单体架构的集群,右边是微服务集群。

什么意思呢?比如根据每个服务的吞吐量不同,支付服务需要部署20台机器,用户服务需要部署30台机器,而商品服务只需要部署10台机器。这种灵活部署只有微服务架构才能实现。

而近几年流行的Docker,为微服务架构提供了有效的容器。

2.资源的有效隔离

微服务设计的原则之一,就是每一个微服务拥有独立的数据源,假如微服务A想要读写微服务B的数据库,只能调用微服务B对外暴露的接口来完成。这样有效避免了服务之间争用数据库和缓存资源所带来的问题。

同时,由于每一个微服务实例在Docker容器上运行,实现了服务器资源(内存、CPU资源等)的有效隔离。

3.团队组织架构的调整

微服务设计的思想也改变了原有的企业研发团队组织架构。传统的研发组织架构是水平架构,前端有前端的团队,后端有后端的团队,DBA有DBA的团队,测试有测试的团队。

而微服务的设计思想对团队的划分有着一定的影响,使得团队组织架构的划分更倾向于垂直架构,比如用户业务是一个团队来负责,支付业务是一个团队来负责。

当然,这种垂直划分只是一个理想的架构,实际在企业中并不会把团队组织架构拆分得这么绝对

微服务与面向服务架构SOA的区别

SOA是什么样子呢?可以是下面这样的Web Service:

也可以是下面这样的ESB企业服务总线:

总之,SOA架构强调的是异构系统之间的通信和解耦合,而微服务架构强调的是系统按业务边界做细粒度的拆分和部署。

微服务架构的不足

,
    推荐阅读
  • 万词霸屏企业(万词霸屏适合什么行业)

    现如今的社会是信息产生价值的时代,网络产品更新迭代迅速,从线下销售转到线上营销的企业数不胜数,是企业发展的大趋势,但是目前网络市场鱼龙混杂,而企业没有自己的网络运营团队,导致无从下手,也有很多企业对万词霸屏系统进行咨询,那么到底那些行业更适合做霸屏推广呢?

  • 我国新能源乘用车市场现状(全国60余家新能源乘用车企业及其新能源战略盘点)

    全国60余家新能源乘用车企业及其新能源战略盘点近日,电动汽车资源网对汽车行业中涉足新能源乘用车的近60家企业进行了大盘点,以下企业的法人代表及注册资本等基本信息源于政府信息,新能源乘用车的款数以上公告的数量为准(截止到第289批《道路机动车辆生产。

  • 高血压治疗出了新指南(高血压治疗及误区)

    高血压治疗出了新指南来源:高血压治疗的根本目的是减少心脑肾以及血管并发症的出现,提高患者的生活质量,降低患者的死亡率。第一是急性期的治疗。第三是药物治疗。高血压是一种长期的疾病状态,一般是由于复杂的神经内分泌调节等因素所导致的。湘潭市第五人民医院老年病科张瑞英本文来自,仅代表作者观点。全国党媒信息公共平台提供信息发布传播服务。

  • 灭火器如何操作(灭火器怎么操作)

    接下来我们就一起去了解一下吧!灭火器如何操作一提,首先手提提把,保持水平垂直,再把灭火器瓶体上下颠倒摇晃几次,让干粉松动。二拔,拔掉灭火器保险销,在灭火器提拔下的环状金属物拔掉。三瞄,将灭火器的喷管瞄准火源,距离火焰3~5米处瞄准,一手握住喷管的最前端,控制好方向,另一只手提起灭火器提把。四压是指压住灭火器的开关,喷出干粉灭火。

  • qq电子邮件格式怎么写(qq电子邮件格式的填写方法)

    qq号码@qq.com,比如是你的qq号是12345678,则qq邮箱是12345678@qq.com;,下面我们就来说一说关于qq电子邮件格式怎么写?我们一起去了解并探讨一下这个问题吧!qq电子邮件格式怎么写qq号码@qq.com,比如是你的qq号是12345678,则qq邮箱是12345678@qq.com;英文格式,这个格式需要用户在邮箱设置里进行注册,格式为“英文@qq.com“;Foxmail格式,这个格式为“英文或数字@foxmail.com”。

  • 埃克塞特大学简介(埃克塞特大学简介介绍)

    埃克塞特大学简介埃克塞特大学,又名埃克斯特大学,是一所位于英国西南部的研究型大学,起源于十九世纪中叶,于1955年受皇家特许正式创建大学。现为英国罗素大学集团、英联邦大学协会、英国大学联盟和GW4联盟成员。学校位于英国西南部德文郡首府埃克塞特和康沃尔郡首府法尔茅斯,该地美丽的城市和海滨风光一同构成了大学优美的校园环境,被泰晤士报称为英国最美的花园式校园。学校位列2022QS世界大学排名第149名。

  • 什么品种的鸡有五个脚趾,鸡脚趾肿大是什么情况

    乌骨鸡一般有5个脚趾,前面有3个脚趾,后面有2个脚趾。如果是典型的乌骨鸡,那么它便会有丛冠、缨头、绿耳、胡须、丝毛、五爪、毛脚、乌皮、乌肉以及乌骨这10大特征,而在乌骨鸡的品种中,泰和乌骨鸡便满足了这个要求。乌骨鸡不光体型比较小,而且头部也较小,其颈部比较短,腿也比较矮,看起来较为小巧玲珑。

  • 大众途观l后排能放平吗(具体怎么操作呢)

    大众途观l后排能放平吗?以下内容大家不妨参考一二希望能帮到您!大众途观l后排能放平吗大众途观l后排能放平,具体的操作步骤如下:首先在汽车的后排,找到后背座椅的卡扣,这个卡扣是用来调节座椅放倒比例的。然后向上抬起卡扣,稍微用力就可以。然后先向前放倒左手边的座椅。

  • 热的组词(热什么意思)

    以下内容希望对你有帮助!热的组词热的组词:冷热、热心、热烈、热水、热爱、炎热、热天、热闹、闷热、热带、地热、热门、热量、燥热、酷热、热浪、热衷、郁热、热忱、白热、热乎、热度、热孝、内热、沸热、热血、热机、热切、热狗、热辣;热拼音为rè,基本含义是温度高,可引申为喧闹,热闹,情意深厚,很受人关注或欢迎的等意思。出自《素问·五常变大论》等。

  • 什么是老鼠仓(老鼠仓的解释)

    什么是老鼠仓老鼠仓是指庄家在用公有资金在拉升股价之前,先用自己个人的资金在低位建仓,待用公有资金拉升到高位后个人仓位率先卖出获利。大家都知道,中国股市的特色就是无庄不成股,而老鼠仓就存在于这些大大小小的庄股当中。这样的结果就是券商亏损累累,老鼠仓赚个钵满盆满。其实,老鼠仓就是一种财富转移的方式,是券商中某些人化公家资金为私人资金的一种方式,本质上与贪污、盗窃没有区别。