使用 Docker 部署 canal 服务,实现 MySQL 数据库 binlog 日志解析

本文介绍了如何使用Docker部署Canal服务来实现MySQL数据库binlog日志的解析。通过创建测试表并进行增删改操作,展示了Canal客户端如何捕获并解析事件,包括数据库名、表名和变更内容。文中还提到了在部署过程中遇到的问题及其解决方案,并提供了日志验证方法。
摘要由CSDN通过智能技术生成

client.check_valid(username=b’‘, password=b’')

client.subscribe(client_id=b’1001’, destination=b’test’, filter=b’.\…')

while True:

message = client.get(100)

entries = message[‘entries’]

for entry in entries:

entry_type = entry.entryType

if entry_type in [EntryProtocol_pb2.EntryType.TRANSACTIONBEGIN, EntryProtocol_pb2.EntryType.TRANSACTIONEND]:

continue

row_change = EntryProtocol_pb2.RowChange()

row_change.MergeFromString(entry.storeValue)

event_type = row_change.eventType

header = entry.header

database = header.schemaName

table = header.tableName

event_type = header.eventType

for row in row_change.rowDatas:

format_data = dict()

if event_type == EntryProtocol_pb2.EventType.DELETE:

for column in row.beforeColumns:

format_data = {

column.name: column.value

}

elif event_type == EntryProtocol_pb2.EventType.INSERT:

for column in row.afterColumns:

format_data = {

column.name: column.value

}

else:

format_data[‘before’] = format_data[‘after’] = dict()

for column in row.beforeColumns:

format_data[‘before’][column.name] = column.value

for column in row.afterColumns:

format_data[‘after’][column.name] = column.value

data = dict(

db=database,

table=table,

event_type=event_type,

data=format_data,

)

print(data)

time.sleep(1)

client.disconne

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值