1
0
Fork 0
bocadillo/cmd/main.go

59 lines
1.3 KiB
Go
Raw Normal View History

2018-07-29 17:20:30 +00:00
package main
import (
"flag"
"fmt"
2018-11-11 13:24:45 +00:00
"log"
2018-07-29 17:20:30 +00:00
"os"
"time"
2018-11-06 22:17:48 +00:00
"github.com/localhots/bocadillo/reader"
2018-11-11 14:26:40 +00:00
"github.com/localhots/bocadillo/reader/slave"
2018-07-29 17:20:30 +00:00
)
func main() {
dsn := flag.String("dsn", "", "Database source name")
id := flag.Uint("id", 1000, "Server ID (arbitrary, unique)")
file := flag.String("file", "", "Binary log file name")
offset := flag.Uint("offset", 0, "Log offset in bytes")
flag.Parse()
validate((*dsn != ""), "Database source name is not set")
validate((*id != 0), "Server ID is not set")
validate((*file != ""), "Binary log file is not set")
2018-11-11 14:26:40 +00:00
reader, err := reader.New(*dsn, slave.Config{
2018-07-29 17:20:30 +00:00
ServerID: uint32(*id),
File: *file,
Offset: uint32(*offset),
2018-11-11 14:26:40 +00:00
})
if err != nil {
2018-11-11 13:24:45 +00:00
log.Fatalf("Failed to create reader: %v", err)
}
2018-11-08 23:20:12 +00:00
// for i := 0; i < 100; i++ {
for {
evt, err := reader.ReadEvent()
2018-07-29 17:20:30 +00:00
if err != nil {
2018-11-09 00:09:25 +00:00
log.Fatalf("Failed to read event: %v", err)
2018-07-29 17:20:30 +00:00
}
ts := time.Unix(int64(evt.Header.Timestamp), 0).Format(time.RFC3339)
2018-11-11 14:26:40 +00:00
log.Printf("Event received: %s %s, %d\n", evt.Header.Type.String(), ts, evt.Header.NextOffset)
if evt.Table != nil {
_, err := evt.DecodeRows()
if err != nil {
log.Fatalf("Failed to parse rows event: %v", err)
}
}
2018-07-29 17:20:30 +00:00
}
}
func validate(cond bool, msg string) {
if !cond {
fmt.Println(msg)
flag.Usage()
os.Exit(2)
}
}