当前位置: 首页 > news >正文

莆田市秀屿区建设局网站企业关键词大全

莆田市秀屿区建设局网站,企业关键词大全,php wordpress开源,wordpress怎么分栏前言 今天要跟大家分享的是监控数据变化#xff0c;实现自己的业务的另一个思路#xff0c;基于数据库的binglog。我这里是用的Binlog4j实现#xff0c;希望看总结的#xff0c;直接看最后。 一、Binlog4j是什么#xff1f; Binlog4j是轻量级 Mysql Binlog 客户端, 提供宕…前言 今天要跟大家分享的是监控数据变化实现自己的业务的另一个思路基于数据库的binglog。我这里是用的Binlog4j实现希望看总结的直接看最后。 一、Binlog4j是什么 Binlog4j是轻量级 Mysql Binlog 客户端, 提供宕机续读, 高可用集群等特性等等。具体看一看它的官网目前已经出到1.9.0版本项目加入了Dromara 社区。 二、使用步骤 先说下我这里用上这个的原因 多个数据增删改触发重新计算不想在每个业务操作方法后调用重新计算不想aop切面处理实现重新计算不想用springboot的事件、监听实现重新计算骨子里想创新接受新事物、新思路 所以我选择了它下面我简单介绍下使用。 官网其实有demo我这里是与springboot集成。 1.引入库 !-- binlog支持 --dependencygroupIdcom.gitee.Jmysy/groupIdartifactIdbinlog4j-spring-boot-starter/artifactIdversion1.9.0/version/dependencymysql的依赖、redis的依赖自行补充。 2.配置文件 spring: binlog4j:database: 要监听的数据库一个实例上有多个库redis-config: #redis配置host: ipport: 端口password: 密码client-configs:master:username: 数据库用户password: 密码host: 数据库ipport: 端口serverId: 1990配置说明 timeOffset 时间偏移量, 单位毫秒serverId 编号redisConfig Redis 配置信息, 详见 RedisConfiginaugural 首次启动, 如果为 true 在启动时不再读取 Redis 记录persistence 是否启用持久化, 默认为 falsestrict 严格模式, 默认为 truemode 模式, 详见: BinlogClientModeusername 数据库账户password 数据库密码host 数据库所在服务器 IP 地址port 数据库占用端口, 默认 3306hikariConfig 数据库连接池配置 3.统一监听处理 MyBinlogEventHandler import cn.hutool.core.bean.BeanUtil; import cn.hutool.core.bean.copier.CopyOptions; import cn.hutool.core.date.StopWatch; import cn.hutool.json.JSONUtil; import com.gitee.Jmysy.binlog4j.core.BinlogEvent; import com.gitee.Jmysy.binlog4j.core.IBinlogEventHandler; import com.gitee.Jmysy.binlog4j.springboot.starter.annotation.BinlogSubscriber; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Value; import site.morn.rest.RestBuilders; import site.morn.rest.RestMessage;import javax.annotation.Resource;/*** binlog事件处理器* 连接数据的用户需要有binlog读权限** author zwmac*/ Slf4j BinlogSubscriber(clientName master) public class MyBinlogEventHandler implements IBinlogEventHandler {Value(${spring.binlog4j.database:linkappdb})public String monitorDatabase;Resourceprivate ProgressWarnService progressWarnService;Overridepublic void onInsert(BinlogEvent binlogEvent) {//log.info(数据库 binlogEvent.getDatabase());//log.info(数据表 binlogEvent.getTable());//log.info(插入数据 binlogEvent.getData());//需要重新计算场景//1、插入设置 app_progress_warn_config//2、新增实际进度详情 app_progress_real_detail//3、新增进度计划任务子节点app_progress_infoRestMessage restMessage RestBuilders.successMessage();CalProgressWarnVo calVo new CalProgressWarnVo();calVo.setType(1);String tableName binlogEvent.getTable();if (app_progress_warn_config.equals(tableName)) {StopWatch sw new StopWatch();sw.start();calVo.setDataType(1);ProgressWarnConfig progressWarnConfig BeanUtil.mapToBean(JSONUtil.parseObj(binlogEvent.getData()), ProgressWarnConfig.class, true, CopyOptions.create().ignoreNullValue());calVo.setNewData(progressWarnConfig);restMessage progressWarnService.calProgressWarn(calVo);sw.stop();log.info(新增[进度预警配置]数据触发binlog事件执行结果:{}-耗时:{}ms, restMessage.getCode(), sw.getTotalTimeMillis());}if (app_progress_real_detail.equals(tableName)) {StopWatch sw new StopWatch();sw.start();calVo.setDataType(2);ProgressRealDetail realDetail BeanUtil.mapToBean(JSONUtil.parseObj(binlogEvent.getData()), ProgressRealDetail.class, true, CopyOptions.create().ignoreNullValue());calVo.setNewData(realDetail);restMessage progressWarnService.calProgressWarn(calVo);sw.stop();log.info(新增[实际进度详情]数据触发binlog事件执行结果:{}-耗时{}ms, restMessage.getCode(), sw.getTotalTimeMillis());}if (app_progress_info.equals(tableName)) {StopWatch sw new StopWatch();sw.start();Object progressInfoObj binlogEvent.getData();ProgressInfo progressInfo BeanUtil.mapToBean(JSONUtil.parseObj(binlogEvent.getData()), ProgressInfo.class, true, CopyOptions.create().ignoreNullValue());if (progressInfo.getType() 2) {//计划任务才需要重新计算calVo.setDataType(3);calVo.setNewData(progressInfo);restMessage progressWarnService.calProgressWarn(calVo);}sw.stop();log.info(新增[进度任务]数据触发binlog事件执行结果:{}-耗时{}ms, restMessage.getCode(), sw.getTotalTimeMillis());}}Overridepublic void onUpdate(BinlogEvent binlogEvent) {//log.info(数据库 binlogEvent.getDatabase());//log.info(数据表 binlogEvent.getTable());//log.info(原数据 binlogEvent.getOriginalData());//log.info(新数据 binlogEvent.getData());//需要重新计算场景//1、设置表变更 app_progress_warn_config//2、进度详情记录变更 app_progress_real_detail//3、进度计划任务变更计划开始时间、计划结束时间、工期app_progress_infoRestMessage restMessage null;CalProgressWarnVo calVo new CalProgressWarnVo();calVo.setType(2);String tableName binlogEvent.getTable();if (app_progress_warn_config.equals(tableName)) {StopWatch sw new StopWatch();sw.start();calVo.setDataType(1);ProgressWarnConfig oldConfig BeanUtil.mapToBean(JSONUtil.parseObj(binlogEvent.getOriginalData()), ProgressWarnConfig.class, true, CopyOptions.create().ignoreNullValue());ProgressWarnConfig newConfig BeanUtil.mapToBean(JSONUtil.parseObj(binlogEvent.getData()), ProgressWarnConfig.class, true, CopyOptions.create().ignoreNullValue());calVo.setNewData(newConfig);calVo.setOldData(oldConfig);restMessage progressWarnService.calProgressWarn(calVo);sw.stop();log.info(修改[进度预警配置]数据触发binlog事件执行结果:{}-耗时{}ms, restMessage.getCode(), sw.getTotalTimeMillis());}if (app_progress_real_detail.equals(tableName)) {StopWatch sw new StopWatch();sw.start();calVo.setDataType(2);ProgressRealDetail oldDetail BeanUtil.mapToBean(JSONUtil.parseObj(binlogEvent.getOriginalData()), ProgressRealDetail.class, true, CopyOptions.create().ignoreNullValue());ProgressRealDetail newDetail BeanUtil.mapToBean(JSONUtil.parseObj(binlogEvent.getData()), ProgressRealDetail.class, true, CopyOptions.create().ignoreNullValue());calVo.setNewData(newDetail);calVo.setOldData(oldDetail);restMessage progressWarnService.calProgressWarn(calVo);sw.stop();log.info(修改[进度详情]数据触发binlog事件执行结果:{}-耗时{}ms, restMessage.getCode(), sw.getTotalTimeMillis());}if (app_progress_info.equals(tableName)) {StopWatch sw new StopWatch();sw.start();calVo.setDataType(3);ProgressInfo oldInfo BeanUtil.mapToBean(JSONUtil.parseObj(binlogEvent.getOriginalData()), ProgressInfo.class, true, CopyOptions.create().ignoreNullValue());ProgressInfo newInfo BeanUtil.mapToBean(JSONUtil.parseObj(binlogEvent.getData()), ProgressInfo.class, true, CopyOptions.create().ignoreNullValue());calVo.setNewData(newInfo);calVo.setOldData(oldInfo);restMessage progressWarnService.calProgressWarn(calVo);sw.stop();log.info(修改[进度计划任务]数据触发binlog事件执行结果:{}-耗时{}ms, restMessage.getCode(), sw.getTotalTimeMillis());}}Overridepublic void onDelete(BinlogEvent binlogEvent) {//log.info(数据库 binlogEvent.getDatabase());//log.info(数据表 binlogEvent.getTable());//log.info(删除数据 binlogEvent.getData());//需要重新计算场景//1、删除进度详情记录 app_progress_real_detail//2、删除进度任务子节点app_progress_infoRestMessage restMessage null;CalProgressWarnVo calVo new CalProgressWarnVo();calVo.setType(3);String tableName binlogEvent.getTable();if (app_progress_real_detail.equals(tableName)) {StopWatch sw new StopWatch();sw.start();calVo.setDataType(2);ProgressRealDetail oldDetail BeanUtil.mapToBean(JSONUtil.parseObj(binlogEvent.getOriginalData()), ProgressRealDetail.class, true, CopyOptions.create().ignoreNullValue());calVo.setOldData(oldDetail);restMessage progressWarnService.calProgressWarn(calVo);sw.stop();log.info(删除[进度详情]数据触发binlog事件执行结果:{}-耗时{}ms, restMessage.getCode(), sw.getTotalTimeMillis());}if (app_progress_info.equals(tableName)) {StopWatch sw new StopWatch();sw.start();calVo.setDataType(3);ProgressInfo oldInfo BeanUtil.mapToBean(JSONUtil.parseObj(binlogEvent.getOriginalData()), ProgressInfo.class, true, CopyOptions.create().ignoreNullValue());calVo.setOldData(oldInfo);restMessage progressWarnService.calProgressWarn(calVo);sw.stop();log.info(删除[进度计划任务]数据触发binlog事件执行结果:{}-耗时{}ms, restMessage.getCode(), sw.getTotalTimeMillis());}}Overridepublic boolean isHandle(String database, String table) {//log.info(database:{},table:{}, database, table);//只监控aep数据库if (monitorDatabase.equals(database)) {return true;}return false;}} CalProgressWarnVo import lombok.Data;/*** 计算进度预警参数Vo** author zwmac*/ Data public class CalProgressWarnVo {/*** 类型1新增2变更,3删除*/private Integer type;/*** 数据类型1进度预警配置2进度详情,3进度计划任务*/private Integer dataType;/*** 旧数据*/private Object oldData;/*** 新数据*/private Object newData;} 从入参可以看出3类数据增删改都触发重新计算这里的oldData、newData可以直接用于修改的时候传参不用在查一次数据库。 progressWarnService.calProgressWarn(calVo);就是重新计算的具体实现了这就涉及到业务了各位自己实现。 总结 配置的账号要有binlog的读权限项目在跑直接用其他工具操作数据库也可以触发这就是监听binlog的美妙其他项目操作本项目的表也可以监听到原理同上统一入口不用有aop、事件、业务调用那么多入口需要考虑        好了就写到这里希望可以帮到大家拥抱新事物uping
http://www.hkea.cn/news/14474412/

相关文章:

  • 做中英文游戏门户网站关键词怎么弄南宁公司网站设计
  • 征求网站建设意见的通知厦门十大软件公司
  • 做网站 图片格式新建的网站可以百度推广
  • 百雀羚网站建设模版2018网站内容和备案
  • 网站项目的流程wordpress 轻博客 主题
  • 最大网站建设公司湖州网站设计公司
  • 中国品牌网站官网网站建设市场调研
  • 广州专业的网站制作网络品牌推广方案
  • 网站设计论文答辩装饰公司手机网站
  • 网站建设与管理 第2版电商设计属于什么设计
  • 黄页88网站推广效果举报网站建设运行情况
  • 搭建网站需要什么网站用户体验度
  • 北京做网站公司有哪些信息管理网站开发实验体会
  • 新手建什么网站赚钱销售管理系统软件哪个好
  • 怎么做网站鹅蛋生蚝婚庆公司租车
  • 长春市建设工程信息网站重庆网站界面设计
  • 成都企业网站设计制作企业做网站要注意些什么问题
  • 如何破解WordPress网站网站微商城的建设运营实践和思考
  • 360网站地图怎么做视觉设计网
  • 响应式网站开发工具做网站需要哪些人才
  • 网站建设平台方案住建部官方网站
  • 网站设计公司 知道万维科技河源网站网站建设
  • 专业的咨询行业网站制作wordpress视频播放
  • 建设人才服务信息网国家网站么网站开发人员属于什么软件
  • 更换网站后台管理系统讷河市铁道北建设高架桥
  • 轻松管理多个织梦网站重庆平台网站推广
  • 大气的网站首页网站栏目和版块的设计心得
  • 企业网络营销网站学生个人网页制作html源代码
  • 一键生成表白网站网站建设和网页制作
  • 和县网站定制北京网站建设公司动感