规模化微服务与研发组织管理

最近在工作中遇到很多IT圈的朋友,这些IT圈的朋友大部分都知道微服务,并且有相当的一部分正在参与在企业内部推行微服务的活动。

大家都非常清楚微服务的价值,随便拉一个出来就可以说出微服务的几大优点,高内积低耦合的架构设计、异构的服务带来技术选型的灵活性、独立发布与部署、高效的IT响应力......

大家同时也有很多疑问,微服务如何划分?微服务分到何种粒度合适,不是不是越小越好?微服务架构下,团队如何划分?开发活动如何组织?如何保证服务之间的API的有效集成?如何保证零散的服务最终能够构建成殿堂级的产品? 如何保证团队之间的高效沟通?如何保证团队的工作效能,会不会有的服务团队的工作量不饱满?
等等一系列问题。

我就这些问题谈一下我的思路与看法。

为什么微服务作为一种系统架构会带来新的挑战?这些挑战在单一结构的系统下是如何被克服的?

其实上规模的系统软件的研发早已经不是什么新鲜事,很多的应用软件,操作系统的研发人员动辄上百、上千。国内有的科技企业某一条产品线的研发人员就会达到上百人的规模。当然对于大型软件,研发方法也分为瀑布式和敏捷式两种,敏捷方法正在逐步的取代瀑布式的开发方式,成为了今天软件开发的主流。对于规模化的软件,敏捷方法给出的建议是对于团队之间的依赖,尽早集成,尽早反馈,从而规避后期的集成风险,因此,自动化测试以及持续集成被作为技术支撑手段被应用的淋漓尽致。
下图是大致的工作流程图。


image.png

当一个软件规模特别巨大的时候,比如说操作系统,这个时候继续集成这种方式就不够了,试想一下一个开发的机器上如何去运行一个操作系统级的软件产品做单元测试呢? 假如10各团队,100人是持续集成的实践的极限,那么对于1000人的研发队伍,如何管理呢?我没有接触过这么大规模的研发管理,但是我推测是这样的,对于这样的组织,需要增加层级来进行治理,为了避免层级的增加而导致协同成本的上升,根据康威定律的启发,需要建设对应层级的技术支撑,或者叫技术平台,来提高协同的效率。 结构可能是这样的......


image.png

一般的组织都会有一个或者多个层次的协同团队,这种层次的增加是自然而然的事情,但关键的问题是,组织层次的增加不会太来沟通协同效率的提升。敏捷强调组织的自我管理,能够进行自我管理的组织效能是最高的,但是规模化组织的自我管理需要制定标准,而对于研发而言,标准的制定落实到平台上是最切实可靠的,上图中对于coordination team的系统就是一个技术平台,也是一个标准平台,各个group的团队产生的组件都必须要保证能够和标准平台一起运行。使用这种开发模式,就可以进行超大规模的组件式软件开发,因为这个结构是可以扩展的,想象一下每个group的产出物里如果都有一个标准平台呢?是不是很有意思。

对于微服务而言,为什么他会带来新的挑战,为什么大家会不适应?我认为原因是,微服务的系统结构把超大规模软件研发的模式带入到了大规模甚至是一般性规模的软件产品研发中,导致大家手足无措,因为国内的超大规模软件研发的经验比国外少,为什么这么说呢?拿操作系统为例,windows和linux都是国外研发出来的,国内还没见到成功的操作系统。

而寻求解决之道,我认为要参考既有的超大规模软件的研发经验。

微服务研发管理之所以带来困扰,原因可能如下图所示,服务与服务之间有依赖,
对应的团队与团队之间就会有沟通协同的需要,当服务之间相互依赖比较多的时候,就会增加服务之间的耦合性,微服务的价值就会大打折扣。


image.png

有人会有疑问,这样的情况是因为服务拆分的不够合理,没有很好的识别bounded context,其实这也是一个balance,服务之间多多少少都有联系,服务之间耦合度降低到多少,才能够算是低耦合呢?这个没有标准答案。
暂时先搁置耦合度以及微服务个数的问题不谈,反观上图中令人头疼的原因,其实在于服务之间、以及团队之间的沟通没有被有效的管理,让人无处着手。
从组织协同的角度来看,解决此类问题的方法是增加协同机构,按照康威定律,这个协同机构需要技术实践来支撑才能来的高效。

image.png

而正是由于协同机构以及相应的技术支撑的出现,才能让"集市"变成"殿堂", 这里不是要批判《大教堂与集市》这本书里的观点,因为书中提到的linux系统在开源之前,已经有了一个版本,这就代表着本身已经形成了一定的标准。

更复杂的系统结构,更多的协同,更多的烦恼

我们进一步来看真正的系统结构,事情会更加复杂一些,


image.png

看,不光是服务之间有集成,前端和后端的team之间也有复杂的集成,随着前端设备的多样性,前端团队的形态也会随着技术分为多个开发团队。
由于PC前端开发工作量大,团队有可能被分为多个团队,也就是前端开发团队之间也会存在协同。看着是不是很头疼。

通常规避前后端协同复杂度的方式,是把前端开发与后端开发放在一个团队内部,如下图:

image.png

造成的问题是一个团队会有后端产出物和部分的前端产出物,在打包的时候会把前端代码共同打成一个包,因为前端很可能使用相同技术栈(如PC前端),那么不同团队之间的前端开发人员会共享部分的代码库,因此造成了团队之间额外的严重依赖。

如果我们把团队之间依赖分类,主要有:代码库依赖、API依赖,也可以叫做编译时依赖和运行时依赖。代码库依赖往往比API依赖要重,应优先避免。

那么我们假设一个理想的划分是这样的:


image.png

这样的结构可以很好的避免团队之间的代码级依赖以及API级的直接依赖。那么剩下的问题就是,如何实现coordination team 管理的协同标准部件呢?协同团队和协同标准平台如何在项目管理中发挥应有的作用呢? 这个问题我们要分别从软件研发的价值流以及技术实现两方面来考虑。

未完待续....

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352

推荐阅读更多精彩内容