OGG实现两台Mysql之间的数据同步(Linux系统)
来源:SegmentFault
时间:2023-01-12 15:44:50 108浏览 收藏
来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习数据库相关编程知识。下面本篇文章就来带大家聊聊《OGG实现两台Mysql之间的数据同步(Linux系统)》,介绍一下MySQL、Linux、ogg,希望对大家的知识积累有所帮助,助力实战开发!
一. OGG同步介绍
- OGG 是一种基于日志的结构化数据复制软件
- OGG 能够实现大量数据的实时捕捉、投递,实现源数据库与目标数据库的数据同步,保持最少10ms的数据延迟
二. OGG部署
- 在一个典型的OGG环境中,会有两个数据库存在,同时也会有两个OGG实例运行
- OGG支持远端部署,即OGG软件不安装在数据库主机上,而是安装在单独的机器上,负责数据抽取和投递,但是OGG不支持以源端数据库为MySQL的远程抽取与投递
一. OGG同步原理
- OGG同步过程大致为源端OGG负责抽取源端数据库变化数据,并将变化数据投递至目标端OGG,目标端OGG负责解析并持久化到目标数据库,进程如下:
进程 | 功能 | 运行位置 |
---|---|---|
Manager | 启动、监控、重启Goldengate的其他进程,报告错误及事件,分配数据存储空间,发布阀值报告等。在目标端和源端有且只有一个Manager进程 | 源端OGG、目标端OGG |
Extract | 负责从源端数据表或者日志中捕获数据,保存在Source Trail文件中 | 源端OGG |
Data Pump | 用于抓取Source Trail,把trail以数据块的形式通过TCP/IP 协议发送到目标端OGG | 源端OGG |
Replicat | 是数据传递的最后一站,负责读取目标端trail文件中的内容,并将其解析为DML或 DDL语句,然后应用到目标数据库中 | 目标端OGG |
三. OGG下载与安装
- OGG下载地址:https://www.oracle.com/middle...
- OGG版本选择:Oracle GoldenGate 21.1.0.0.1 for MySQL on Linux x86-64
- OGG安装:将下载的OGG压缩包本地进行zip解压,上传其中的 ggs_Linux_x64_MySQL_64bit.tar 到Linux服务器中自定义的ogg文件夹中,直接进行解压即可(tar -xvf ggs_Linux_x64_MySQL_64bit.tar)
使用ggsci创建ogg相关子目录:
首先输入./ggsci进入ggsci
然后输入create subdirs 命令创建相关子目录如果第一步输入./ggsci无法进入,请输入ldd ggsci查看依赖关系
下图为无法进入的情况(我的问题是因为下载OGG版本错误,网上大部分文章都是缺少libnnz11.so这个大同小异,如果出现了可以按这些文章去处理)
下图为正常安装能进入ggsci
四. OGG源端配置
- 配置管理进程Manager
#输入配置管理进程命令 GGSCI (localhost.localdomain) 1> edit param mgr #指定端口号 port 7809 #绑定可用端口列表 dynamicportlist 7840-7939 #定时清理trail文件 purgeoldextracts /ogg/dirdat/*,usecheckpoints, minkeepdays 1 #输入启动管理进程命令(关闭:stop mgr ) GGSCI (localhost.localdomain) 2> start mgr Manager started. #输入查看状态命令查看是否启动 GGSCI (localhost.localdomain) 3> info all Program Status Group Lag at Chkpt Time Since Chkpt MANAGER RUNNING
下图为实际操作
- 配置抽取进程Extract
#输入配置抽取进程命令 GGSCI (localhost.localdomain) 2> edit param exta #定义抽取进程名称 extract exta #指定OGG连接数据库的地址、账户与密码 sourcedb shop_system@192.168.16.99:3306 userid ogg password ogg #指定写入到本地的哪个队列 exttrail /ogg/dirdat/ea #定义discardfile文件位置,如果处理中有记录出错会写入到此文件中 discardfile /ogg/dirrpt/exta.dsc,append #指定在解析数据库日志时所需要的特殊参数 TranLogOptions AltLogDest /mysql/binlog/master-bin.index #定义需复制的表,后面需以;结尾 table shop_system.*; GGSCI (localhost.localdomain) 5> add extract exta,tranlog,begin now EXTRACT added. #添加抽取源文件位置和大小 GGSCI (localhost.localdomain) 6> add exttrail /ogg/dirdat/ea,extract exta EXTTRAIL added.
下图为实际操作
- 配置投递进程Data Pump
GGSCI (localhost.localdomain) 15> edit param dmpa #定义投递进程名 extract dmpa passthru #源端数据库地址、用户名 sourcedb shop_system@192.168.16.99:3306 userid ogg password ogg #目标端地址 rmthost 192.168.10.12,mgrport 7809,compress # 指定写入文件 rmttrail /ogg/dirdat/da dynamicresolution numfiles 3000 #投递的表 table shop_system.test_ogg; GGSCI (localhost.localdomain) 16> add extract dmpa ,exttrailsource /ogg/dirdat/ea EXTRACT added. GGSCI (localhost.localdomain) 17> add rmttrail /ogg/dirdat/da,extract dmpa RMTTRAIL added.
下图为实际操作
- 配置数据结构不一致时的表定义文件
GGSCI (localhost.localdomain) 23> edit param defgen defsfile ./dirdef/testdb.def sourcedb point_manager@192.168.10.11:3306 userid ogg, password ogg table point_manager.test_ogg; GGSCI (localhost.localdomain) 26> exit
生成表定义文件(生成成功后复制一份到目标端OGG的dirdef目录下)
[root@masterdb ogg]# ./defgen paramfile ./dirprm/defgen.prm
五. OGG目标端配置
- 配置管理进程Manager
GGSCI (localhost.localdomain) 3> edit param mgr port 7809 dynamicportlist 7840-7939 purgeoldextracts /ogg/dirdat/*,usecheckpoints, minkeepdays 1 GGSCI (localhost.localdomain) 5> start mgr Manager started. GGSCI (localhost.localdomain) 6> info all Program Status Group Lag at Chkpt Time Since Chkpt MANAGER RUNNING
- 配置检查表
GGSCI (localhost.localdomain) 9> dblogin sourcedb shop_system@192.168.10.12:3306 userid ogg password ogg Successfully logged into database. GGSCI (localhost.localdomain DBLOGIN as root) 10> add checkpointtable shop_system.checkpoint Successfully created checkpoint table shop_system.checkpoint. GGSCI (localhost.localdomain DBLOGIN as root) 11> edit params ./GLOBALS checkpointtable shop_system.checkpoint
- 配置应用进程Replicat
GGSCI (slavedb DBLOGIN as ogg) 13> edit params repa #定义应用进程名称 replicat repa #配置目标端数据库地址、用户名和密码 targetdb testdb_repl@192.168.10.12:3306 userid ogg password ogg handlecollisions #假定两端数据结构不一致,使用此参数指定源端的数据结构定义文件,该文件需要由GlodenGate工具产生 sourcedefs /ogg/dirdef/testdb.def #定义discardfile文件位置,如果处理中有记录出错会写入到此文件中,建议参数值1024m discardfile /ogg/dirrpt/repa.dsc,purge #用于指定源端与目标端表的映射关系 map point_manager.test_ogg, target shop_system.test_ogg; GGSCI (slavedb DBLOGIN as ogg) 16> add replicat repa,exttrail /ogg/dirdat/da,checkpointtable testdb_repl.checkpoint REPLICAT added.
下图为实际操作
随后进入ggsci启动源端抽取进程、投递进程和目标端的应用进程,随后在源端数据库手动插入数据查看目标数据库是否完成了同步
start exta start dmpa start repa
六. 同步数据结构变化总结
目前没有找到源端数据结构修改不影响现有同步进程的方法
- 源端数据表与目标端数据表结构不一致则会导致源端抽取进程中断,需先处理源端与目标端的数据结构保持一致,随后重启抽取进程。(如果是字段的类型的修改可自动转换的则不会失败,否则会失败)
- 目标端DB表增加或减少字段则不会影响同步
- 重启:使用stop +进程名 停止服务,如果不能停止的话使用delete+进程名直接删除,随后重新配置进程并启动
- 指定同步列:如果我们只想同步一张表中的某些字段,我们可以指定我们需要同步的列,修改抽取进程exta如下图(但是从测试的结果来看不能解决源表后期增加字段不影响同步的问题)
- 多表同步:在涉及配置table的一行下边直接追加新的一行配置需要同步的表,方式与原来相同table+ 数据库.表
到这里,我们也就讲完了《OGG实现两台Mysql之间的数据同步(Linux系统)》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于mysql的知识点!
声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
最新阅读
更多>
-
208 收藏
-
174 收藏
-
317 收藏
-
371 收藏
-
244 收藏
-
288 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习