java微服务_Java开发架构篇:领域驱动设计架构基于SpringCloud搭建微服务

9b08c7b744f14c3899d5acac687280b9.png

作者:小傅哥

来自:博客园小傅哥

一、前言介绍

微服务不是泥球小单体,而是具备更加清晰职责边界的完整一体的业务功能服务。领域驱动设计的思想通过Domain的功能域设计,可以把核心功能与支撑功能很好的区分开。而在MVC的设计模式尝尝是把所有的;数据服务、定义的属性类、提供的功能都在一条线上,这样是非常快速的开发方式但在作为服务部署时候却很麻烦。

按照不同的业务场景可能设计出软件在数据库使用上会有单库单表或者分库分表,如果是一个体量足够需要分库分表设计的系统,在扩容时候它是否能满足你的需求包括;

  1. 核心计算不涉及库扩容,但是系统功能都在一起怎么办,已扩容都扩容了很浪费
  2. 所有的扩容都涉及到数据库连接数增加,但并不是每个行为都直达到所有库表
  3. 持续发展的业务会带来数据激增,将来怎么进行扩展,重新洗数据并不是很好的选择

那么实际开发大泥球架构时,不只是会遇到上面的问题,还可能会遇到工期很赶加个人也不提升效率,反复交接代码扶不过三代等等,因此我们将服务拆分为独立单体具备此核心域完整功能的系统是非常必要的。

如图,是微服务数据库使用的一种思想,我们希望路由层从最开始就被执行,用户分群动态扩展

d255136dacdaeaaba9ea0a674b82509d.png

二、案例目标

本案例通过使用SpringCloud将我们的服务架构扩展为通过路由调用的微服务

  1. 首先通过Eureka作为服务注册与发现中心
  2. 然后使用Feign模式作为调用API接口
  3. 最后依赖于zuul设置路由转发功能

为了方便测试,本案例会在itstack-demo-ddd-03中建4个工程;itstack-demo-ddd-case{基于DDD的微服务}itstack-demo-ddd-eureka-server{服务注册与发现}itstack-demo-ddd-feign{调用方,通过API接口调用}itstack-demo-ddd-zuul{网关路由组件}

三、开发环境

  1. jdk1.8
  2. springboot 2.0.6.RELEASE 以及SpringCloud相关服务
  3. idea + maven

四、代码示例

1. itstack-demo-ddd-case | 基于DDD的微服务 {本段代码在上一章节已经演示}

itstack-demo-ddd-case└── src    ├── main    │   ├── java    │   │   └── org.itstack.demo    │   │       ├── application    │   │       │├── MallRuleService.java    │   │       │└── MallTreeService.java    │   │       ├── domain    │   │       │├── rule    │   │       ││   ├── model    │   │       ││   │   ├── aggregates    │   │       ││   │   │   └── UserRichInfo.java    │   │       ││   │   └── vo    │   │       ││   │       ├── DecisionMatter.java    │   │       ││   │       ├── EngineResult.java    │   │       ││   │       ├── TreeNodeInfo.java    │   │       ││   │       ├── TreeNodeLineInfo.java    │   │       ││   │       └── UserSchool.java    │   │       ││   ├── repository    │   │       ││   │   └── IRuleRepository.java    │   │       ││   └── service    │   │       ││       ├── engine    │   │       ││       │   ├── impl    │   │       ││       │   └── EngineFilter.java    │   │       ││       ├── logic    │   │       ││       │   ├── impl    │   │       ││       │   └── LogicFilter.java    │   │       ││       └── MallRuleServiceImpl.java    │   │       │└── tree    │   │       │    ├── model    │   │       │    │   ├── aggregates    │   │       │    │   │   └── TreeCollect.java    │   │       │    │   └── vo    │   │       │    │       ├── TreeInfo.java    │   │       │    │       └── TreeRulePoint.java    │   │       │    ├── repository    │   │       │    │   └── ITreeRepository.java    │   │       │    └── service    │   │       │        └── MallTreeServiceImpl.java    │   │       ├── infrastructure    │   │       │├── common    │   │       ││   └── Constants.java    │   │       │├── dao    │   │       ││   ├── RuleTreeDao.java    │   │       ││   ├── RuleTreeNodeDao.java    │   │       ││   └── RuleTreeNodeLineDao.java    │   │       │├── po    │   │       ││   ├── RuleTree.java    │   │       ││   ├── RuleTreeConfig.java    │   │       ││   ├── RuleTreeNode.java    │   │       ││   └── RuleTreeNodeLine.java    │   │       │├── repository    │   │       ││   ├── cache    │   │       ││   │   └── RuleCacheRepository.java    │   │       ││   ├── mysql    │   │       ││   │   ├── RuleMysqlRepository.java    │   │       ││   │   └── TreeMysqlRepository.java    │   │       ││   ├── RuleRepository.java    │   │       ││   └── TreeRepository.java    │   │       │└── util    │   │       │    └── CacheUtil.java    │   │       ├── interfaces    │   │       │├── dto    │   │       ││├── DecisionMatterDTO.java    │   │       ││└── TreeDTO.java    │   │       │└── DDDController.java    │   │       └── DDDApplication.java    │   └── resources    │       ├── mybatis    │       └── application.yml    └── test         └── java             └── org.itstack.demo.test                 └── ApiTest.java

2. itstack-demo-ddd-eureka-server | 服务注册与发现

itstack-demo-ddd-eureka-server└── src    ├── main    │   ├── java    │   │   └── org.itstack.demo    │   │       └── EurekaServerApplication.java    │   └── resources    │       └── application.yml    └── test         └── java             └── org.itstack.demo.test                 └── ApiTest.java

EurekaServerApplication.java | 启动服务

@SpringBootApplication@EnableEurekaServerpublic class EurekaServerApplication {    public static void main(String[] args) {        SpringApplication.run( EurekaServerApplication.class, args );    }}

application.yml | 服务配置

server:  port: 8989eureka:  instance:    hostname: localhost  client:    registerWithEureka: false    fetchRegistry: false    serviceUrl:      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/spring:  application:    name: itstack-demo-ddd-eureka-server

3. itstack-demo-ddd-feign | 调用方,通过API接口调用

itstack-demo-ddd-feign└── src    ├── main    │   ├── java    │   │   └── org.itstack.demo    │   │       ├── domain    │   │       │└── TreeDTO.java    │   │       ├── service    │   │       │└── MallService.java    │   │       ├── web    │   │       │└── FeignController.java    │   │       └── FeignApplication.java    │   └── resources    │       └── application.yml    └── test         └── java             └── org.itstack.demo.test                 └── ApiTest.java

MallService.java | 通过注册方式调用API

@FeignClient(value = "itstack-demo-ddd-case")public interface MallService {    @RequestMapping(value = "/api/tree/queryTreeSummaryInfo", method = RequestMethod.POST)    Object queryTreeSummaryInfo(@RequestBody TreeDTO request);}

FeignApplication.java | 启动服务

@SpringBootApplication@EnableEurekaClient@EnableDiscoveryClient@EnableFeignClientspublic class FeignApplication {    public static void main(String[] args) {        SpringApplication.run(FeignApplication.class, args);    }}

application.yml | 服务配置

server:  port: 9090spring:  application:    name: itstack-demo-ddd-feigneureka:  client:    serviceUrl:      defaultZone: http://localhost:8989/eureka/

4. itstack-demo-ddd-zuul| 网关路由组件

itstack-demo-ddd-zuul└── src    ├── main    │   ├── java    │   │   └── org.itstack.demo    │   │       └── ZuulApplication.java    │   └── resources    │       └── application.yml    └── test         └── java             └── org.itstack.demo.test                 └── ApiTest.java

ZuulApplication.java | 启动服务

@SpringBootApplication@EnableZuulProxy@EnableEurekaClient@EnableDiscoveryClientpublic class ZuulApplication {    public static void main(String[] args) {        SpringApplication.run(ZuulApplication.class, args);    }}

application.yml | 服务配置{本案例是静态路由,按需可以开发为动态路由}

server:  port: 9191spring:  application:    name: itstack-demo-ddd-zuuleureka:  client:    serviceUrl:      defaultZone: http://localhost:8989/eureka/zuul:  routes:    api-a:      path: /route-a/**      serviceId: itstack-demo-ddd-feign

五、测试验证

按照顺序启动;itstack-demo-ddd-eureka-server、itstack-demo-ddd-case{可以模拟启动多个}、itstack-demo-ddd-feign、itstack-demo-ddd-zuul

访问;http://localhost:8989/ | 服务中心

访问:http://localhost:9191/route-a/api/queryTreeSummaryInfo?treeId=10001 | 通过网关路由调用DDD服务接口

e0d68bab1c17ac538f929e211c52498d.png

六、综上总结

  1. DDD的设计模式加上SpringBoot与SpringCloud非常适合开发微服务
  2. 以上案例可以进行扩展,使不同的用户群体在网关接口调用时就打到不同的服务上
  3. 另外目前没有使用dubbo类型的rpc框架,也就是没有对外提供定义接口jar包,后续会进行延展
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值