news 2026/6/10 0:26:03

【canal】canal同步msyql到redis

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【canal】canal同步msyql到redis

java层面 canal client配置pom文件

<dependency> <groupId>com.google.code.gson</groupId> <artifactId>gson</artifactId> <version>2.13.2</version> </dependency> <dependency> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>33.5.0-jre</version> </dependency> <dependency> <groupId>com.alibaba.otter</groupId> <artifactId>canal.client</artifactId> <version>1.1.7</version> <!-- 使用最新版本 --> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.47</version> </dependency> <!-- Redisson --> <dependency> <groupId>org.redisson</groupId> <artifactId>redisson</artifactId> <version>3.23.5</version> </dependency> <dependency> <groupId>com.alibaba.otter</groupId> <artifactId>canal.protocol</artifactId> <version>1.1.7</version> </dependency>

java client

1.将接收到的canal数据2进制转为10进制数据

2.redis client需要2进制转10进制,否则key是10进制,内部还是2进制

package org.example.cannal.redis; import com.alibaba.otter.canal.client.CanalConnectors; import com.alibaba.otter.canal.client.CanalConnector; import com.alibaba.otter.canal.protocol.Message; import com.alibaba.otter.canal.protocol.CanalEntry.*; import org.redisson.api.RMap; import org.redisson.api.RedissonClient; import org.redisson.config.Config; import java.net.InetSocketAddress; import java.util.HashMap; import java.util.List; import java.util.Map; public class CanalBinaryParseWithRedisson { public static void main(String[] args) { // 1. 创建 Canal 连接 CanalConnector connector = CanalConnectors.newSingleConnector( new InetSocketAddress("127.0.0.1", 11111), "example", "", "" ); // 2. 创建 Redisson 客户端 RedissonClient redisson = createRedissonClient(); try { connector.connect(); connector.subscribe(".*\\..*"); connector.rollback(); while (true) { Message message = connector.getWithoutAck(100); // 每次取100条 long batchId = message.getId(); int size = message.getEntries().size(); if (batchId == -1 || size == 0) { try { Thread.sleep(1000); } catch (InterruptedException ignored) {} } else { handleEntries(message.getEntries(), redisson); connector.ack(batchId); // 确认消费 } } } finally { connector.disconnect(); redisson.shutdown(); } } private static void handleEntries(List<Entry> entrys, RedissonClient redisson) { for (Entry entry : entrys) { if (entry.getEntryType() == EntryType.TRANSACTIONBEGIN || entry.getEntryType() == EntryType.TRANSACTIONEND) { continue; } RowChange rowChange; try { // 关键:把二进制解析成 RowChange rowChange = RowChange.parseFrom(entry.getStoreValue()); } catch (Exception e) { throw new RuntimeException("解析 RowChange 失败", e); } EventType eventType = rowChange.getEventType(); String tableName = entry.getHeader().getTableName(); for (RowData rowData : rowChange.getRowDatasList()) { if (eventType == EventType.INSERT || eventType == EventType.UPDATE) { Map<String, String> dataMap = new HashMap<>(); String id = null; for (Column column : rowData.getAfterColumnsList()) { dataMap.put(column.getName(), column.getValue()); if ("id".equals(column.getName())) { id = column.getValue(); } } // 用 Redisson 写入 Redis Hash RMap<String, String> map = redisson.getMap(tableName + ":" + id); map.putAll(dataMap); System.out.println("写入 Redis: " + tableName + ":" + id + " -> " + dataMap); } else if (eventType == EventType.DELETE) { String id = null; for (Column column : rowData.getBeforeColumnsList()) { if ("id".equals(column.getName())) { id = column.getValue(); break; } } // 删除 Redis Key redisson.getMap(tableName + ":" + id).delete(); System.out.println("删除 Redis: " + tableName + ":" + id); } } } } private static RedissonClient createRedissonClient() { Config config = new Config(); // 1. 配置Redis连接(单节点为例) config.useSingleServer() .setAddress("redis://127.0.0.1:6379") // .setPassword("你的密码") // 无密码则省略 .setDatabase(1); // 2. 关键:设置序列化器为StringCodec(明文字符串序列化) config.setCodec(new org.redisson.client.codec.StringCodec()); return org.redisson.Redisson.create(config); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 19:41:12

YuukiPS Launcher游戏启动器终极使用指南:一键畅玩动漫游戏

YuukiPS Launcher游戏启动器终极使用指南&#xff1a;一键畅玩动漫游戏 【免费下载链接】Launcher-PC 项目地址: https://gitcode.com/gh_mirrors/la/Launcher-PC 还在为管理多个游戏账号而烦恼吗&#xff1f;YuukiPS Launcher就是你的救星&#xff01;这款开源启动工具…

作者头像 李华
网站建设 2026/6/9 20:59:52

WorkshopDL终极指南:突破Steam创意工坊限制的完美解决方案

还在为无法访问Steam创意工坊的海量模组资源而烦恼吗&#xff1f;WorkshopDL作为功能强大的Steam创意工坊下载工具&#xff0c;让跨平台模组获取变得前所未有的简单。无论你在GOG、Epic Games Store还是其他平台购买游戏&#xff0c;现在都能轻松突破平台限制&#xff0c;畅享无…

作者头像 李华
网站建设 2026/6/9 18:33:24

Windows Defender 完全移除与系统安全组件管理指南

Windows Defender 完全移除与系统安全组件管理指南 【免费下载链接】windows-defender-remover A tool which is uses to remove Windows Defender in Windows 8.x, Windows 10 (every version) and Windows 11. 项目地址: https://gitcode.com/gh_mirrors/wi/windows-defend…

作者头像 李华
网站建设 2026/6/9 18:33:07

Qwen3-VL识别微PE官网界面元素?实际测试结果曝光

Qwen3-VL识别微PE官网界面元素&#xff1f;实际测试结果曝光 在智能系统日益追求“自主操作”的今天&#xff0c;一个核心问题摆在我们面前&#xff1a;AI能否真正像人类一样“看懂”电脑屏幕&#xff0c;并据此做出合理决策&#xff1f;尤其是在面对真实网页界面时——那些字体…

作者头像 李华
网站建设 2026/6/9 19:43:26

Qwen3-VL去中心化身份:个人图像作为DID凭证解析

Qwen3-VL赋能去中心化身份&#xff1a;以个人图像为凭证的可信验证新范式 在数字身份日益成为网络空间“通行证”的今天&#xff0c;我们正面临一个根本性矛盾&#xff1a;身份越重要&#xff0c;就越需要强验证&#xff1b;但验证越集中&#xff0c;隐私风险就越高。传统系统依…

作者头像 李华
网站建设 2026/6/9 20:58:25

Beyond Compare 5密钥生成实战:从原理到应用的完整指南

Beyond Compare 5密钥生成实战&#xff1a;从原理到应用的完整指南 【免费下载链接】BCompare_Keygen Keygen for BCompare 5 项目地址: https://gitcode.com/gh_mirrors/bc/BCompare_Keygen 在软件开发和日常工作中&#xff0c;文件比较工具Beyond Compare因其强大的功…

作者头像 李华