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)
}
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
大型分布式网站架构设计与实践
陈康贤 / 电子工业出版社 / 2014-9-1 / 79.00元
《大型分布式网站架构设计与实践》主要介绍了大型分布式网站架构所涉及的一些技术细节,包括SOA架构的实现、互联网安全架构、构建分布式网站所依赖的基础设施、系统稳定性保障和海量数据分析等内容;深入地讲述了大型分布式网站架构设计的核心原理,并通过一些架构设计的典型案例,帮助读者了解大型分布式网站设计的一些常见场景及遇到的问题。 作者结合自己在阿里巴巴及淘宝网的实际工作经历展开论述。《大型分布式网站......一起来看看 《大型分布式网站架构设计与实践》 这本书的介绍吧!