微服务-12 自开源高性能处理框架dataproces依托组件Canal+RocketMQ+Redis+ElasticSearch
自开源高性能处理框架dataproces依托组件Canal+RocketMQ+Redis+ElasticSearch
本次项目涉及到源码 https://gitee.com/lang_junnan/dataprocess
dataprocess简介
项目初衷:
随着业务系统的不断迭代,数据库的数据量也随着逐渐增大,就导致业务系统日常运行情况下很多接口查询请求缓慢, 甚至读取超时 ,为了整体优化项目,提高系统性能 希望在系统中对于部分业务充分利用缓存操作或使用ElasticSearch 搜索引擎来高效率的查询 那么问题来了,数据如何同步到ES,Redis或其他的容器中呢
数据同步:
既然是搜索业务,读取缓存 那么对数据的实时性要求一定很高,所以这里我们使用 阿里巴巴开源的Canal让它去监听 我们关系型数据库的主库例如 MySql-Master,实时读取数据库操作日志的变更,Canal就相当于关系型数据库的从库Slave, Canal经过很多次迭代已经很成熟了,Canal自身又对RocketMq和kafka做了集成 可以把数据库订阅的日志直接输送到我们MQ当中, 使用者只需要去监听MQ的消息队列即可,本次项目集成的是RocketMQ
dataprocess角色:
Mysql-》Canal-》RocketMQ-》dataproces提供观察者模式和责任链模式,其中观察者模式自动订阅数据,使用者按要求使用即可。 两种模式都对外提供 增 删 改 索引 回滚 异常捕获 前置拦截器 后置拦截器 等接口,其中拦截器功能默认不开启,使用者自己可以在配置文件中设置 dataprocess主要充当着监听数据来源 适配数据源 解析数据 检验数据 托管代理本次执行的数据 然后创建执行责任链或者订阅观察者模式, 两种模式其中一种就可以实现业务逻辑了,都是由使用者自己去定义的,只要编写的类实现了ChainTemplate责任链模板或者实现ObserverTemplate观察者 模板并且是在com.dataprocess.databases.某个库包下的表包下的所有实现类都会形成一条链或者都会被观察者通知到,当前执行的链条或观察者是可以被 dataprocess和Spring共同来管理的,没有执行的链条或观察者类由Spring自己来管理,所谓的当前执行链条或观察类就是监听到某个库中的某个表中的 某一批或一条记录发生了变更,针对当前数据表的链条或观察类是会被dataprocess来执行的,每个链条或观察者的实现类都对外开放了一些接口方法 例如: 添加 修改 删除 创建索引 异常捕获 拦截器 等操作,当某个 表发生了变化,就会以过滤链或者观察者的形式给使用者提供了 添加/修改/删除 异常捕获 拦截器 等接口方法,使用者只需要 专注去做自己想要做的添加功能 删除功能 修改功能 异常记录功能 就可以了,另外dataproces也提供了 缓存查询 和 ElasticSearch 复杂查询案例展示
项目涉及到的技术点:
- 基础环境 jdk1.8
- MySQL 5.5
- Canal.deployer-1.1.5
- RocketMQ-all-4.3.0-bin-release
- ElasticSearch-7.16.2-windows-x86_64
- Redis-x64-5.0.14
- SpringBoot2.6 集成ElasticSearch & Redis做CRUD
- SpringBoot2.6 集成ElasticSearch 复杂查询案例
系统结构
com.dataprocess.common ### 业务工具类 使用者可在该包下创建工具类
com.dataprocess.core ### 核心包 如果不是对项目结构,架构层面修改的代码 不建议修改该包下的代码
com.dataprocess.core.adapter ### 适配器类得扩展目前并没有做适配
com.dataprocess.core.builder ### 方案建造者
com.dataprocess.core.common ### 核心工具类
com.dataprocess.core.factory ### 核心工厂 策略处理
com.dataprocess.core.interceptor ### 前置,后置核心拦截器
com.dataprocess.core.handler ### 核心托管代理处理
com.dataprocess.core.subject### 观察者订阅的主题
com.dataprocess.core.template### 核心模板 责任链模板 观察者模板
com.dataprocess.databases ### 数据业务处理包 该包是专门为使用者提供的
### 该包下的第一个*包是数据库名称 第二个*包是数据表名称,使用者应 按照规范
### 在当前表名包下创建过滤器类 实现CoreTemplate约束 进行后续业务操作
com.dataprocess.databases.*.*
###demo案例 godnan包是MySql中bpm库,merchant包是bpm库下的merchant表
com.dataprocess.databases.bpm.merchant
com.dataprocess.es.api ### es接口对外提供的查询, 附带复杂查询案例
com.dataprocess.es.dao ### es 到层面的操作
com.dataprocess.es.entity ### es 涉及到实体 也叫文档
com.dataprocess.es.index ### es 文档索引
com.dataprocess.init ###初始化 es索引
com.dataprocess.interceptor ###给使用者提供的拦截器包
com.dataprocess.mq ### 监听rocketmq推送的消息
com.dataprocess.redis ###redis 配置相关信息
系统架构图2
内部依赖图
系统安装依赖
- 相关的资源地址: 链接:https://pan.baidu.com/s/18V38e4h9_BncyqYu1yp2BA 提取码:1234
- 准备环境 必备条件本地应安装好jdk1.8 并且配置好环境变量
- 以下安装链接是我个人博客园提供,描述比较简单,不保证您也能这么畅通,相信你也能遇到问题解决问题
- 下载ElasticSearch并配置 https://www.cnblogs.com/langjunnan/articles/15798379.html
- 下载Canal到本地并配置 https://www.cnblogs.com/langjunnan/articles/15798583.html
- 下载RocketMQ并配置 https://www.cnblogs.com/langjunnan/articles/15798518.html
- 下载Redis并启动 https://www.cnblogs.com/langjunnan/articles/15798670.html
- 下载dataprocess也就是当前项目到本地,并且找到SpringBoot的运行类 点击运行
- 成功案例介绍: https://www.cnblogs.com/langjunnan/articles/15799285.html
使用说明说
- dataprocess 为使用者提供了两种方案:1 观察者模式方案 2责任链模式方案 使用者只需要实现一种方案完成业务即可
- 在resources文件夹下 配置修改application.properties,application.yml两个文件的信息RocketMQ,Redis,Es配置
- 创建包 com.dataprocess.databases.. 第一个包 换成你想要连接数据库的名称 第二个包换成库下的表名,
- 观察者模式方案:在com.dataprocess.databases.*.*包下随便创建一个类或多个类 实现ObserverTemplate抽象类,这些类就会自己去订阅当前 表的动态,并且该类提供了 insertData updateData deleteData 和 对应的回滚方法 insertDataRollBack updateDataRollBack deleteDataRollBack
- 责任链模式方案:在com.dataprocess.databases.*.*包下随便创建一个类或多个类 实现ChainTemplate抽象类,这些类就会被系统所管理,由使用者 去决定是否要执行下一个类,伪代码如下:result=getNext().insertData(obj)或者在做好某个类业务点包装下一个请求参数再去执行下一个类,该类提供了 insertData updateData deleteData 和 对应的回滚方法 insertDataRollBack updateDataRollBack deleteDataRollBack
- 重点要注意得是和dataprocess默认建造的是OrdinaryBuilder构建者,我们也为你准备了代理构建者ProxyBuilder,使用代理构建者可以开启烂机器功能, 拦截器提供了 前置拦截器ProxyBefore和后置拦截器ProxyAfter,使用者只需要编写实现类实现拦截器接口,就可以实现自己的业务功能,
- 是否使用或开启代理构建者可以在application.properties配置文件中进行配置,open.proxy=false默认不开启代理模式 拦截器功能也不会开启, 在开启代理模式需要注意的是所有继承ChainTemplate,ObserverTemplate抽象类的实现类里面的属性 必须要有GET SET 方法,否则运行会出现 意想不到得错误,因为当前所有类由dataprocess代理,本次执行的所有类都是由Spring 和dataprocess 同时进行管理得,具体管理用到了浅Copy所以 必须要给所有属性加上 GET SET方法 7 es 相关的查询服务 可以在 com.dataprocess.es 下编写 8 找到DataProcessApplication类启动 确保项目能启动并且控制台不报错
贡献代码(欢迎您的加入)
如果你有兴趣参与项目开发,请联系我个人邮箱: 1419052183@qq.com 编码不易 如果觉得对您有帮助请点一下Star 同时 也接受您宝贵的建议 接受批评 谢谢!