基于DDD的微服务架构设计
DDD领域驱动设计(DDD:Domain-Driven Design)
架构背景:
现有的架构设计实在受不了,业务的反反复复地变化,导致代码圈复杂度之深让人恐惧。之前的微服务架构经验让我更加彻底点,采用DDD领域驱动设计进行整个改变。
随着经过几个月的努力,确实慢慢地体会到ddd的架构设计的优势,聚合根设计能够协助我们整个服务改造,开发起来越来越迅速。
CQRS访问方式:
在CQRS的架构体系,首先会被独立出来两个组件,一个事command的微服务负责add、update等改变状态的动作,query的微服务顾名思义就是读动作。
- 微服务采用spring-boot框架
- 构建、运行采用docker容器
- CQRS的axon、eventbus,存储采用elasticsearch
- gateway采用自主研发的方式,支持注册、发现、路由方式
案例:
gateway在之前的blog已经写过,不在这里叙述
首先简单的rest controller
@RestController public class NotifyController { @Autowired private CommandGateway commandGateway; @RequestMapping(value = "/notify", method = RequestMethod.GET) public void notify(HttpServletRequest request) { commandGateway.send(asCommandMessage(new CreateTaskCommand("1","chenyang","China")), new CommandCallback() { @Override public void onSuccess(Object result) { //成功继续事情 } @Override public void onFailure(Throwable cause) { //失败 } }); } }
Command:
public class SuccessNotification extends AbstractAnnotatedAggregateRoot<String> { /** * The constant serialVersionUID */ private static final long serialVersionUID = -159779842362041665L; @AggregateIdentifier private String id; @CommandHandler public SuccessNotification(SuccessNotifyCommand command) { apply(new SuccessNotifyEvent(command.getId())); } SuccessNotification() { } @CommandHandler void on(SuccessNotifyCommand command) { apply(new SuccessNotifyEvent(command.getId())); } @EventSourcingHandler public void on(SuccessNotifyEvent event) { this.id = event.getId(); } }
Event:
@EventHandler String on(SuccessNotifyEvent event) { return "world"; }
最终结论:
相对于烟囱式的方式,ddd对于开发者以及架构师要求更高,充当角色之一领域专家,需要对于聚合根理解透彻,才能更好地理解业务。
相关推荐
MrIronHand 2016-08-09
IT小小鸟 2019-11-04
evolone 2018-03-01
肖舸NoSQLt架构 2018-03-01
gggwfn 2016-08-09
yinren 2020-07-10
rise 2020-06-07
yinren 2020-02-04
87384496 2020-02-02
TingBen 2019-12-27
Abel 2015-04-23
zhuiqiuuuu 2019-11-11
超哥Blog 2011-05-21
pengruiyu 2019-10-20
刘涛 2015-04-23
87334992 2011-10-20
gilbertzhyin 2012-07-15
静 2019-06-28
yongyoumengxiang 2019-06-28