OceanBase到MySQL实时同步方案

概述

本方案基于OceanBase Binlog服务,采用数据库实时复制软件Beedup订阅捕获OceanBase数据库的Binlog事件,复制软件将Binlog事件还原为MySQL支持的DML或DDL,然后交由MySQL数据库执行。

配置Binlog任务

启用OceanBase Binlog服务,涉及以下关键步骤。

1 安装obbinlog程序包。

sudo rpm --ivh ./obbinlog-ce-4.0.1-1.el7.x86_64.rpm

2 部署启动Binlog服务。

sudo sh env/deploy.sh -m deploy -f env/deploy.conf.json

3 登录Binlog服务,创建Binlog任务。

mysql -h192.168.113.144 -P2983

CREATE BINLOG INSTANCE binlog1 FOR TENANT `test`.`mq_t1`

TO USER `root` PASSWORD `*******`

WITH CLUSTER URL

`http://192.168.113.144:8080/services?Action=ObRootServiceInfo\&ObCluster=test\`

, REPLICATE NUM 1;

4 登录OceanBase数据库代理( OBProxy), 查看所有 Binlog 事件。

obclient -h192.168.113.144 -P2883 -uroot@mq_t1#test -A

SHOW BINLOG EVENTS ;

一旦通过OBProxy可以正常查看Binlog事件,表明Binlog任务运行正常,否则表明任务运行失败,需要仔细排查错误。

5 创建同步用户。

CREATE USER 'beedup'@'%' IDENTIFIED BY '********';

GRANT ALL PRIVILEGES ON *.* TO 'beedup'@'%';

配置复制任务

在数据库复制软件Beedup中创建复制任务。

1 主库连接设置如下。

其中端口指向OBProxy,用户名称包含连接的OceanBase租户及集群名称。

2 从库连接设置如下。

3 启动复制任务。

4 在OceanBase数据中执行建表及增删改操作,同时查看复制软件界面输出。

5 比较主库与从库表数据。

相关推荐
送秋三十五14 分钟前
5分钟读懂MySQL+Redis双写一致性实现流程
数据库·redis·mysql
bbmmqq18 分钟前
根据角色ID获取完整角色信息(异步)
数据库·spring·oracle
阿波罗尼亚19 分钟前
查询修正字段sql记录
数据库·sql·mysql
一个儒雅随和的男子21 分钟前
Redis性能调优指南
数据库·redis·spring
老华带你飞22 分钟前
动漫资讯|基于Springboot的动漫交流网站设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·国产动漫网站
JIngJaneIL26 分钟前
机器人信息|基于Springboot的机器人门户展示系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·机器人·论文·毕设·机器人门户展示系统
QQ12958455041 小时前
ThingsBoard部件数据结构解析
数据结构·数据库·物联网·iot
苦学编程的谢1 小时前
Redis_1_初识Redis+浅谈分布式系统
数据库·redis·缓存
Hello.Reader1 小时前
用 Flink CDC 将 MySQL 实时同步到 Doris
大数据·mysql·flink
人工智能教学实践1 小时前
Flask-SQLAlchemy 操作 SQLite 数据库示例
数据库·sqlite·flask