zoukankan      html  css  js  c++  java
  • Canal介绍以及应用

    Canal介绍以及应用

    应用场景:

    canal [kə'næl],译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费

    早期阿里巴巴因为杭州和美国双机房部署,存在跨机房同步的业务需求,实现方式主要是基于业务 trigger 获取增量变更。从 2010 年开始,业务逐步尝试数据库日志解析获取增量变更进行同步,由此衍生出了大量的数据库增量订阅和消费业务。

    基于日志增量订阅和消费的业务包括

    • 数据库镜像
    • 数据库实时备份
    • 索引构建和实时维护(拆分异构索引、倒排索引等)
    • 业务 cache 刷新
    • 带业务逻辑的增量数据处理

    当前的 canal 支持源端 MySQL 版本包括 5.1.x , 5.5.x , 5.6.x , 5.7.x , 8.0.x

    工作原理:

    MySQL主备复制原理:

    • MySQL master 将数据变更写入二进制日志( binary log, 其中记录叫做二进制日志事件binary log events,可以通过 show binlog events 进行查看)
    • MySQL slave 将 master 的 binary log events 拷贝到它的中继日志(relay log)
    • MySQL slave 重放 relay log 中事件,将数据变更反映它自己的数据

    canal 工作原理:

    • canal 模拟 MySQL slave 的交互协议,伪装自己为 MySQL slave ,向 MySQL master 发送dump 协议
    • MySQL master 收到 dump 请求,开始推送 binary log 给 slave (即 canal )
    • canal 解析 binary log 对象(原始为 byte 流)

    Canal环境搭建:

    canal的原理是基于mysql binlog技术,所以这里一定需要开启mysql的binlog写入功能

    开启mysql服务: service mysql start (或者 systemctl start mysqld.service)

    1.检查binlog功能是否有开启

    mysql> show variables like 'log_bin';
    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | log_bin       | OFF    |
    +---------------+-------+
    1 row in set (0.00 sec)
    

    2.如果显示状态为OFF表示该功能未开启,开启binlog功能

    1,修改 mysql 的配置文件 my.cnf
    vi /etc/my.cnf
    追加内容:
    log-bin=mysql-bin #binlog文件名
    binlog_format=ROW #选择row模式
    server_id=1 #mysql实例id,不能和canal的slaveId重复

    2,重启 mysql:
    service mysql restart

    3,登录 mysql 客户端,查看 log_bin 变量
    mysql> show variables like 'log_bin';
    +---------------+-------+

    Variable_name Value

    +---------------+-------+

    log_bin ON

    +---------------+-------+
    1 row in set (0.00 sec)
    ————————————————
    如果显示状态为ON表示该功能已开启

    3.在mysql里面添加以下的相关用户和权限

    CREATE USER 'canal'@'%' IDENTIFIED BY 'canal';
    GRANT SHOW VIEW, SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'canal'@'%';
    FLUSH PRIVILEGES;
    

    下载安装Canal服务

    下载地址:

    https://github.com/alibaba/canal/releases

    下载之后,放到目录中,解压文件**

    cd `/usr/local/canal`
    
    tar zxvf canal.deployer-1.1.4.tar.gz
    

    修改配置文件

    vi conf/example/instance.properties
    
    #需要改成自己的数据库信息
    canal.instance.master.address=192.168.44.132:3306
    
    #需要改成自己的数据库用户名与密码
    
    canal.instance.dbUsername=canal
    canal.instance.dbPassword=canal
    
    #需要改成同步的数据库表规则,例如只是同步一下表
    #canal.instance.filter.regex=.*\..*
    canal.instance.filter.regex=guli_ucenter.ucenter_member
    

    进入bin目录下启动

    sh bin/startup.sh
    
  • 相关阅读:
    计算机操作系统 存储器管理
    数据结构 平衡二叉树avl c++
    数据结构 线索二叉树 c++
    数据结构 赫夫曼树及其应用 c++
    c++ cstring 常用函数
    数据结构 哈希表 c++
    数据结构 静态链表
    ajax返回填充的数据不显示
    使用JSON.parse()转化成json对象需要注意的地方
    参数错误导致bug
  • 原文地址:https://www.cnblogs.com/Courage129/p/14054832.html
Copyright © 2011-2022 走看看