cannal实战

参考:https://www.cnblogs.com/java-spring/p/8930740.html
https://www.cnblogs.com/houzs/p/10329384.html

在这里插入图片描述
启动:报错
在这里插入图片描述
解决:
在这里插入图片描述
在这里插入图片描述

成功:
在这里插入图片描述
cannal客户端代码:

package com.sdyy.biz;


import java.net.InetSocketAddress;
import java.util.List;

import com.alibaba.otter.canal.client.CanalConnector;
import com.alibaba.otter.canal.client.CanalConnectors;
import com.alibaba.otter.canal.protocol.CanalEntry.Column;
import com.alibaba.otter.canal.protocol.CanalEntry.Entry;
import com.alibaba.otter.canal.protocol.CanalEntry.EntryType;
import com.alibaba.otter.canal.protocol.CanalEntry.EventType;
import com.alibaba.otter.canal.protocol.CanalEntry.RowChange;
import com.alibaba.otter.canal.protocol.CanalEntry.RowData;
import com.alibaba.otter.canal.protocol.Message;


public class Cannal {



	    public static void main(String args[]) {
	        // 创建链接
	        CanalConnector connector = CanalConnectors.newSingleConnector(new InetSocketAddress("192.168.226.128", 11111),
	                "example", "", "");
	        int batchSize = 1000;
	        int emptyCount = 0;
	        try {
	            connector.connect();
	            connector.subscribe(".*\\..*");
	            connector.rollback();
	            int totalEmtryCount = 1200;
	            while (emptyCount < totalEmtryCount) {
	                Message message = connector.getWithoutAck(batchSize); // 获取指定数量的数据
	                long batchId = message.getId();
	                int size = message.getEntries().size();
	                if (batchId == -1 || size == 0) {
	                    emptyCount++;
//	                    System.out.println("empty count : " + emptyCount);
	                    try {
	                        Thread.sleep(1000);
	                    } catch (InterruptedException e) {
	                        e.printStackTrace();
	                    }
	                } else {
	                    emptyCount = 0;
	                    // System.out.printf("message[batchId=%s,size=%s] \n", batchId, size);
	                    printEntry(message.getEntries());
	                }

	                connector.ack(batchId); // 提交确认
	                // connector.rollback(batchId); // 处理失败, 回滚数据
	            }

	            System.out.println("empty too many times, exit");
	        } finally {
	            connector.disconnect();
	        }
	    }

	    private static void printEntry(List<Entry> entrys) {
	        for (Entry entry : entrys) {
	            if (entry.getEntryType() == EntryType.TRANSACTIONBEGIN
	                    || entry.getEntryType() == EntryType.TRANSACTIONEND) {
	                continue;
	            }

	            RowChange rowChage = null;
	            try {
	                rowChage = RowChange.parseFrom(entry.getStoreValue());
	            } catch (Exception e) {
	                throw new RuntimeException("ERROR ## parser of eromanga-event has an error , data:" + entry.toString(),
	                        e);
	            }

	            EventType eventType = rowChage.getEventType();
	            System.out.println(String.format("================> binlog[%s:%s] , name[%s,%s] , eventType : %s",
	                    entry.getHeader().getLogfileName(), entry.getHeader().getLogfileOffset(),
	                    entry.getHeader().getSchemaName(), entry.getHeader().getTableName(), eventType));

	            for (RowData rowData : rowChage.getRowDatasList()) {
	                if (eventType == EventType.DELETE) {
	                    printColumn(rowData.getBeforeColumnsList());
	                } else if (eventType == EventType.INSERT) {
	                    printColumn(rowData.getAfterColumnsList());
	                } else {
	                    System.out.println("-------> before");
	                    printColumn(rowData.getBeforeColumnsList());
	                    System.out.println("-------> after");
	                    printColumn(rowData.getAfterColumnsList());
	                }
	            }
	        }
	    }

	    private static void printColumn(List<Column> columns) {
	        for (Column column : columns) {
	            System.out.println(column.getName() + " : " + column.getValue() + "    update=" + column.getUpdated());
	        }
	    }

	

}

引入pom

<dependencies>
<dependency>
<groupId>com.alibaba.otter</groupId>
<artifactId>canal.client</artifactId>
<version>1.0.12</version>
</dependency>
</dependencies>

效果图:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值