linux 安装 canal 的详细步骤

Canal 是阿里巴巴开源的 MySQL 数据库 binlog 的增量订阅&消费组件,在 Linux 系统上安装 Canal 的步骤如下:

一、环境准备

  1. JDK 安装

    Canal 依赖 Java 环境,需安装 JDK 8 及以上版本:

    bash 复制代码
    # 以 OpenJDK 为例
    sudo apt update  # Ubuntu/Debian
    sudo apt install openjdk-11-jdk
    
    # 或 CentOS/RHEL
    sudo yum install java-11-openjdk-devel
    
    # 验证安装
    java -version
  2. 配置 MySQL

    修改 MySQL 配置文件(通常是 /etc/mysql/my.cnf/etc/my.cnf):

    ini 复制代码
    [mysqld]
    log-bin=mysql-bin       # 开启 binlog
    binlog-format=ROW       # binlog 格式,必须为 ROW
    server-id=1             # MySQL 实例唯一 ID

    重启 MySQL 并创建 Canal 专用账号:

    sql 复制代码
    CREATE USER 'canal'@'%' IDENTIFIED BY 'canal';
    GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'canal'@'%';
    FLUSH PRIVILEGES;

二、下载并安装 Canal

  1. 下载 Canal 发行包

    Canal GitHub 仓库 下载最新稳定版(例如 canal.deployer-1.1.5.tar.gz):

    bash 复制代码
    wget https://github.com/alibaba/canal/releases/download/canal-1.1.5/canal.deployer-1.1.5.tar.gz
    tar -zxvf canal.deployer-1.1.5.tar.gz -C /opt/canal/
  2. 配置 Canal 实例

    进入 conf 目录,复制示例配置并编辑:

    bash 复制代码
    cd /opt/canal/conf/
    cp example instance_name  # instance_name 为自定义实例名,如 mysql_test
    cd instance_name
    vi instance.properties

    修改以下配置项:

    properties 复制代码
    canal.instance.master.address=127.0.0.1:3306  # MySQL 地址和端口
    canal.instance.dbUsername=canal                # MySQL 用户名
    canal.instance.dbPassword=canal                # MySQL 密码
    canal.instance.defaultDatabaseName=            # 监控的数据库,留空则监控所有
    canal.instance.connectionCharset=UTF-8        # 字符集
    canal.instance.filter.regex=.*\\..*            # 表过滤规则,例如 test\\..* 表示 test 库下的所有表

三、启动 Canal

  1. 启动脚本

    使用内置脚本启动 Canal 服务:

    bash 复制代码
    cd /opt/canal/bin
    ./startup.sh [instance_name]  # 可选实例名,不指定则启动所有实例
  2. 查看日志

    检查服务是否正常启动:

    bash 复制代码
    # 查看主服务日志
    cat /opt/canal/logs/canal/canal.log
    
    # 查看实例日志
    cat /opt/canal/logs/instance_name/instance.log

    若看到 start successful 则表示启动成功。

四、验证安装

  1. 客户端测试

    使用 Canal 自带的客户端工具测试连接:

    bash 复制代码
    cd /opt/canal/bin
    ./canal_client.sh

    在客户端中输入 show info 查看状态。

  2. 编程验证

    通过代码连接 Canal Server,消费 binlog 数据(以 Java 为例):

    java 复制代码
    // 添加依赖(Maven)
    <dependency>
        <groupId>com.alibaba.otter</groupId>
        <artifactId>canal.client</artifactId>
        <version>1.1.5</version>
    </dependency>
    
    // 代码示例
    CanalConnector connector = CanalConnectors.newSingleConnector(
        new InetSocketAddress("127.0.0.1", 11111),
        "instance_name", "", "");
    connector.connect();
    connector.subscribe(".*\\..*");
    
    while (true) {
        Message message = connector.get(100);
        List<CanalEntry.Entry> entries = message.getEntries();
        // 处理 entries...
    }

五、停止服务

bash 复制代码
cd /opt/canal/bin
./stop.sh [instance_name]  # 可选实例名,不指定则停止所有

常见问题

  1. 连接失败

    检查 MySQL 配置、用户权限及网络连通性。

  2. 权限不足

    确保 Canal 账号拥有 REPLICATION SLAVEREPLICATION CLIENT 权限。

  3. 内存溢出

    编辑 bin/startup.sh,调整 JVM 内存参数(如 JAVA_OPTS="-Xms256m -Xmx512m")。

通过以上步骤,你可以在 Linux 系统上成功安装并配置 Canal,实现 MySQL binlog 的增量订阅与消费。

相关推荐
阿华hhh12 分钟前
项目(购物商城)
linux·服务器·c语言·c++
摸鱼仙人~19 分钟前
大模型文章生成的风格个性化与多文体写作:一套可落地的方法论
linux·运维·服务器
xybDIY22 分钟前
亚马逊云 Organizations 组织 Link 账号关联与解绑自动化解决方案
运维·自动化·云计算·aws
煤球王子24 分钟前
浅学文件系统4(页面缓存)
linux
peixiuhui27 分钟前
Iotgateway技术手册-1. 项目概述
linux·网关·iot·modbus·数据采集网关·iotgateway·采集软件
wdfk_prog29 分钟前
[Linux]学习笔记系列 -- [fs]sysfs
linux·笔记·学习
慕容雪_30 分钟前
运维笔记-网络【属性】-【共享】中没有【家庭网络连接(H)】的选项
运维·网络·共享
AllFiles39 分钟前
Linux 网络故障排查:如何诊断与解决 ARP 缓存溢出问题
linux·后端
爬山算法1 小时前
Hibernate(30)Hibernate的Named Query是什么?
服务器·前端·hibernate
AC赳赳老秦1 小时前
Shell 脚本批量生成:DeepSeek 辅助编写服务器运维自动化指令
运维·服务器·前端·vue.js·数据分析·自动化·deepseek