欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Canal監(jiān)聽(tīng)MySQL的實(shí)現(xiàn)步驟

 更新時(shí)間:2022年08月11日 15:16:17   作者:CODING一場(chǎng)空  
本文主要介紹了Canal監(jiān)聽(tīng)MySQL的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

1、Mysql數(shù)據(jù)庫(kù)開(kāi)啟binlog模式

注意:Mysql容器,此處Mysql版本為5.7

#進(jìn)入容器
docker exec -it mysql /bin/bash
#進(jìn)入配置目錄
cd /etc/mysql/mysql.conf.d
#修改配置文件
vi mysqld.cnf

(1) 修改mysqld.cnf配置文件,添加如下配置:

log-bin=mysql-bin
server-id=12345

(2) 創(chuàng)建賬號(hào) 用于測(cè)試使用,使用root賬號(hào)創(chuàng)建用戶(hù)并授予權(quán)限

create user canal@'%' IDENTIFIED by 'canal';

GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT,SUPER ON *.* TO 'canal'@'%';

FLUSH PRIVILEGES;

(3) 重啟mysql容器

docker restart mysql

2、Docker下Canal容器安裝

(1)拉取canal鏡像

docker pull docker.io/canal/canal-server

(2)創(chuàng)建Canal容器

docker run -p 11111:11111 --name canal -d docker.io/canal/canal-server

(3)進(jìn)入容器,修改核心配置canal.properties 和instance.properties,canal.properties 是canal自身的配置,instance.properties是需要同步數(shù)據(jù)的數(shù)據(jù)庫(kù)連接配置。

#進(jìn)入容器
docker exec -it canal /bin/bash
cd canal-server/conf/
#修改 canal.properties
vi canal.properties
cd example/
#修改 instance.properties
vi instance.properties

修改canal.properties的id,不能和mysql的server-id重復(fù),如下圖:

修改instance.properties,配置數(shù)據(jù)庫(kù)連接地址:

這里的canal.instance.filter.regex有多種配置,如下:

可以參考地址如下: https://github.com/alibaba/canal/wiki/AdminGuide

mysql 數(shù)據(jù)解析關(guān)注的表,Perl正則表達(dá)式.

多個(gè)正則之間以逗號(hào)(,)分隔,轉(zhuǎn)義符需要雙斜杠(\\) 

常見(jiàn)例子:

1.  所有表:.*   or  .*\\..*
2.  canal schema下所有表: canal\\..*
3.  canal下的以canal打頭的表:canal\\.canal.*
4.  canal schema下的一張表:canal.test1
5.  多個(gè)規(guī)則組合使用:canal\\..*,mysql.test1,mysql.test2 (逗號(hào)分隔)
注意:此過(guò)濾條件只針對(duì)row模式的數(shù)據(jù)有效(ps. mixed/statement因?yàn)椴唤馕鰏ql,所以無(wú)法準(zhǔn)確提取tableName進(jìn)行過(guò)濾)

配置完成后,設(shè)置開(kāi)機(jī)啟動(dòng),并記得重啟canal。

docker update --restart=always canal
docker restart canal

3、Canal Client項(xiàng)目搭建

(1)引入依賴(lài)

   <parent>
        <artifactId>spring-boot-parent</artifactId>
        <groupId>org.springframework.boot</groupId>
        <version>2.1.4.RELEASE</version>
    </parent>

    <dependencies>
  	<!--canal依賴(lài)-->
        <dependency>
            <groupId>com.xpand</groupId>
            <artifactId>starter-canal</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>
    </dependencies>

注意:canal依賴(lài)stater在中央倉(cāng)庫(kù)是不存在的,需要手動(dòng)放進(jìn)本地倉(cāng)庫(kù)或者你公司里面的nexus

這里以放進(jìn)本地倉(cāng)庫(kù)為例:

  • 首先解壓spring-boot-starter-canal-master.zip
  • 在spring-boot-starter-canal-master\starter-canal文件夾下執(zhí)行mvn clean install
  • 此時(shí)在本地倉(cāng)庫(kù)就會(huì)存在jar包
  • 引入依賴(lài)
 	<!--canal依賴(lài)-->
        <dependency>
            <groupId>com.xpand</groupId>
            <artifactId>starter-canal</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>

(2)啟動(dòng)類(lèi)編寫(xiě)

@SpringBootApplication
@EnableCanalClient
public class CanalApplication {
    public static void main(String[] args) {
        SpringApplication.run(CanalApplication.class,args);
    }
}

(3)監(jiān)聽(tīng)器編寫(xiě)

@CanalEventListener
public class CanalDataEventListener {

    /***
     * 增加數(shù)據(jù)監(jiān)聽(tīng)
     * @param eventType
     * @param rowData
     */
    @InsertListenPoint
    public void onEventInsert(CanalEntry.EventType eventType, CanalEntry.RowData rowData) {
        rowData.getAfterColumnsList().forEach((c) -> System.out.println("By--Annotation: " + c.getName() + " ::   " + c.getValue()));
    }

    /***
     * 修改數(shù)據(jù)監(jiān)聽(tīng)
     * @param rowData
     */
    @UpdateListenPoint
    public void onEventUpdate(CanalEntry.RowData rowData) {
        System.out.println("UpdateListenPoint");
        rowData.getAfterColumnsList().forEach((c) -> System.out.println("By--Annotation: " + c.getName() + " ::   " + c.getValue()));
    }

    /***
     * 刪除數(shù)據(jù)監(jiān)聽(tīng)
     * @param eventType
     */
    @DeleteListenPoint
    public void onEventDelete(CanalEntry.EventType eventType) {
        System.out.println("DeleteListenPoint");
    }

    /***
     * 自定義數(shù)據(jù)修改監(jiān)聽(tīng)
     * @param eventType
     * @param rowData
     */
    @ListenPoint(destination = "example", schema = "torlesse_test", table = {"tb_user", "tb_order"}, eventType = CanalEntry.EventType.UPDATE)
    public void onEventCustomUpdate(CanalEntry.EventType eventType, CanalEntry.RowData rowData) {
        System.err.println("DeleteListenPoint");
        rowData.getAfterColumnsList().forEach((c) -> System.out.println("By--Annotation: " + c.getName() + " ::   " + c.getValue()));
    }


    @ListenPoint(destination = "example",
            schema = "test_canal", //所要監(jiān)聽(tīng)的數(shù)據(jù)庫(kù)名
            table = {"tb_user"}, //所要監(jiān)聽(tīng)的數(shù)據(jù)庫(kù)表名
            eventType = {CanalEntry.EventType.UPDATE, CanalEntry.EventType.INSERT, CanalEntry.EventType.DELETE})
    public void onEventCustomUpdateForTbUser(CanalEntry.EventType eventType, CanalEntry.RowData rowData){
        getChangeValue(eventType,rowData);
    }

    public static void getChangeValue(CanalEntry.EventType eventType, CanalEntry.RowData rowData){
        if(eventType == CanalEntry.EventType.DELETE){
            rowData.getBeforeColumnsList().forEach(column -> {
                //獲取刪除前的數(shù)據(jù)
                System.out.println(column.getName() + " == " + column.getValue());
            });
        }else {
            rowData.getBeforeColumnsList().forEach(column -> {
                //打印改變前的字段名和值
                System.out.println(column.getName() + " == " + column.getValue());
            });

            rowData.getAfterColumnsList().forEach(column -> {
                //打印改變后的字段名和值
                System.out.println(column.getName() + " == " + column.getValue());
            });
        }
    }
}

到此就可以實(shí)現(xiàn)Canal監(jiān)聽(tīng)Mysql

項(xiàng)目gitee地址:test-canal

詳情可以查看:

https://github.com/alibaba/canal (阿里官方)

https://github.com/alibaba/canal/wiki/AdminGuide (阿里官方)

https://github.com/chenqian56131/spring-boot-starter-canal (自制starter)

到此這篇關(guān)于Canal監(jiān)聽(tīng)MySQL的實(shí)現(xiàn)步驟的文章就介紹到這了,更多相關(guān)Canal監(jiān)聽(tīng)MySQL內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論