分享
  1. 首页
  2. 文章

第一个go-mysql-binlog解析

xingzhehxiang · · 4612 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

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)

}


}




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

本文来自:51CTO博客

感谢作者:xingzhehxiang

查看原文:第一个go-mysql-binlog解析

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
4612 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏