阿里Canal部署及使用理解
[mysqld]
log-bin=mysql-bin #添加這一行就ok
binlog-format=ROW #選擇row模式
server_id=1 #配置mysql replaction需要定義,不能和canal的slaveId重複
2.對配置在canal的mysql用戶進行賦權操作(需要模擬slave):CREATE USER canal IDENTIFIED BY 'canal';
GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'canal'@'%';
-- GRANT ALL PRIVILEGES ON *.* TO 'canal'@'%' ;
FLUSH PRIVILEGES;
3.下載canal並進行解壓(當時操作的版本爲canal.deployer-1.0.25.tar.gz)vi conf/example/instance.properties
## mysql serverId
canal.instance.mysql.slaveId = 1234
position info,需要改成自己的數據庫信息
canal.instance.master.address = 127.0.0.1:3306
canal.instance.master.journal.name =
canal.instance.master.position =
canal.instance.master.timestamp =
#canal.instance.standby.address =
#canal.instance.standby.journal.name =
#canal.instance.standby.position =
#canal.instance.standby.timestamp =
username/password,需要改成自己的數據庫信息
canal.instance.dbUsername = canal
canal.instance.dbPassword = canal
canal.instance.defaultDatabaseName =
canal.instance.connectionCharset = UTF-8
#正則控制對那些數據庫的哪些表進行監控,.\..則是全庫全表
table regex
canal.instance.filter.regex = .\..
說明:
canal.instance.connectionCharset 代表數據庫的編碼方式對應到java中的編碼類型,比如UTF-8,GBK , ISO-8859-1
啓動服務。
sh bin/startup.sh使用樣例: