OGG-Postgres实时同步到MySQL
(一)数据库信息
|
名称 |
源端数据库 |
目标端数据库 |
|
数据库类型 |
Postgresql 12.4 |
MySQL 5.7 |
|
IP地址 |
20.2.127.23 |
20.2.127.24 |
|
端口 |
5432 |
3306 |
|
数据库 |
testpdb |
test |
|
用户 |
ogguser |
root |
|
密码 |
ogguserP2021 |
Root@1234 |
postgreSQL数据库配置:
vi postgresql.conf
wal_level = logical # minimal, replica, or logical
# (change requires restart)
max_wal_senders = 10 # max number of walsender processes
# (change requires restart)
max_replication_slots = 10 # max number of replication slots
# (change requires restart)
修改后,重启PostgreSQL数据库。
(二)OGG安装信息
|
名称 |
源端OGG |
目标端OGG |
|
OGG版本 |
213000_ggs_Linux_x64_PostgreSQL_64bit.zip |
213000_ggs_Linux_x64_MySQL_64bit.zip |
|
安装服务器IP |
20.2.127.24 |
20.2.127.24 |
|
OGG_HOME |
/data/ogg_pg/ |
/data/ogg_mysql/ |
|
MGR进程 |
mgr |
mgr |
|
EXTRACT进程 |
ext1 |
— |
|
PUMP进程 |
pump1 |
— |
|
REPLICAT进程 |
— |
rep1 |
编辑变量:
vi /etc/profile
export LD_LIBRARY_PATH=/data/ogg_pg/lib:/data/ogg_mysql/lib:$LD_LIBRARY_PATH
alias pg_ggsci='cd /data/ogg_pg; ./ggsci'
alias mysql_ggsci='cd /data/ogg_mysql; ./ggsci'
source /etc/profile
(三)OGG源端配置
1.启动PG的ggsci
pg_ggsci
2.PG 创建目录
create subdirs
3.配置并启动MGR
--编辑MGR
edit param mgr
port 2031
dynamicportlist 2032-2040
purgeoldextracts ./dirdat/*, usecheckpoints,minkeephours 24
AUTORESTART ER *, RETRIES 3, WAITMINUTES 2,RESETMINUTES 10
--启动MGR
start mgr
--查看MGR状态
Info mgr
4.登录PG数据库
编辑 odbc.ini
[ODBC Data Sources]
PGDSN=DataDirect 12.4 PostgreSQL Wire Protocol
postgres=DataDirect 12.4 PostgreSQL Wire Protocol
scott=DataDirect 12.4 PostgreSQL Wire Protocol
[ODBC]
IANAAppCodePage=106
InstallDir=/data/ogg_pg
[TESTPDB]
Driver=/data/ogg_pg/lib/GGpsql25.so
Description=DataDirect 12.4 PostgreSQL Wire Protocol
Database=testpdb
HostName=20.2.127.23
PortNumber=5432
LogonID=ogguser
Password=ogguserP2021
TransactionErrorBehavior=2
--登录
dblogin sourcedb testpdb, userid ogguser, password ogguserP2021
5.配置抽取进程
--注册抽取
register extract ext1
--增加抽取进程日志
add ext ext1, tranlog , begin now
add exttrail ./dirdat/e1, ext ext1
--编辑抽取参数
edit param ext1
extract ext1
setenv(PGCLIENTENCODING = "UTF8")
setenv(ODBCINI="/data/ogg_pg/odbc.ini" )
sourcedb testpdb, userid ogguser, password ogguserP2021
exttrail ./dirdat/e1
discardfile ./dirrpt/ext1.dsc
cachemgr cachesize 1G
container mem_limit 8G
table public.*;
--启动抽取进程
start ext1
--查看进程状态
info ext1
--查看统计信息
stats ext1, total
6.配置投递进程
--编辑投递参数
edit param pump1
extract pump1
rmthost 20.2.127.24, mgrport 7809
rmttrail ./dirdat/e1
passthru
cachemgr cachesize 1G
container mem_limit 8G
table public.*;
--添加投递进程日志
add extract pump1, exttrailsource ./dirdat/e1
add rmttrail ./dirdat/e1, extract pump1
--启动投递进程
start pump1
--查看投递进程状态
Info pump1
7.配置源端OGG异构mapping文件
edit params defgen1
defsfile ./dirdef/defgen1.def
sourcedb testpdb, userid ogguser, password ogguserP2021
table public.*;
--将默认生成的文件保存到OGG目录的dirdef目录下
shell ./defgen paramfile dirprm/defgen1.prm
将生成的def传输到目标端
shell scp ./dirdef/defgen1.def root@20.2.127.24:/data/ogg_mysql/dirdef/
如果出现提示:说明/data/ogg_mysql/dirdef/这个目录不存在,需要在OGG目标端创建目录后才能会自动生成。
(四)OGG目标端配置
1.启动MySQL的ggsci
mysql_ggsci
2.MySQL 创建目录
create subdirs
3.配置并启动MGR
edit param mgr
PORT 7809
DYNAMICPORTLIST 7810-7909
AUTORESTART EXTRACT *,RETRIES 5,WAITMINUTES 3
PURGEOLDEXTRACTS ./dirdat/*,USECHECKPOINTS, MINKEEPDAYS 3
--启动MGR
start mgr
--查看MGR状态
Info mgr
4.目标端检查日志表(checkpoint)配置
--登录数据库
dblogin sourcedb test@20.2.127.24:3306 userid root password Root@1234
--添加检查日志表
add checkpointtable test.ggs_checkpoint
5.回放(Replicat)进程配置
--添加一个回放进程并与源端pump进程传输过来的trail文件关联,并使用checkpoint表确保数据不丢失
add replicat rep1, exttrail ./dirdat/e1, checkpointtable test.ggs_checkpoint
--添加/编辑回放进程配置文件
edit param rep1
replicat rep1
targetdb test@20.2.127.24:3306,userid root,password Root@1234
sourcedefs ./dirdef/defgen1.def
discardfile ./dirrpt/rep1.dsc,append,megabytes 1024
handlecollisions
cachemgr cachesize 1G
container mem_limit 8G
map public.*, target test.*;
--启动回放进程
start rep1
--查看进程状态
info rep1
(五)常用命令总结
--查看所有OGG进程
info all
--查看某个OGG进程
info 进程名
info 进程名 detail
--管理OGG进程
start/stop/delete 进程名
--查看进程日志报告
view report 进程名
--修改进程参数
edit params 进程名
--修改全局参数
edit params ./GLOBAL
--查看统计信息,列出处理的所有记录数
stats 进程名,total
--查看详细处理过的事务记录
info 进程名 showch
--查看进程中最长的10个交易
send extract 进程名 ,showtrans thread 1 count 10
--查看当前GoldenGate环境信息
show
--历史命令
history
--执行本地shell
shell ls
--查看告警日志信息
view ggsevt
--查看延时,以及文件抽取应用情况
lag 进程名
OGG-Postgres实时同步到MySQL的更多相关文章
- 实战:sqlserver 数据实时同步到mysql
1.安装安装mysqlconnector 2.配置mysqlconnector ODBC数据管理器->系统DSN->加入->mysql ODBC 5.3 ANSI driver-&g ...
- mysql实时同步到mssql的解决方案
数据库在应用程序中是必不可少的部分,mysql是开源的,所以很多人它,mssql是微软的,用在windows平台上是非常方便的,所以也有很多人用它.现在问题来了,如何将这两个数据库同步,即数据内容保持 ...
- 基于OGG的Oracle与Hadoop集群准实时同步介绍
版权声明:本文由王亮原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/220 来源:腾云阁 https://www.qclou ...
- 使用Logstash来实时同步MySQL数据到ES
上篇讲到了ES和Head插件的环境搭建和配置,也简单模拟了数据作测试 本篇我们来实战从MYSQL里直接同步数据 一.首先下载和你的ES对应的logstash版本,本篇我们使用的都是6.1.1 下载后使 ...
- Mysql数据实时同步
企业运维的数据库最常见的是 mysql;但是 mysql 有个缺陷:当数据量达到千万条的时候,mysql 的相关操作会变的非常迟缓; 如果这个时候有需求需要实时展示数据;对于 mysql 来说是一种灾 ...
- goldengate 12.3 实现mysql数据及DDL实时同步
以下环境在mysql 5.7上完成. set mysql_home=mysql安装路径 set path=%mysql_home%\bin;%path% 首先要准备mysql的启动,可参考:http: ...
- Mysql 到 Hbase 数据如何实时同步,强大的 Streamsets 告诉你
很多情况大数据集群需要获取业务数据,用于分析.通常有两种方式: 业务直接或间接写入的方式 业务的关系型数据库同步到大数据集群的方式 第一种可以是在业务中编写代码,将觉得需要发送的数据发送到消息队列,最 ...
- logstash-input-jdbc实现mysql 与elasticsearch实时同步(ES与关系型数据库同步)
引言: elasticsearch 的出现使得我们的存储.检索数据更快捷.方便.但很多情况下,我们的需求是:现在的数据存储在mysql.oracle等关系型传统数据库中,如何尽量不改变原有数据库表结构 ...
- mysql数据实时同步到Elasticsearch
业务需要把mysql的数据实时同步到ES,实现低延迟的检索到ES中的数据或者进行其它数据分析处理.本文给出以同步mysql binlog的方式实时同步数据到ES的思路, 实践并验证该方式的可行性,以供 ...
- 基于Canal和Kafka实现MySQL的Binlog近实时同步
前提 近段时间,业务系统架构基本完备,数据层面的建设比较薄弱,因为笔者目前工作重心在于搭建一个小型的数据平台.优先级比较高的一个任务就是需要近实时同步业务系统的数据(包括保存.更新或者软删除)到一个另 ...
随机推荐
- vue后台管理系统,接口环境配置
https://coding.imooc.com/lesson/397.html#mid=31487
- 2024-01-20:用go语言,小扣在探索丛林的过程中,无意间发现了传说中“落寞的黄金之都“, 而在这片建筑废墟的地带中,小扣使用探测仪监测到了存在某种带有「祝福」效果的力场, 经过不断的勘测记录,
2024-01-20:用go语言,小扣在探索丛林的过程中,无意间发现了传说中"落寞的黄金之都", 而在这片建筑废墟的地带中,小扣使用探测仪监测到了存在某种带有「祝福」效果的力场, ...
- 16-集电极开路门(OC门)
集电极开路门(OC门) OC门 两个与非门,要实现非,一般来讲再与一下就可以. 能不能将输出端并在一起?普通的门电路永远不可能输出端并在一起,连在一起的. TTL与非门输出端连在一起 集电极断开之后连 ...
- 02-python简介
python简介 python认知 1.python简介 89年开发的语言,创始人范罗苏姆(Guido van Rossum),别称:龟叔(Guido). python具有非常多并且强大的第三方库,使 ...
- [转帖]解Bug之路-记一次中间件导致的慢SQL排查过程
https://zhuanlan.zhihu.com/p/242265937 解Bug之路-记一次中间件导致的慢SQL排查过程 前言 最近发现线上出现一个奇葩的问题,这问题让笔者定位了好长时间,期间排 ...
- [转帖]是的你没看错,HTTP3来了
https://www.jianshu.com/p/288ce6a8ab88 简介 很多小伙伴可能还沉浸在HTTP1.1的世界无法自拔,但是时代的洪流已经带领我们来到了HTTP3的世界了.是的,你在桥 ...
- [转帖]Percolator - 分布式事务的理解与分析
https://zhuanlan.zhihu.com/p/261115166 Percolator - 分布式事务的理解与分析 概述 一个web页面能不能被Google搜索到,取决于它是否被Googl ...
- [转帖]《Linux性能优化实战》笔记(25)—— 总结:Linux 性能工具速查
一. 性能工具速查 在梳理性能工具之前,首先给你提一个问题,那就是,在什么情况下,我们才需要去查找.挑选性能工具呢? 其实在我看来,只有当你想了解某个性能指标,却不知道该怎么办的时候,才会想到,&qu ...
- Jmeter学习之五_跟踪被测试服务器的performance
Jmeter学习之五_跟踪被测试服务器的performance 背景 这几天简单学习了一些基本的测试过程. 可以实现一些简单基本的功能了. 今天晚上继续进行了jmeter的一些学习. 想着可以在测试人 ...
- [转帖]linux下 进程io队列,IO队列和IO调度
IO体系概览 先看看本文主题IO调度和IO队列处于整个IO体系的哪个位置,这个IO体系是非常重要的,了解IO体系我们可以对整个IO过程有个全面的认识.虽然一下两下并不清楚IO体系各个部分的细节,但是我 ...