百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

用DataX实现两个MySQL实例间的数据同步

liuian 2025-06-23 20:38 2 浏览

DataX

DataX使用Java实现。

如果可以实现数据库实例之间准实时的#数据同步#,可以解决很多问题。例如数据可靠性和高并发的问题。Oracle Golden Gate是Oracle提供的一个商业解决方案,而开源的也有很多,这里介绍的#datax#就是一种。下面是DataX的设计原理图





环境

两个数据库实例,都是MySQL,一个位于生产环境,一个位于测试环境。想将指定数据库的指定表数据,从生产环境同步到测试环境对应表中。

步骤

  1. 安装JDK 1.8
sudo apt update
sudo apt install openjdk-8-jdk -y
......
gauss@power-edge-r730:~$ java -version
openjdk version "1.8.0_452"
OpenJDK Runtime Environment (build 1.8.0_452-8u452-ga~us1-0ubuntu1~24.04-b09)
OpenJDK 64-Bit Server VM (build 25.452-b09, mixed mode)
gauss@power-edge-r730:~$ javac -version
javac 1.8.0_452
  1. 下载DataX
$ wget https://github.com/alibaba/DataX/releases/download/datax_0.0.1/datax.tar.gz
# 可从国内下载 : https://datax-opensource.oss-cn-hangzhou.aliyuncs.com/202308/datax.tar.gz
$ tar -zxvf datax.tar.gz
$ mv datax ~/soft/
$ cd ~/soft/datax/
$ python3 bin/datax.py --help

DataX (DATAX-OPENSOURCE-3.0), From Alibaba !
Copyright (C) 2010-2017, Alibaba Group. All Rights Reserved.
  1. 编写同步配置文件
$ cat job/mysql_jygt_2_enger.json
{
    "job": {
        "setting": {
            "speed": {
                "channel": 1,
            },
            "errorLimit": {
                "record": 0,
                "percentage": 0.02
            }
        },
        "content": [
            {
                "reader": {
                    "name": "mysqlreader",
                    "parameter": {
                        "username": "name",
                        "password": "passwd",
                        "column": ["*"],
                        "connection": [
                            {
                                "table": ["t_user"],
                                "jdbcUrl": ["jdbc:mysql://192.168.1.222:3306/db_jygt?useSSL=false&serverTimezone=UTC"]
                            }
                        ],
                        "splitPk": "id",
                        "where": "f_modify_time> '${last_sync_time}'"
                    }
                },
                "writer": {
                    "name": "mysqlwriter",
                    "parameter": {
                        "writeMode": "insert",
                        "username": "name",
                        "password": "passwd",
                        "column": ["*"],
                        "connection": [
                            {
                                "jdbcUrl": "jdbc:mysql://192.168.1.111:3306/db_enger?useSSL=false&serverTimezone=UTC",
                                "table": ["t_user"]
                            }
                        ],
                        "preSql": [
                                "CREATE TABLE  IF NOT EXISTS `t_user` (
                                `f_id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '主键:唯一标识特定表的一个记录',
                                `f_uid` VARCHAR(64) NOT NULL COMMENT '用户ID,业务语义上,与f_user_source_id一起唯一标记一个用户' COLLATE 'utf8mb4_bin',
                                `f_user_source_id` INT(11) NOT NULL COMMENT '用户来源id,对应t_user_source表的相关记录主键',
                                `f_auth_code` VARCHAR(256) NOT NULL COMMENT '用户身份识别码,一般用来验证用户的身份。例如密码,手机验证码、邮件验证码、或者来自第三方平台的授权吗' COLLATE 'utf8mb4_bin',
                                `f_name` VARCHAR(64) NULL DEFAULT NULL COMMENT '用户名' COLLATE 'utf8mb4_bin',
                                `f_motto` VARCHAR(128) NULL DEFAULT NULL COMMENT '用户座右铭' COLLATE 'utf8mb4_bin',
                                `f_avarta_url` VARCHAR(50) NULL DEFAULT NULL COMMENT '用户的头像url' COLLATE 'utf8mb4_bin',
                                `f_create_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
                                `f_modify_time` TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
                                PRIMARY KEY (`f_id`) USING BTREE,
                                UNIQUE INDEX `unq_source_and_uid` (`f_uid`, `f_user_source_id`) USING BTREE,
                                INDEX `idx_source` (`f_user_source_id`) USING BTREE
                                )"
                        ]
                    }
                }
            }
        ]
    }
}
  1. 执行
gauss@power-edge-r730:~/soft/datax$ python3 bin/datax.py job/mysql_jygt_2_enger.json

.......
 All Task WaitWriterTime 0.000s |  All Task WaitReaderTime 0.177s | Percentage 100.00%
2025-05-27 16:31:22.350 [job-0] INFO  JobContainer -
任务启动时刻                    : 2025-05-28 00:31:11
任务结束时刻                    : 2025-05-28 00:31:22
任务总计耗时                    :                 11s
任务平均流量                    :               73B/s
记录写入速度                    :              0rec/s
读出记录总数                    :                   9
读写失败总数                    :                   0
  1. 验证




  1. 更多

可以编制一个脚本来管理已经同步的数据最后更新时间,再次运行就只对其后更改的数据进行同步。并配置定时任务,令其自省,实现准实时同步数据。

gauss@power-edge-r730:~/soft/datax$ cat script/mysql_jygt_2_enger.sh
#!/bin/bash

# DataX路径
DATAX_PATH="/home/gauss/soft/datax"

# 配置文件路径
CONFIG_FILE="$DATAX_PATH/job/mysql_jygt_2_enger.json"

# 时间戳文件路径
TIME_FILE="$DATAX_PATH/job/imysql_jygt_2_enger_last_sync_time.txt"

# 获取上次同步时间
LAST_TIME=$(cat $TIME_FILE)

# 当前时间
CURRENT_TIME=$(date +"%Y-%m-%d %H:%M:%S")

# 替换配置文件中的时间变量
sed -i "s/'\${last_sync_time}'/'$LAST_TIME'/" $CONFIG_FILE

# 执行DataX同步
python3 $DATAX_PATH/bin/datax.py $CONFIG_FILE

# 更新时间戳文件
echo $CURRENT_TIME > $TIME_FILE

# 恢复配置文件
sed -i "s/'$LAST_TIME'/'\${last_sync_time}'/" $CONFIG_FILE
crontab -e
*/5 * * * * /opt/datax/incremental_sync.sh >> /opt/datax/sync.log 2>&1

相关推荐

linux -- sed命令(linux sed命令详解)

1.sed调用方式sed[options]‘command’file(s)sed[options]-fscriptfilefile(s)第一种直接在命令行中执行,第二种把命令写到了脚本...

AutoCAD的常用快捷命令汇总(autocad常用快捷键命令大全)

AutoCAD常用快捷命令分类汇总,涵盖绘图、修改、标注、视图控制等高频操作,适用于大部分版本(如AutoCAD2023/2020/2016)。按功能分类整理,建议收藏保存,便于快速查阅:一、绘...

Linux Shell文件处理(linux shell 技巧)

预计更新1:基础知识简介和安装基本命令变量和环境变量2:流程控制条件语句循环语句函数3:文件处理文件读写文件权限和所有权文件搜索和替换4:网络和进程网络通信进程管理信号处理5:文本处理正则表...

bash通配符(通配符的匹配很全面)

Bash中常用的通配符和正则表达式,以及正则表达式的应用场景。**通配符(Globbing)**通配符主要用于文件名扩展,由Shell解释执行,用于查找符合特定模式的文件名。***`*`...

用DataX实现两个MySQL实例间的数据同步

DataXDataX使用Java实现。如果可以实现数据库实例之间准实时的#数据同步#,可以解决很多问题。例如数据可靠性和高并发的问题。OracleGoldenGate是Oracle提供的一个商业...

Linux gron 命令使用详解(linux中gun命令的含义)

简介gron是一个独特的命令行工具,用于将JSON数据转换为离散的、易于grep处理的赋值语句格式。它的名字来源于"grepableon"或"grepable...

[Linux Shell]脚本修改包含空格的文件名

脚本如下:#!/bin/bashforFILEin*doSP=`echo$FILE|sed's//_/g'`if["$SP"!="$FILE"];thenecho"...

Shell脚本怎么写?Linux命令三剑客之sed命令

大家好呀,今天周五,总算下了个早班,我们今天的主题还是跟Linux的Shell脚本相关,截至这篇文章,我们已经给大家介绍了Shell这种编程语言的基本语法,变量,流程控制,函数,模块和一些特殊系统变量...

Linux怎样在文件特定的位置添加一行文本

HELLO大家好,欢迎来的我的频道,如果这篇文章能帮到你,请把我点赞,收藏,谢谢!如果您想通过脚本在文件中特定的一行中添加文本。下面的例子将帮助你做到这一点。例如,您有一个名为file1.txt的文...

tomcat修改默认端口号(tomcat在哪修改端口)

关注我,不迷路,大家好,我是大王。--记录运维中遇到的故障及排查方法一、背景说明tomcat默认的端口号是8080,但是对于生产环境来说,为了安全性能,一般不建议用默认端口,这时候就需要我们修改端口号...

ubuntu7:进入维护模式修改文件(ubuntu系统修复命令)

ubuntu系统提供了维护模式,以便于在系统启动异常或者因修改、删除文件导致系统起不来的情况时,通过维护模式来修改文件等操作。如果ubuntu系统已经不能挂载文件系统,比如修改了/etc/fstab错...

linux sed命令详解(linux sed c)

//删除文件第二行d命令#sed'2d'text.txt//打印从第五行开始到第一个包含以w1开始的行之间的所有行p命令#sed-n'5,/^w1/p'#所...

Linux下sed的简单使用(linux sed命令详解)

1、sed简介stremeditor流编辑器,它是一项Linux指令,功能同awk类似,差别在于,sed简单,对列处理的功能要差一些,awk的功能复杂,对列处理的功能比较强大,sed编辑器是一行一...

Linux基础命令-sed命令(linux三剑客之sed命令)

Sed全名streameditor流编辑器,它是一个强大的文本处理工具,它可以从文件中接受输入,也可以接受来自标准输入流的输入,它擅长取行。Sed的用途非常广泛,包括:1)文本替换2)选择性的输...

Linux sed命令介绍(linux中的sed)

简介sed命令应用广泛,使用简单,是文本流编辑器的利器,逐行对文件的内容进行处理处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(patternspace),可以指定仅仅处理哪些行。s...