This repository was archived by the owner on Jan 7, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
120 lines (99 loc) · 2.8 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
package main
import (
"flag"
"fmt"
"os"
"os/signal"
"syscall"
"github.com/siddontang/go-mysql/canal"
"github.com/streadway/amqp"
"encoding/json"
)
var host = flag.String("host", "127.0.0.1", "MySQL host")
var port = flag.Int("port", 3306, "MySQL port")
var user = flag.String("user", "root", "MySQL user, must have replication privilege")
var password = flag.String("password", "", "MySQL password")
var flavor = flag.String("flavor", "mysql", "Flavor: mysql or mariadb")
var dataDir = flag.String("data-dir", "./var", "Path to store data, like master.info")
var serverID = flag.Int("server-id", 101, "Unique Server ID")
var mysqldump = flag.String("mysqldump", "", "mysqldump execution path")
var rabbitmq_host = flag.String("rabbitmq_host", "127.0.0.1", "RabbitMQ host")
var rabbitmq_port = flag.Int("rabbitmq_port", 5672, "RabbitMQ port")
var rabbitmq_user = flag.String("rabbitmq_user", "guest", "RabbitMQ user")
var rabbitmq_password = flag.String("rabbitmq_password", "guest", "RabbitMQ password")
var rabbitmq_exchange = flag.String("rabbitmq_exchange", "mysql", "RabbitMQ exchange name")
func main() {
flag.Parse()
cfg := canal.NewDefaultConfig()
cfg.Addr = fmt.Sprintf("%s:%d", *host, *port)
cfg.User = *user
cfg.Password = *password
cfg.Flavor = *flavor
cfg.DataDir = *dataDir
cfg.ServerID = uint32(*serverID)
cfg.Dump.ExecutionPath = *mysqldump
cfg.Dump.DiscardErr = false
c, err := canal.NewCanal(cfg)
if err != nil {
fmt.Printf("create canal err %v", err)
os.Exit(1)
}
url := fmt.Sprintf("amqp://%s:%s@%s:%d/", *rabbitmq_user, *rabbitmq_password, *rabbitmq_host, *rabbitmq_port)
conn, err := amqp.Dial(url)
failOnError(err, "Failed to connect to RabbitMQ")
defer conn.Close()
ch, err := conn.Channel()
failOnError(err, "Failed to open a channel")
defer ch.Close()
err = ch.ExchangeDeclare(
fmt.Sprintf("%s", *rabbitmq_exchange),
"topic",
true,
false,
false,
false,
nil,
)
failOnError(err, "Failed to declare an exchange")
c.RegRowsEventHandler(&handler{ch})
err = c.Start()
if err != nil {
fmt.Printf("start canal err %v", err)
os.Exit(1)
}
sc := make(chan os.Signal, 1)
signal.Notify(sc,
os.Kill,
os.Interrupt,
syscall.SIGHUP,
syscall.SIGINT,
syscall.SIGTERM,
syscall.SIGQUIT)
<-sc
c.Close()
}
type handler struct {
channel *amqp.Channel
}
func (h *handler) Do(e *canal.RowsEvent) error {
body, _ := json.Marshal(e)
key := e.Table.Schema + "." + e.Table.Name + "." + e.Action
return h.channel.Publish(
fmt.Sprintf("%s", *rabbitmq_exchange),
key,
false,
false,
amqp.Publishing{
ContentType: "application/json",
Body: body,
})
}
func (h *handler) String() string {
return "TestHandler"
}
func failOnError(err error, msg string) {
if err != nil {
//log.Fatalf("%s: %s", msg, err)
panic(fmt.Sprintf("%s: %s", msg, err))
}
}