canal的使用
Posted shangyunlin
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了canal的使用相关的知识,希望对你有一定的参考价值。
- mysql开启binlog模式
- 查看mysql是否开启binlog模式
SHOW VARIABLES LIKE ‘%log_bin%‘ </DI< div>
- 修改/etc/my.cnf 需要开启binlog模式
[mysqld]
log-bin=mysql-bin
binlog-format=ROW
server_id=1 </DI< div>
- 修改完成之后,重启mysqld的服务。
- canal服务端安装配置
- 下载地址canal
- 下载好之后安装本地仓库,导入依赖
<dependency>
<groupId>com.xpand</groupId>
<artifactId>starter-canal</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
- canal使用
- 启动类添加
@EnableCanalClient
package com.changgou.canal.listener;
import com.alibaba.otter.canal.protocol.CanalEntry;
import com.changgou.canal.config.RabbitMQConfig;
import com.xpand.starter.canal.annotation.CanalEventListener;
import com.xpand.starter.canal.annotation.ListenPoint;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
@CanalEventListener //声明当前的类是canal的监听类
public class BusinessListener {
@Autowired
private RabbitTemplate rabbitTemplate;
/**
*
* @param eventType 当前操作数据库的类型
* @param rowData 当前操作数据库的数据
*/
@ListenPoint(schema = "changgou_business",table = "tb_ad")
public void adUpdate(CanalEntry.EventType eventType,CanalEntry.RowData rowData){
System.out.println("广告表数据发生改变");
//获取改变之前的数据
//rowData.getBeforeColumnsList().forEach((c)-> System.out.println("改变前的数据:"+c.getName()+"::"+c.getValue()));
//获取改变之后的数据
//rowData.getAfterColumnsList().forEach((c)-> System.out.println("改变之后的数据:"+c.getName()+"::"+c.getValue()));
for (CanalEntry.Column column : rowData.getAfterColumnsList()) {
if ("position".equals(column.getName())){
System.out.println("发送最新的数据到MQ:"+column.getValue());
//发送消息
rabbitTemplate.convertAndSend("", RabbitMQConfig.AD_UPDATE_QUEUE,column.getValue());
}
}
}
}
以上是关于canal的使用的主要内容,如果未能解决你的问题,请参考以下文章