怎样将系统拆分成微服务

来源:互联网 发布:南海海沟大地震 知乎 编辑:程序博客网 时间:2024/05/16 02:21

将系统划分为微服务。这是一门艺术,这里介绍一些策略希望可以帮助大家:

  •  通过业务功能分解,并定义与业务功能相对应的服务。
  •  使用DDD(域驱动设计方法)设计微服务。
  •  由动词或用例分解系统,并定义负责特定动作的服务。例如,一种负责装货运订单的运输服务。这里的“运输”就可以被用来分解系统,将运输服务分解成微服务。
  •  由名词或资源来分解系统,分离出某一个服务,这个服务负责对给定类型的名词实体或者资源实施操作。例如一个负责管理用户帐户的帐户服务。账户被用来分解出“账户服务”

 

理想情况下,每个服务都应该只有一小部分责任。设计模式中的SRP(Single Responsibility Principle)适合使用在此处。

 

另一个有助于服务设计的类比是Unix实用工具的设计。Unix提供了大量实用程序,如grep、cat和find。每个实用程序都做了一件事,通常非常出色,并且可以使用shell脚本与其他实用程序结合使用,以执行复杂的任务。微服务的设计也可以如此。