【微服务】微服务架构核心20讲
01丨什么是微服务架构?
data:image/s3,"s3://crabby-images/cc315/cc315828aca5c393eeaacadb4c9b48c9ec20932b" alt=""
02丨架构师如何权衡微服务的利弊?
data:image/s3,"s3://crabby-images/f3e47/f3e4792592436f5f2c2e4435269b44b89c8ee6ce" alt=""
data:image/s3,"s3://crabby-images/626b9/626b9f1c5cfae0dcb38c4d0e6e00e25abdc6fdfd" alt=""
03丨康威法则和微服务给架构师怎样的启示?
data:image/s3,"s3://crabby-images/bc058/bc0585188e879b2ab6bea4114182f4bf438baff8" alt=""
data:image/s3,"s3://crabby-images/1fb3f/1fb3fc8471efcaad7f14d43fc91283ea505d7953" alt=""
康威定律(Conway’s law),是马尔文康威1967提出的:“设计系统的架构受制于产生这些设计的组织的沟通结构。
”通俗的来讲:产品必然是其(人员)组织沟通结构的缩影。 -- 百度百科
康威定律可总结为四个定律:
-
第一定律,组织沟通方式会通过系统设计表达出来。
沟通成本 = N(N-1)/ 2,N代表沟通的总人数
沟通的问题会影响系统设计,软件架构最终会是沟通(组织)结构的映射。 -
第二定律,时间再多一件事情也不可能做的完美,但总有时间做完一件事情。
There is never enough time to do something right, but there is always enough time to do it over。
时间永远不够,人力永远不足,事情永远做不完,一件一件慢慢来来。
系统经过再严格的测试,总是会有问题。完美测试不存在,测试无法100%覆盖并保证系统没有问题,系统需要测试但永远避免不了问题。 -
第三定律,线性系统和线性组织架构间有潜在的异质同态特性。
There is a homomorphism from the linear graph of a system to the linear graph of its design organization。
什么样的系统对应什么样的组织,什么样的组织设计出什么样的系统。
架构由组织关系决定,架构服务于技术,同样服务于组织中的人 -
第四定律,大的系统组织总是比小系统更倾向于分解。
The structures of large systems tend to disintegrate during development, qualitatively more so than with small systems。
系统越复杂,越需越多的人手,需要越多的沟通,需要更高的成本。
分而治之,以结构化、模块化的方式架构和设计系统,以小团队形式进行开发和沟通。
04丨企业应该在什么时候开始考虑引入微服务?
05丨什么样的组织架构更适合微服务?
data:image/s3,"s3://crabby-images/a3423/a3423e43724a7d8a149b8a222c34dcf9dda43658" alt=""
data:image/s3,"s3://crabby-images/8956f/8956fd2c6bb35d3eaa76e11da05f04f63b5e345c" alt=""
06丨如何理解阿里巴巴提出的微服务中台战略?
data:image/s3,"s3://crabby-images/aa76f/aa76f4076b87a301192a4afeb0954a4ddfa642ee" alt=""
07丨如何给出一个清晰简洁的服务分层方式?
data:image/s3,"s3://crabby-images/06cd7/06cd7f0b342fb5aeb64c02624be0793f5439d6f6" alt=""
data:image/s3,"s3://crabby-images/fabf3/fabf37f5450333847f10854ca122326a1d0922d4" alt=""
08丨微服务总体技术架构体系是怎样设计的?
data:image/s3,"s3://crabby-images/bd3fa/bd3fa4e8a2837f07d1b95808287526618a66a1e0" alt=""
data:image/s3,"s3://crabby-images/4c66c/4c66c70965de6677a880e40f3e0676cdbcb17ebf" alt=""
09丨微服务最经典的三种服务发现机制
data:image/s3,"s3://crabby-images/14735/1473588a14a9c132bd1cfc971e841fef2e7ed5f2" alt=""
data:image/s3,"s3://crabby-images/b2739/b273993f2e95efcf47c6d2f7ee75a48bd54176a2" alt=""
10丨微服务 API 服务网关(一)原理
data:image/s3,"s3://crabby-images/64685/6468566755c48e0bcfdec05e665895488dd854a5" alt=""
data:image/s3,"s3://crabby-images/461d4/461d4959e8e476844ebb662ca60d0a777653da2d" alt=""
11丨微服务 API 服务网关(二)开源网关 Zuul
data:image/s3,"s3://crabby-images/bd45a/bd45ad243db7e99cbc2631b37bdcb0e5a77bd131" alt=""
data:image/s3,"s3://crabby-images/d0115/d0115dc256e4d8669ab86c11444455fd5d36cb20" alt=""
data:image/s3,"s3://crabby-images/b9de5/b9de57fe9eb47d860b72043f410f01c36fad5f81" alt=""
12丨跟 Netflix 学习微服务路由发现体系
data:image/s3,"s3://crabby-images/14c32/14c32d56058071384f532d2f3f8d5633bb38da19" alt=""
data:image/s3,"s3://crabby-images/e56cb/e56cbdda6e84a914085a86507cb60cac891f903d" alt=""
13丨集中式配置中心的作用和原理是什么?
data:image/s3,"s3://crabby-images/afe10/afe10426933bd88c99f32117ed918cc34c2802e5" alt=""
data:image/s3,"s3://crabby-images/70da6/70da6361a60e797c6f06ae663b6dcea59d195c19" alt=""
14丨微服务通讯方式 RPC vs REST
data:image/s3,"s3://crabby-images/e5d3d/e5d3dc26f77393adcf70f761e5502e8cbb2d1ec8" alt=""
15丨微服务框架需要考虑哪些治理环节?
data:image/s3,"s3://crabby-images/544ea/544ea6e8f6c3b87d16a39de3c375b0e706e3e816" alt=""
16丨微服务监控系统分层和监控架构
data:image/s3,"s3://crabby-images/aba18/aba18e5113fe5b8cd242f7f24a73a1e4bda75169" alt=""
data:image/s3,"s3://crabby-images/466d2/466d27590b2b277ab7079d127b6bf61e0fc0844e" alt=""
17丨微服务的调用链监控该如何选型?
data:image/s3,"s3://crabby-images/5465e/5465e9ad1c29839da3c6b66f91cab2b248cc1db9" alt=""
18丨微服务的容错限流是如何工作的?
data:image/s3,"s3://crabby-images/8a56f/8a56fa6dfa520dac27b0925c0b95cfafb4e8a0bc" alt=""
19丨Docker 容器部署技术 & 持续交付流水线
data:image/s3,"s3://crabby-images/c85fc/c85fc4d40537f43db834d7df9a81c440885b2e48" alt=""
20丨容器集群调度和基于容器的发布体系
data:image/s3,"s3://crabby-images/7ba95/7ba958ce2398bf858000da2fd8035d713ff9d079" alt=""
data:image/s3,"s3://crabby-images/2ce8a/2ce8a88b2945c85fbd51c9e945d4fcc033b54c43" alt=""