第一个go-mysql-binlog解析

栏目: 数据库 · 发布时间: 6年前

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)

}

}


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

百面机器学习

百面机器学习

诸葛越、葫芦娃 / 人民邮电出版社 / 2018-8-1 / 89.00元

人工智能领域正在以超乎人们想象的速度发展,本书赶在人工智能彻底占领世界之前完成编写,实属万幸。 书中收录了超过100道机器学习算法工程师的面试题目和解答,其中大部分源于Hulu算法研究岗位的真实场景。本书从日常工作、生活中各种有趣的现象出发,不仅囊括了机器学习的基本知识 ,而且还包含了成为出众算法工程师的相关技能,更重要的是凝聚了笔者对人工智能领域的一颗热忱之心,旨在培养读者发现问题、解决问......一起来看看 《百面机器学习》 这本书的介绍吧!

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具