一个应用,拆分为多个小服务,这样的架构方式,就是微服务架构
我们拿一个电商贷款场景(如京东白条)划分微服务举例,以便后面的描述。 购买场景主要有如下关键服务。
我们一开始设计出如下图的服务架构:
对比的微服务的标准: 符合单独部署; 符合进程独立; 服务间通信使用rpc,符合轻量级。
专注于一件事这一点,看起来是符合,但是我们结合两个实际流程:
支付流程:
注册流程:
我们可以看到,除了微服务本身的逻辑,在具体流程下,部分微服务还要考虑如何和别的服务串起来,也就是说,原有的逻辑层,并未消失,而是分散到了各个微服务,职责并不单一!
于是架构进化:
可以看到,多了一层聚合层。专门负责聚合领域层的数据,对外提供接口。而领域层的微服务,只用承担好自己领域的职责,提供出独立,通用的服务接口。但在业务扩展的过程中,我们发现聚合层业务越来越重,于是乎,我们需要继续演进:
聚合层也做了拆分,于是,领域层是一组微服务,聚合层是一组微服务,职责清晰。聚合层划分通常可以考虑到实际业务的前端界面,页面为最小粒度来考虑聚合层微服务,不失为一个参考办法,即一个页面或者几个页面为一个微服务。
五年前加入腾讯时还是使用典型的logic-server架构,后面微服务如燎原之火,成了新的主角。后续经历的上市外企,tmd中的一家,微服务也是大行其道。也时常思考微服务的必要性。
微服务 优点:
缺点