微服务架构 (八): 业务驱动与团队协作微服务粒度设计: 微服务内部的世界

2016.8.20, 深圳, Ken Fang

在“微服务架构設計 (七): 微服务粒度设计上的核心设计原则与思考的面向” 的一文中, 探讨了从微服务外部的世界驱动微服务粒度的设计。如文中所描述, 为了保障微服务整体的性能与可靠度, 可能会设计出粒度较大的微服务, 而降低了微服务持续部署的速度。

然而, 架构师也不能光只看到微服务外部的世界, 而轻忽或完全忽略了微服务内部的世界。因为, 当架构师轻忽或完全忽略了微服务内部的世界时, 将可能会使得微服务的粒度过大, 而使得微服务内部世界的复杂度过高, 开发与测试人员了解微服务需求 (场景) 的难度增加, 微服务的缺陷率升高, 微服务修复缺陷的时间增长。最终, 不仅使得微服务持续部署的速度越来越慢, 同时微服务整体的交付与运维的质量也会降低。

架构师需仅记微服务 “外部的世界” 远比 “内部的世界” 要来得重要。但, 并不代表著架构师可轻忽或完全忽略了微服务内部的世界。

架构师如何能避免自身轻忽或完全忽略了微服务内部的世界?

业务驱动与团队协作将能使得架构师, 避免自身轻忽或完全忽略了微服务内部的世界; 使得架构师可在微服务外部的世界与内部的世界中, 取得一较好的平衡点与可落地的实施方案。

I.   业务驱动: 业务驱动指的是, 架构师将微服务需达到的业务目的, 纳入微服务粒度设计的考量。

以不同的业务目的为例子来说明:

Case

业务目的

部署

性能

水平扩展

可靠性

微服务粒度

A

更快响应市场

重要性高

重要性低

重要性低

重要性低

B

更快响应速度

重要性低

重要性高

重要性高

重要性低

C

提升可靠性

重要性低

重要性低

重要性低

重要性高

II.      团对协作:

对于 Case A: 更快响应市场, 架构师设计了较小粒度的微服务。当然, 这样的设计, 就如在微服务架构設計 (七): 微服务粒度设计上的核心设计原则与思考的面向” 的一文中所提及的, 因微服务粒度小, 可能将使得微服务间的远程调用增加, 而使得整体微服务的性能降低。

此时, 架构师便必需与团队成员协作, 共同探讨出如何解决整体微服务性能降低的问题? 例如: 牺牲些水平扩展的能力; 将会产生互相调用的微服务,部署在同一节点上。

而对 Case B 与Case C, 就如同本文先前所提的: 微服务的粒度过大, 而使得微服务内部世界的复杂度过高, 开发与测试人员了解微服务需求 (场景) 的难度增加。

此时, 架构师、开发人员与测试人员便需经由轻量级, 可视化的工程实践 (注一) , 共同协作, 高效的完成微服务的分析、设计与测试用例的设计。以有效的提升开发与测试人员的效率与质量。

“微服务架构設計 (七): 微服务粒度设计上的核心设计原则与思考的面向” 与 “微服务架构設計 (八): 业务驱动与团队协作微服务粒度设计: 微服务内部的世界”, 分别从微服务外部的世界与微服务内部的世界, 探讨了设计微服务粒度; 边界上下文 (Bounded Context)。

总结这两篇文章, 所得出的: 设计微服务粒度; 边界上下文 (Bounded Context) 的原则:

A.      微服务 “外部的世界” 远比 “内部的世界” 重要。

B.      业务驱动; 在微服务外部的世界与内部的世界中, 取得一较好的平衡点。

C.      协作、协作、协作; 找到最适合市场, 产品与团队现况的微服务实施方案。

注一: 轻量级, 可视化的工程实践, 将在后续探讨: 微服务产品级敏捷时, 再来讨论。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏区块链开发科技公司

区块链开发公司 什么是区块链共识机制?

区块链是一种去中心化的分布式账本系统,由于点对点网络下存在较高的网络延迟,各个节点所观察到的交易事务先后顺序不可能完全一致。 因此区块链系统需要设计一种机制对在...

90
来自专栏云计算D1net

迁移云端,关于容量规划、灾难恢复你都想好了吗?

在将工作负载迁移到云端之前,管理员通常需要解决大量相关的问题,包括从软件即服务应用程序到灾难恢复以及容量规划,下文将介绍一些相关技巧。 不少企业进行云端迁移的工...

3445
来自专栏Cloud Native - 产品级敏捷

微服务产品级敏捷案例: DJ 企业云存储团队

2016.10.11,成都,Ken Fang DJ 企业云存储团队,运用微服务产品级敏捷,使得架构师、开发骨干、测试经理、开发人员、测试人员可共同的协作, 高效...

1755
来自专栏软件测试经验与教训

为什么不能照搬以前的成功经验?

3186
来自专栏云计算D1net

混合云策略的推动因素及优势

还没有做好完全脱离数据中心的准备,但是却对云计算所提供的优势十分感兴趣?很多人都有相同的想法。尽管现在越来越多的企业IT部门逐渐适应了云环境,但是企业还是不能放...

2686
来自专栏区块链

关于安全服务模型的一些思考

本文从云计算出发,结合云计算的优点,分析了云化的各种安全服务提供方式的特点和优势,总体来看SaaS、PaaS、IaaS三种安全服务提供方式对用户来讲,其使用的门...

1918
来自专栏企鹅号快讯

信息安全不可或缺应用交付 还需安全交付

从负载均衡、应用交付到交付安全,在短短的十数年里,交付领域的变化可谓日新月异,从软件到硬件,从4层负载到7层应用,而这两年,主流厂商又将应用交付的大旗指向了信息...

1809
来自专栏数据和云

揭秘:贵州交警“六合一”系统,零故障运行500天的背后

如今贵州地区,市民只需打开手机APP,就能够快速便捷地享受到诸如路况查询、违章处理、罚款缴纳等一系列自助式服务,免去了往来于家与交警队之间的奔波之苦。在其背后,...

3638
来自专栏SDNLAB

从应用的视角看网络

从一幅图说起 Step 1:从设备主导到软件定义分离网络数据平面和控制平面,实现软件定义网络(SDN),带来的是物理网络之上逻辑网络构建和控制的极大灵活性。 ...

3147
来自专栏云计算D1net

公共云存储服务的可扩展性和性能

公共云存储服务供应商可帮助企业用户免于承担物理硬件及其相关成本的负担,其中包括能源、冷却以及服务器维护等。 很多企业都在使用公共云、私有云以及混合云这样的一个组...

3159

扫码关注云+社区