springboot整合easy-es和canbal、kafka实现mysql数据同步,支持数据全量和增量同步

时间: 2023-07-15 16:13:13 浏览: 83
Spring Boot 整合 Easy-ES、Canal 和 Kafka 可以实现 MySQL 数据的全量和增量同步。下面简单介绍一下具体步骤: 1. 集成 Easy-ES (1)在 pom.xml 中添加 Easy-ES 依赖: ``` <dependency> <groupId>com.alibaba</groupId> <artifactId>easy-es-spring-boot-starter</artifactId> <version>2.3.0</version> </dependency> ``` (2)在 application.yml 中配置 Easy-ES: ``` spring: elasticsearch: rest: uris: http://127.0.0.1:9200 easy-es: enabled: true index-prefix: my_index refresh-interval: 5s ``` 2. 集成 Canal (1)在 pom.xml 中添加 Canal 依赖: ``` <dependency> <groupId>com.alibaba.otter</groupId> <artifactId>canal.client</artifactId> <version>1.1.4</version> </dependency> ``` (2)在 application.yml 中配置 Canal: ``` canal: client: # canal server的ip地址和端口号 servers: 127.0.0.1:11111 # 监听的实例名称,多个实例用逗号分隔 instance: my_instance # 连接 Canal server 的用户名和密码 username: password: destination: # 数据源名称 schema: my_db # 数据库连接信息 url: jdbc:mysql://127.0.0.1:3306/my_db?serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=utf-8 username: root password: root filter: # 监听表的正则表达式,多个表用逗号分隔 include: .*\\..* ``` 3. 集成 Kafka (1)在 pom.xml 中添加 Kafka 依赖: ``` <dependency> <groupId>org.springframework.kafka</groupId> <artifactId>spring-kafka</artifactId> <version>2.5.4.RELEASE</version> </dependency> ``` (2)在 application.yml 中配置 Kafka: ``` spring: kafka: bootstrap-servers: 127.0.0.1:9092 producer: retries: 0 consumer: group-id: my_group_id auto-offset-reset: earliest properties: max.poll.interval.ms: 600000 ``` 4. 实现数据同步 (1)全量同步 全量同步可以通过 Easy-ES 的 `com.alibaba.easysearch.indexbuilder.IndexBuilderFactory` 类来实现。在应用启动时,通过监听 `ApplicationReadyEvent` 事件,获取 MySQL 数据并调用 `com.alibaba.easysearch.indexbuilder.IndexBuilderFactory.buildFullIndex()` 方法来创建索引,具体代码如下: ``` @Component public class FullIndexBuilder implements ApplicationListener<ApplicationReadyEvent> { @Autowired private IndexBuilderFactory indexBuilderFactory; @Override public void onApplicationEvent(ApplicationReadyEvent applicationReadyEvent) { // 获取 MySQL 数据并创建索引 indexBuilderFactory.buildFullIndex(); } } ``` (2)增量同步 增量同步可以通过 Canal 和 Kafka 实现。Canal 监听 MySQL 数据库变化,将变化信息发送到 Kafka 中,然后在消费者中获取变化信息并更新索引。 首先创建一个 Canal 客户端: ``` @Component public class CanalClient { private static final Logger logger = LoggerFactory.getLogger(CanalClient.class); @Autowired private KafkaTemplate<String, String> kafkaTemplate; @Value("${canal.client.servers}") private String servers; @Value("${canal.client.instance}") private String instance; @PostConstruct public void init() { CanalConnector connector = CanalConnectors.newClusterConnector(servers, instance, "", ""); int batchSize = 1000; try { connector.connect(); connector.subscribe(".*\\..*"); connector.rollback(); while (true) { Message message = connector.getWithoutAck(batchSize); long batchId = message.getId(); if (batchId == -1 || message.getEntries().isEmpty()) { continue; } List<String> messages = new ArrayList<>(); for (CanalEntry.Entry entry : message.getEntries()) { if (entry.getEntryType() == CanalEntry.EntryType.ROWDATA) { RowChange rowChange; try { rowChange = RowChange.parseFrom(entry.getStoreValue()); } catch (Exception e) { throw new RuntimeException("ERROR ## parser of eromanga-event has an error , data:" + entry.toString(), e); } String tableName = entry.getHeader().getTableName(); EventType eventType = rowChange.getEventType(); for (CanalEntry.RowData rowData : rowChange.getRowDatasList()) { String messageJson = JSON.toJSONString(rowData.getAfterColumnsList() .stream() .collect(Collectors.toMap(CanalEntry.Column::getName, CanalEntry.Column::getValue))); messages.add(tableName + "|" + eventType + "|" + messageJson); } } } if (!messages.isEmpty()) { kafkaTemplate.send("my_topic", StringUtils.join(messages, "\n")); } connector.ack(batchId); } } catch (Exception e) { logger.error("CanalClient error", e); } finally { connector.disconnect(); } } } ``` 然后创建一个 Kafka 消费者,获取变化信息并更新索引: ``` @Component public class IncrementIndexBuilder { private static final Logger logger = LoggerFactory.getLogger(IncrementIndexBuilder.class); @Autowired private IndexBuilderFactory indexBuilderFactory; @KafkaListener(topics = "my_topic") public void listen(ConsumerRecord<String, String> record) { String[] fields = StringUtils.split(record.value(), "|"); String tableName = fields[0]; String eventType = fields[1]; String messageJson = fields[2]; try { Map<String, Object> message = JSON.parseObject(messageJson, new TypeReference<Map<String, Object>>() {}); if ("INSERT".equals(eventType)) { indexBuilderFactory.buildIndex(tableName, message); } else if ("UPDATE".equals(eventType)) { indexBuilderFactory.updateIndex(tableName, message); } else if ("DELETE".equals(eventType)) { indexBuilderFactory.deleteIndex(tableName, message); } } catch (Exception e) { logger.error("IncrementIndexBuilder error", e); } } } ``` 到此为止,我们就实现了 Spring Boot 整合 Easy-ES、Canal 和 Kafka 实现 MySQL 数据的全量和增量同步。

相关推荐

最新推荐

recommend-type

OGG实现ORACLE数据到大数据平台KFAKF的实时同步到KUDU数据库

该文档是根据真实项目,搭建的一套OGG实时同步oracle数据到kafka集群,文档主要介绍OGG的安装和进程配置。文档最后附带整个数据处理的流程图。
recommend-type

python3实现从kafka获取数据,并解析为json格式,写入到mysql中

今天小编就为大家分享一篇python3实现从kafka获取数据,并解析为json格式,写入到mysql中,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

kafka-python批量发送数据的实例

今天小编就为大家分享一篇kafka-python批量发送数据的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

Java实现批量向mysql写入数据的方法

主要介绍了Java实现批量向mysql写入数据的方法,涉及java基于JDBC连接mysql数据库及写入数据的相关操作技巧,非常简单实用,需要的朋友可以参考下
recommend-type

Spring Boot集群管理工具KafkaAdminClient使用方法解析

主要介绍了Spring Boot集群管理工具KafkaAdminClient使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章

![:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章](https://img-blog.csdnimg.cn/img_convert/69b98e1a619b1bb3c59cf98f4e397cd2.png) # 1. 目标检测算法概述 目标检测算法是一种计算机视觉技术,用于识别和定位图像或视频中的对象。它在各种应用中至关重要,例如自动驾驶、视频监控和医疗诊断。 目标检测算法通常分为两类:两阶段算法和单阶段算法。两阶段算法,如 R-CNN 和 Fast R-CNN,首先生成候选区域,然后对每个区域进行分类和边界框回归。单阶段算法,如 YOLO 和 SSD,一次性执行检
recommend-type

info-center source defatult

这是一个 Cisco IOS 命令,用于配置 Info Center 默认源。Info Center 是 Cisco 设备的日志记录和报告工具,可以用于收集和查看设备的事件、警报和错误信息。该命令用于配置 Info Center 默认源,即设备的默认日志记录和报告服务器。在命令行界面中输入该命令后,可以使用其他命令来配置默认源的 IP 地址、端口号和协议等参数。
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。