当前位置:首页 > 文章列表 > 数据库 > MySQL > OGG实现两台Mysql之间的数据同步(Linux系统)

OGG实现两台Mysql之间的数据同步(Linux系统)

来源:SegmentFault 2023-01-12 15:44:50 0浏览 收藏

来到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版本选择: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删除
SSM结合easyexcel导入数据库SSM结合easyexcel导入数据库
上一篇
SSM结合easyexcel导入数据库
云上高并发系统改造最佳实践
下一篇
云上高并发系统改造最佳实践
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 笔灵AI生成答辩PPT:高效制作学术与职场PPT的利器
    笔灵AI生成答辩PPT
    探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
    14次使用
  • 知网AIGC检测服务系统:精准识别学术文本中的AI生成内容
    知网AIGC检测服务系统
    知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
    22次使用
  • AIGC检测服务:AIbiye助力确保论文原创性
    AIGC检测-Aibiye
    AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
    30次使用
  • 易笔AI论文平台:快速生成高质量学术论文的利器
    易笔AI论文
    易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
    39次使用
  • 笔启AI论文写作平台:多类型论文生成与多语言支持
    笔启AI论文写作平台
    笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
    35次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码