RabbitMQ + TSL 实现安全访问

## RabbitMQ + TSL 实现安全访问 前段时间,公司有台服务器需要安装 RabbitMQ 进行消息传输,对 MQ 服务的安全有着严格的要求。 - RabbitMQ 版本需要大于等于 3.6.9 - 不能使用 guest 用户 - 要求暴露外网的端口需要有 SSL 安全协议 这里就简单说说用户的配置与端口 SSL 的配置,如果大家配置自签证书出现问题,并且无法解决,

- 阅读全文 -

基于 DDD 的微服务设计演示

### 基于 DDD 的微服务设计演示 [TOC] #### 单 Service 实现数据查询 用单 Service 注入不同的 Dao,实现各种不同的查询。 > 大数据相关产品,运用大数据技术对海量的数据进行分析处理,并且最终的结果是通过各种报表来查询并展示。因此这些项目除了后台的各种分析处理以外,还要在前段展现各种报表,而且这些报表非常多且繁杂。同时,使用这个系统的都是决策型领

- 阅读全文 -

如何实现支持快速交付的技术中台战略

## 如何实现支持快速交付的技术中台战略 以往建设的系统都分为前台和后台,前台是与用户交互的UI界面,后台是服务端完成的业务逻辑操作。然而在我开发的很多系统中,有一些内容是共用的部分,在未来的开发系统中也要使用到,所以如果能把内容提取出来,做成共用主键,那么在未来开发系统就简单了,不用每次都重头开发。 > 公用的组件既包含前台的界面,也包含后台的逻辑,被称为“中台”。 > > 中台

- 阅读全文 -

DDD 是如何解决微服务拆分的难题

## DDD 是如何解决微服务拆分的难题 将微服务落地到具体的业务中,真正的难题是`微服务按照说明原则拆分、如何拆分以及会面对哪些潜在风险` > 微服务的拆分原则--“小而专”即微服务内高内聚、微服务间低耦合 > > 微服务的高内聚:就是单一职责原则,将代码修改的范围缩小到这个微服务内 > > 微服务间低耦合:在微服务实现自身业务的过程中,如果需要执行的某些过程不是自己的职责,

- 阅读全文 -

如何开事件风暴会议

## 如何开事件风暴会议 微服务设计最核心的难题是`微服务拆分`,要讲究“小而专”的设计,要“低耦合、高内聚”。这里以在线订餐系统项目来进行实战邻域模型设计。 ![image-20210904153156351](https://mufeng-blog.oss-cn-beijing.aliyuncs.com/typecho/image-20210904153156351.png

- 阅读全文 -

限界上下文

## 限界上下文 在软件设计中,复杂系统中包含了那么多的场景,每个场景都包含了那么多的邻域对象,并且每个邻域对象中还存在那么多的复杂关系,我们对系统的领域模型该如何设计? ### 问题域和限界上下文 首先,我们应该将整个系统划分成许多相对独立的业务场景,在一个个的业务场景中进行邻域分析与建模,这样的业务场景称之为“问题子域”,简称“子域”。 邻域驱动核心的设计思想--将对软

- 阅读全文 -

聚合、仓库与工厂

## 聚合、仓库与工厂 [TOC] 领域模型的最终设计可以落实到服务、实体和值对象 ### 服务 标识的是在领域对象之外的操作与行为,接收用户的请求和执行某些操作 当用户在操作界面中进行操作时,会向系统发送请求,“服务”去接收用户的这些请求,让后根据需求去执行相应的方法,所有操作都完成后,再将实体或值对象中的数据持久化到数据库中 ### 实体 通过一个唯一标识

- 阅读全文 -

领域模型落地数据库设计

## 领域模型落地数据库设计 > 早期的系统软件设计流程是以数据库为核心,当需求确定下来后,团队首先对数据库进行设计,通过数据库表作为模块接口,在数据库设计的过程中就尽量不要让模块接口存在交互,从而达到独立开发的效果。 > > 如果先进行数据库设计,但数据库设计只能描述数据结构,而不能描述系统对这些数据结构的处理。 ### 面向对象的软件系统设计流程图 ![系统设计流程图](

- 阅读全文 -

如何保持低成本维护与高质量的设计

## 如何保持低成本维护与高质量的设计 > 先推荐一本书《领域驱动设计:软件核心复杂性应对之道》。 在过去的开发初期软件系统并没有那么复杂,即使软件维护了几年,软件退化,软件变得越来越不好维护,推到重新开发就好。随着软件行业的快速发展,软件规模越来越大,生命周期也越来越长,推到重新开发的风险越来越大,这里时候软件团队急需一个低成本的状态下去持续维护一个系统很多年。 这个时候微服务

- 阅读全文 -

Jenkins 搭建与使用

## Jenkins 搭建与使用 ### Jenkins 定义 Jenkins 是一个开源那软件项目,目的是提供一个开放易用的软件平台,使用软件的持续集成变成可能。 Jenkins 是用于 Java 开发的一种持续集成工具,用于监控持续重复的工作,功能包括: 1. 持续的软件版本发布/测试项目 2. 监控外部调用执行的工作 > 简单的理解 > > 1.

- 阅读全文 -