go解析mysql binlog_第一个go-mysql-binlog解析

1、这是我第一个二进制日志解析的例子,对官方给出的demo做出相应调整,使其能够运行

package main

import (

"context"

"os"

"time"

"github.com/siddontang/go-mysql/mysql"

"github.com/siddontang/go-mysql/replication"

)

// Create a binlog syncer with a unique server id, the server id must be different from other MySQL's.

// flavor is mysql or mariadb

func main() {

cfg := replication.BinlogSyncerConfig{

ServerID: 100,

Flavor:   "mysql",

Host:     "127.0.0.1",

Port:     3306,

User:     "root",

Password: "123456",

}

syncer := replication.NewBinlogSyncer(cfg)

// Start sync with specified binlog file and position

streamer, _ := syncer.StartSync(mysql.Position{"mysql.000001", 405322})

// or you can start a gtid replication like

// streamer, _ := syncer.StartSyncGTID(gtidSet)

// the mysql GTID set likes this "de278ad0-2106-11e4-9f8e-6edd0ca20947:1-2"

// the mariadb GTID set likes this "0-1-100"

for {

ev, _ := streamer.GetEvent(context.Background())

// Dump event

ev.Dump(os.Stdout)

}

// or we can use a timeout context

for {

ctx, cancel := context.WithTimeout(context.Background(), 2*time.Second)

ev, err := streamer.GetEvent(ctx)

cancel()

if err == context.DeadlineExceeded {

// meet timeout

continue

}

ev.Dump(os.Stdout)

}

}

有疑问加站长微信联系(非本文作者)

5c5fbae790ec0313d6ee17e8b3dd9ba1.png

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值