Goldengate配置及M to M分库分表迁移

2019-01-31  本文已影响0人  左轮Lee

Goldengate安装

OS:CentOS Linux release 7.3.1611 (Core)
mysql:5.6.28-log,企业版和社区版均支持
GoldenGate:12.2.0.1.1
源库:192.168.118.129:3306
目标库:192.168.118.130:3306
表存储引擎:InnoDB

前提条件:

源端必须开启log-bin和log-bin-index

mysql> show VARIABLES like '%log_bin%';
+---------------------------------+--------------------------------------------+
| Variable_name                   | Value                                      |
+---------------------------------+--------------------------------------------+
| log_bin                         | ON                                         |
| log_bin_basename                | /data/mysql/mysql3306/data/mysql-bin       |
| log_bin_index                   | /data/mysql/mysql3306/data/mysql-bin.index |
| log_bin_trust_function_creators | ON                                         |
| log_bin_use_v1_row_events       | OFF                                        |
| sql_log_bin                     | ON                                         |
+---------------------------------+--------------------------------------------+

源和目标库均执行

1.解压ogg安装包
mkdir /u01/app/ggs -p
tar -xvf ggs_Linux_x64_MySQL_64bit.tar  -C /u01/app/ggs

2.初始化ogg目录
cd /u01/app/ggs
./ggsci
create subdirs

3.建ogg数据库及账号
create database ogg;
grant all on \*.* to ogg@'192.168.118.%' identified by 'ggs';
flush privileges;

分库分表进程配置

源端
注意格式,表名与分号;之间不要有空格!!!!
1.管理进程
edit param mgr        ##编辑管理进程mgr,输入下面内容
port 8809
DYNAMICPORTLIST 8840-8850
ACCESSRULE, PROG *, IPADDR 192.168.118.130, ALLOW     --允许目标端ip访问

2.抓取进程
dblogin sourcedb ogg@192.168.118.129:3306 userid ogg password ggs
add extract exttp,tranlog,begin now
add exttrail ./dirdat/tp,extract exttp, megabytes 500

edit params exttp         ##编辑进程exttp,输入下面内容
extract exttp
sourcedb ogg@192.168.118.129:3306 userid ogg password ggs
tranlogoptions altlogdest /data/mysql/mysql3306/logs/mysql-bin.index 
exttrail ./dirdat/tp
dynamicresolution
gettruncates
table test_user.goods_time_price,KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);     --需要主键和分区字段同时作为keycols

3.传递进程
ADD EXTRACT dpetp, EXTTRAILSOURCE ./dirdat/tp
ADD RMTTRAIL ./dirdat/tp, EXTRACT dpetp, megabytes 500

edit params dpetp         ##编辑进程dpetp,输入下面内容
extract dpetp
rmthost 192.168.118.130,mgrport 8809
rmttrail ./dirdat/tp
PASSTHRU
gettruncates
table test_user.goods_time_price;

4.数据初始化抓取进程
--初始化数据进程,也可用其他方式同步初始数据,此方法同步速度约10000条/秒(机械盘)
--若有多个大表,可分开配置多个,同时进行初始化
add extract inittp1,sourceistable
edit params inittp1        ##编辑进程inittp1,输入下面内容
extract inittp1
sourcedb ogg@192.168.118.129:3306 userid ogg password ggs
rmthost 192.168.118.130,mgrport 8809
rmttask replicat,group reptp1         --reptp1需要与目标端初始化应用进程名对应
table test_user.goods_time_price;
目标端
注意格式,表名与分号;之间不要有空格!!!!
1.管理进程
edit param mgr        ##编辑管理进程mgr,输入下面内容
port 8809
DYNAMICPORTLIST 8840-8850
ACCESSRULE, PROG *, IPADDR 192.168.118.129, ALLOW     --允许源端ip访问

2.登陆目标库,创建checkpoint table
dblogin sourcedb ogg@192.168.118.130:3306 userid ogg password ggs
add checkpointtable ogg.ckp_table

3.应用进程:
add replicat reptp,exttrail /u01/app/ggs/dirdat/tp,checkpointtable ogg.ckp_table
edit params reptp       ##编辑进程reptp,输入下面内容,此案例是按照SUPP_GOODS_ID取余来分片,注意map的格式,空格不可改动,直接复制修改表名即可
replicat reptp
targetdb ogg@192.168.118.130:3306 userid ogg password ggs
discardfile /u01/app/ggs/dirrpt/reptp.dsc,purge
handlecollisions
map test_user.goods_time_price,target test_user_0.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=0),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_1.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=1),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_2.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=2),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_3.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=3),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_4.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=4),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_5.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=5),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_6.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=6),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_7.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=7),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);

5.数据初始化应用进程
add replicat reptp1,specialrun
edit param reptp1       ##编辑进程reptp1,对应前面的抓取进程里的reptp1,注意map的格式,空格不可改动,直接复制修改表名即可
replicat reptp1
targetdb ogg@192.168.118.130:3306 userid ogg password ggs
discardfile /u01/app/ggs/dirrpt/reptp1.dsc,purge
sqlexec "SET FOREIGN_KEY_CHECKS=0"
map test_user.goods_time_price,target test_user_0.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=0),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_1.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=1),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_2.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=2),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_3.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=3),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_4.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=4),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_5.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=5),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_6.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=6),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
map test_user.goods_time_price,target test_user_7.goods_time_price,FILTER (@compute( SUPP_GOODS_ID \ 8)=7),KEYCOLS(SUPP_GOODS_ID,TIME_PRICE_ID);
启动进程,开始同步
1.启动源端和目标端管理进程
cd /u01/app/ggs
./ggsci
start mgr

2.启动源端抓取和传递进程
cd /u01/app/ggs
./ggsci
start exttp
start dpetp
info all

3.启动源端初始化进程同步全量数据,目标端应用进程随之启动,无需处理
cd /u01/app/ggs
./ggsci
start inittp1
info ini*,tasks          ###查看初始化进程状态
EXTRACT    INITTP1   Last Started 2018-11-12 17:21   Status RUNNING
Checkpoint Lag       Not Available
Log Read Checkpoint  Table test_user.goods_time_price
                     2018-11-12 17:21:39  Record 51007
Task                 SOURCEISTABLE

4.待第三步完成后启动目标端应用进程
cd /u01/app/ggs
./ggsci
start  reptp

5.检查数据是否分库分表正确

6.检查dml是否正确同步

范围分区参考
抓取:
table hotel.com_photo,KEYCOLS(PHOTO_ID,OBJECT_ID);

传递:
table hotel.com_photo;

应用(注意条件的括号、表小写、字段大写):
map hotel.com_photo,target hotel0.com_photo,FILTER ( (OBJECT_ID>0) AND (OBJECT_ID<=5000000) ),KEYCOLS(PHOTO_ID,OBJECT_ID);
map hotel.com_photo,target hotel1.com_photo,FILTER ( (OBJECT_ID>5000000) AND (OBJECT_ID<=10000000) ),KEYCOLS(PHOTO_ID,OBJECT_ID);
map hotel.com_photo,target hotel2.com_photo,FILTER ( (OBJECT_ID>10000000) AND (OBJECT_ID<=20000000) ),KEYCOLS(PHOTO_ID,OBJECT_ID);

上一篇 下一篇

猜你喜欢

热点阅读