Java 实现实时监听MySQL数据库变更MySQLBinListener

news2024/10/6 10:31:30

目录

1、导出需要的类和接口

2、 定义 MySQLBinlogListener类

3、私有方法,启动重连定时器

4、完整代码


 

编写一个MySQL数据库实时变更的监听器。

为什么要编写这个一个监听器:为了实时监测和响应MySQL数据库中的变更事件

  1. 实时数据同步:通过监听MySQL Binlog,可以捕获数据库的变更操作,例如插入、更新、删除等,从而能够实时地获取数据的变动情况。这对于需要及时同步数据的应用场景非常重要,例如实时分析、数据同步等
  2. 数据库监控和审计:通过监听数据库的变更事件,可以实现对数据库的实时监控和审计功能。你可以捕获和记录数据库中的每个操作,了解数据库的变更情况,同时也方便进行故障排查和安全审计。
  3. 数据变更触发业务逻辑:当数据库中的数据发生变化时,可以通过监听器触发相应的业务逻辑。例如,在某个表发生变更时,可以发送通知、调用其他服务或者进行数据处理等操作。
  4. 数据缓存和更新:通过监听数据库变更事件,可以及时更新应用程序中的缓存数据,提高应用程序的性能和响应速度。当数据库数据变化时,可以通过监听器自动刷新缓存,确保应用程序使用的数据是最新的。

总之:写这样的监听器可以提供实时数据同步、数据库监控和审计、业务逻辑触发、数据缓存更新以及异构数据集成等多种好处。

那我们就开始来写一个这么的功能:

1、导出需要的类和接口

import com.github.shyiko.mysql.binlog.BinaryLogClient;
import com.github.shyiko.mysql.binlog.event.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.stereotype.Component;

import java.io.IOException;
import java.util.Timer;
import java.util.TimerTask;

接下来,使用一个Spring组件标记

@Component

2、 定义 MySQLBinlogListener

public class MySQLBinlogListener {

定义一个常量,表明定义的是重连间隔时间,单位可以设为毫秒。

private static final int RECONNECT_INTERVAL = 10000;

 定义一个定时任务,用于定时尝试重新连接MySQL服务器

private static Timer reconnectTimer;

定义一个BinaryLogClient对象,用于连接到MySQL服务器

private static BinaryLogClient client;

定义一个用于依赖注入的ApplicationContext对象

@Autowired
private static ApplicationContext applicationContext;

编辑程序的入口方法,它会调用startMySQLBinlogListener方法来开始监听MySQL Binlog事件

public void main(String[] args) {
    startMySQLBinlogListener();
}

这是startMySQLBinlogListener方法,它用于启动MySQL Binlog监听器

public static void startMySQLBinlogListener() {

创建一个BinaryLogClient对象,指定MySQL服务器的主机名、端口号、数据库名、用户名和密码。

client = new BinaryLogClient("127.0.0.1",3306, "你的数据库表","root", "密码");

设置BinaryLogClient对象的一些属性,包括保持连接、心跳包发送间隔和心跳包连接超时时间。

client.setKeepAlive(true);
client.setKeepAliveInterval(60 * 1000);
client.setKeepAliveConnectTimeout(5 * 1000);

注册事件监听器,对不同类型的事件做出响应。在这里,我们对TableMapEventData类型的事件进行处理,根据表名发送WebSocket消息;对UpdateRowsEventData、WriteRowsEventData、DeleteRowsEventData类型的事件进行输出日志。

client.registerEventListener(event -> {
    try {
        EventData data = event.getData();
        if (data instanceof TableMapEventData) {
            TableMapEventData tableMapEventData = (TableMapEventData) data;
            String database = tableMapEventData.getDatabase();
            String table = tableMapEventData.getTable();
            WebsocketService websocketService = new WebsocketService();
            if ("你的数据库表".equalsIgnoreCase(table)) {
                websocketService.groupSending("你的数据库表字段");
            }
            if ("你的数据库表".equalsIgnoreCase(table)) {
                websocketService.groupSending("你的数据库表字段");
            }
        } else if (data instanceof UpdateRowsEventData) {
            System.out.println("更新:");
            System.out.println(data.toString());
        } else if (data instanceof WriteRowsEventData) {
            System.out.println("添加:");
            System.out.println(data.toString());
        } else if (data instanceof DeleteRowsEventData) {
            System.out.println("删除:");
            System.out.println(data.toString());
        }
    } catch (Exception e) {
        e.printStackTrace();
    }
});

注册生命周期监听器,用于处理连接成功、通信异常、事件数据解析异常和连接断开等情况

client.registerLifecycleListener(new BinaryLogClient.LifecycleListener() {
    @Override
    public void onConnect(BinaryLogClient client) {
        System.out.println("MySQL数据库已连接!");
    }

    @Override
    public void onCommunicationFailure(BinaryLogClient client, Exception ex) {
        System.out.println("已执行通信故障方法!");
        ex.printStackTrace();
    }

    @Override
    public void onEventDeserializationFailure(BinaryLogClient client, Exception ex) {
        System.out.println("已执行反质化方法!");
        ex.printStackTrace();
    }

    @Override
    public void onDisconnect(BinaryLogClient client) {
        System.out.println("MySQL数据库已断开!");
        startReconnectTimer();
    }
});

3、私有方法,启动重连定时器

该功能如下:

private static void startReconnectTimer() {

如果已存在重连定时器,先取消之前的定时任务

if (reconnectTimer != null) {
    reconnectTimer.cancel();
}

创建一个新的重连定时器,并执行定时任务。定时任务中会尝试重新连接MySQL服务器

reconnectTimer = new Timer();
reconnectTimer.schedule(new TimerTask() {
    @Override
    public void run() {
        boolean isConnected = client != null && client.isConnected();
        try {
            if (isConnected) {
                System.out.println("和数据库断开连接。重连。。。。。。");
                client.disconnect();
            }
            client.connect();
        } catch (IOException e) {
            e.printStackTrace();
            startReconnectTimer();
        }
    }
}, RECONNECT_INTERVAL);
}

这就是整段代码的解释,它实现了一个MySQL Binlog监听器,能够监听MySQL数据库的变更事件并做出相应的处理。

4、完整代码

需要私聊。。。。。。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/559868.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

运营-12.转化

用户注册、登录、浏览、发布、购买等行为都可以视为转化;而对于电商产品而言,狭义的转化即为获取 收入,就是要用户买单、消费,把免费用户转化为付费用户; 转化的重要性 1.转化意味着用户有投入,投入即沉没成…

Serverless冷扩机器在压测中被击穿问题 | 京东云技术团队

一、现象回顾 在今天ForceBot全链路压测中,有位同事负责的服务做Serverless扩容(负载达到50%之后自动扩容并上线接入流量)中,发现新扩容的机器被击穿,监控如下(关注2:40-3:15时间段的数据)&…

人工智能AI 计算平台介绍

人工智能AI计算平台介绍 产品及服务: 标准模块开源 核心模块及服务收费 资源齐全 服务支持 产品使用者: 自行扩充组件 快速二次开发 轻松搭建企业级 数据挖掘应用 自…

linux0.12-10-1-总体功能

第10章 字符设备驱动程序 [466页] 10-1 总体功能 本章的程序可分成三部分: 第一部分是是关于RS-232串行线路驱动程序,包括程序rs_io.s和serial.c; 第二部分是涉及控制台的驱动程序,包括键盘中断驱动程序keyboard.S和控制台显示驱动程序con…

人工智能AI会话+文字转为markdown格式/思维导图的工具的介绍和使用

AI会话工具和文字转换为markdown格式 1、这里首先要有一个xmind思维导图软件,下载链接在下方。XMind: 2、本章中列举的AI工具是近期国内交火的prompt(文心一言 作者还没排上队) https://chat.givemeprompt.com/3、首先运用此工具生成你想要的…

leetcode刷题之数组问题总结,二分法,移除元素,

目录 一、二分查找相关应用704.二分查找35.搜索插入位置方法一:二分法暴力解法 34.在排序数组中查找元素的开始位置和最后一个位置方法一:暴力解法方法二:二分法,确定左右两侧的边界 69.x的平方根方法一:二分法方法二:暴力解法错解…

k8s1.26.1部署 ingress-nginx-controller(1.6.4)

文章目录 参考ingress-nginx git地址ingress-nginx 的 deployment的地址: 参考 1.24版本k8s集群配置Nginx-Ingressrancher配置https域名访问图文教程 ingress-nginx git地址 https://github.com/kubernetes/ingress-nginx ingress-nginx 的 deployment的地址&a…

cdn配置(超详细+图解+原理)

具体的详细配置在右侧目录翻到“三”,前面的一二是将原理 以腾讯云的cdn为例,其它家的大同小异 一、cdn作用和配置思路 (一)cdn作用 1.加速访问 cdn服务通常有多个节点缓存,用户可以就近获取,延迟较低 …

得物App万米高空WiFi拦截记

0.前情摘要 在一次飞行途中,我司客户遭遇到了得物App在飞机上的WiFi网络访问异常的问题。这让我们意识到在特定场景下,用户可能面临无法使用得物App的困扰。经过SRE团队与无线团队、网络团队联合全力排查与优化,最终成功解决了这一问题&…

PAN(Pyramid Attention Network for semantic segmentation)paper解读

Pyramid Attention Network for Semantic Segmentation讲PAN用于语义分割,网络结构类似encoder-decode, u-shape。 背景 encoder-decoder结构, 在encoding到高维度特征的过程中,原始的纹理信息会遭遇空间分辨率损失,例如FCN。 P…

Spring Boot进阶(39):SpringBoot之Jackson配置全局时间日期格式 | 超级详细,建议收藏

1. 前言🔥 不知道小伙伴对于日期字段,在项目中都是如何处理的,是单独给每个字段都自定义日期格式还是做全局格式设置?这个我之前啊,是对日期都是有做单独配置,给每个Entity带有日期字段的都配JsonFormat注解…

SolVES 模型与多技术融合【QGIS、PostgreSQL、ARCGIS、MAXENT、R】实现生态系统服务功能社会价值评估及拓展案例分析

生态系统服务是人类从自然界中获得的直接或间接惠益,可分为供给服务、文化服务、调节服务和支持服务4类,对提升人类福祉具有重大意义,且被视为连接社会与生态系统的桥梁。自从启动千年生态系统评估项目(Millennium Ecosystem Asse…

编译器设计(十四)——寄存器分配

文章目录 一、简介二、背景问题2.1 内存与寄存器2.2 分配与指派2.3 寄存器类别 三、局部寄存器分配和指派3.1 自顶向下的局部寄存器分配3.2 自底向上的局部寄存器分配3.3 超越单个程序块 四、全局寄存器分配和指派4.1 了解图着色4.2 找到全局活跃范围4.3 估算全局逐出代价4.4 冲…

前端列表页+element-puls实现列表数据弹窗功能

效果图: 这是一个修改的弹窗,我们要实现的功能是,在列表,点击修改按钮时,将数据带入到弹窗里面,点击保存时关闭弹窗。 1,点击修改展开弹窗 使用 eldialog组件,v-model绑定的值为tru…

fluent-operator在kubesphere中的实战详解

前言 最近收到一个小任务:熟悉kubesphere实现一个日志平台。基于这样的机会,将最近所整理的笔记进行汇总。 kubesphere开启日志收集 根据官网介绍只需要将 enabled 的 false 改为 true即可 执行kubectl get pod -n kubesphere-logging-system命令来检查…

QT课程 QT介绍

QT介绍(了解) Qt是一个基于C开发语言的图形用户界面开发(GUI)框架。界面开发知识Qt的一部分,实际上Qt也可以支持很多其他的功能,比如:网络编程、文件IO、图形图像处理等。 Qt在嵌入式领域最大…

Vue之插值表达式,v-bind(单向绑定),v-model(双向绑定)

文章目录 前言一、插值表达式二、v-bind指令三、v-model指令总结 前言 插值表达式{{…}} v-bind v-model 一、插值表达式 插值表达式支持匿名变量、三目运算符、四则运算符、比较运算符、数值类型的一些内置方法&#xff0c;还有数组的索引取值方法和对象属性。 <!DOCTYPE…

安全工具 | CMSeeK [指纹识别]

0x00 免责声明 本文仅限于学习讨论与技术知识的分享&#xff0c;不得违反当地国家的法律法规。对于传播、利用文章中提供的信息而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;本文作者不为此承担任何责任&#xff0c;一旦造成后果请自行承担…

2023年北京.NET线下技术沙龙圆满落幕!

5月20日&#xff0c;MASA技术团队在北京举办的“2023年北京.NET线下技术沙龙”圆满落幕&#xff01;整个活动气氛热烈&#xff0c;嘉宾们的分享内容丰富多彩&#xff0c;现场观众都受益匪浅。我们期待着更多这样的技术交流活动&#xff0c;让.NET社区不断发展和进步。 本次活动…

材料电磁参数综合测试解决方案 材料吸波、屏蔽性能测试系统 (10MHz~500GHz)

材料吸波、屏蔽性能测试系统测试频率范围可达10MHz&#xff5e;500GHz&#xff0c;可实现材料反射率、屏蔽性能特性参数测试。系统由矢量网络分析仪、测试夹具、系统软件等组成&#xff0c;根据用户不同频率、材料性能测试需求&#xff0c;可选用弓形框法、便携式反射率测试法进…