• Mysql 8.0 OGG21C 安装使用


    OGG安装

      环境介绍,为了节省资源OGG我选择和原库安装在了同一台服务器

    软件版本

    IP地址

    OGG21.3

    192.168.2.251

    Mysql8.0.11

    192.168.2.251

    Mysql8.0.11

    192.168.2.252

    1.1  解压ogg的安装包

      上传并解压mysql ogg安装包,无需安装解压即可使用

    # mkdir /ogg
    # unzip 213000_ggs_Linux_x64_MySQL_64bit.zip
    # tar -xvf ggs_Linux_x64_MySQL_64bit.tar

    1.2  Mysql数据库配置

    源库配置

      OGG21C可以使用基于日志的DDL复制,要求添binlog_row_metadata为full模式才可以实现

    # vi /etc/my.cnf
    [mysqld]
    datadir=/usr/local/mysql/data
    basedir=/usr/local/mysql
    socket=/tmp/mysql.sock
    user=mysql
    port=3306
    character-set-server=utf8mb4
    symbolic-links=0
    
    server_id         = 1
    log_bin           = mysql-bin
    expire_logs_days  = 1
    binlog_format     = row
    binlog_row_metadata=full
    
    [mysqld_safe]
    log-error=/var/log/mysqld.log
    pid-file=/var/run/mysqld/mysqld.pid

    目标库配置

    [mysqld]
    datadir=/usr/local/mysql/data
    basedir=/usr/local/mysql
    socket=/tmp/mysql.sock
    user=mysql
    port=3306
    character-set-server=utf8mb4
    symbolic-links=0
    
    server_id         = 2
    log_bin           = mysql-bin
    expire_logs_days  = 1
    binlog_format     = row
    binlog_row_metadata=full
    
    [mysqld_safe]
    log-error=/var/log/mysqld.log
    pid-file=/var/run/mysqld/mysqld.pid

    主备数据库创建同步用户并附权

    CREATE USER 'ogg'@'%' IDENTIFIED BY 'Sandata@123';
    GRANT ALL PRIVILEGES ON *.* TO 'ogg'@'%' WITH GRANT OPTION;
    FLUSH PRIVILEGES;

    1.3  OGG配置

      在21C的OGG中ogg可以单独部署并不需要每台服务器都安装,只要网络可达即可

    [root@mysql ogg]# ./ggsci 
    
    Oracle GoldenGate Command Interpreter for MySQL
    Version 21.3.0.0.0 OGGCORE_21.3.0.0.0_PLATFORMS_210728.1047
    Oracle Linux 7, x64, 64bit (optimized), MySQL  on Jul 28 2021 18:17:46
    Operating system character set identified as UTF-8.
    
    Copyright (C) 1995, 2021, Oracle and/or its affiliates. All rights reserved.
    
    
    GGSCI (mysql) 1> CREATE SUBDIRS
    Creating subdirectories under current directory /ogg
    Parameter file                 /ogg/dirprm: created.
    Report file                    /ogg/dirrpt: created.
    Checkpoint file                /ogg/dirchk: created.
    Process status files           /ogg/dirpcs: created.
    SQL script files               /ogg/dirsql: created.
    Database definitions files     /ogg/dirdef: created.
    Extract data files             /ogg/dirdat: created.
    Temporary files                /ogg/dirtmp: created.
    Credential store files         /ogg/dircrd: created.
    Master encryption key wallet files /ogg/dirwlt: created.
    Dump files                     /ogg/dirdmp: created.

    配置mgr进程

    GGSCI (mysql) 36> edit param mgr
    
    PORT 17809
    DYNAMICPORTLIST 17810-17909
    AUTORESTART EXTRACT *,RETRIES 5,WAITMINUTES 3
    PURGEOLDEXTRACTS ./dirdat/*,usecheckpoints, minkeepdays 3

    配置EXTRACT进程

    GGSCI (mysql) 38> edit param EXM8
    
    extract exm8
    sourcedb wutong@192.168.2.251:3306, userid ogg, password Sandata@123
    tranLogOptions altlogDest REMOTE
    ddl include mapped
    exttrail ./dirdat/m8
    table wutong.*;
    
    GGSCI (mysql) 39> add ext exm8, tranlog, begin now
    GGSCI (mysql) 40> add exttrail ./dirdat/m8, ext exm8

    配置REPLICAT进程,在21C的版本中已经不用配置pump进程

    GGSCI (mysql) 2> edit param REP252
    
    replicat rep252
    targetdb wutong@192.168.2.252:3306, userid ogg, password Sandata@123
    DDLERROR DEFAULT IGNORE RETRYOP
    map wutong.*, target wutong.*;

    启动所有进程

    GGSCI (mysql) 3> info all
    
    Program     Status      Group       Lag at Chkpt  Time Since Chkpt
    
    MANAGER     RUNNING                                           
    EXTRACT     RUNNING     EXM8        00:00:00      00:00:08    
    REPLICAT    RUNNING     REP252      00:00:00      00:00:00

    1.4 DDL、DML测试

    主库
    mysql> use wutong;
    Reading table information for completion of table and column names
    You can turn off this feature to get a quicker startup with -A
    
    Database changed
    
    mysql> show tables;
    +------------------+
    | Tables_in_wutong |
    +------------------+
    | test2            |
    +------------------+
    1 row in set (0.00 sec)
    
    目标库
    mysql> use wutong;
    Reading table information for completion of table and column names
    You can turn off this feature to get a quicker startup with -A
    
    Database changed
    mysql> show tables;
    +------------------+
    | Tables_in_wutong |
    +------------------+
    | test2            |
    +------------------+
    1 row in set (0.00 sec)
    
    
    主库
    mysql> create table sandata (id int,name varchar(20));
    Query OK, 0 rows affected (0.07 sec)
    
    mysql> insert into sandata values (1,'wutong');
    Query OK, 1 row affected (0.04 sec)
    
    mysql> select * from sandata
        -> ;
    +------+--------+
    | id   | name   |
    +------+--------+
    |    1 | wutong |
    +------+--------+
    1 row in set (0.00 sec)
    
    
    目标库
    mysql> show tables;
    +------------------+
    | Tables_in_wutong |
    +------------------+
    | test2            |
    +------------------+
    1 row in set (0.00 sec)
    
    mysql> show tables;
    +------------------+
    | Tables_in_wutong |
    +------------------+
    | sandata          |
    | test2            |
    +------------------+
    2 rows in set (0.00 sec)
    
    mysql> select * from sandata;
    +------+--------+
    | id   | name   |
    +------+--------+
    |    1 | wutong |
    +------+--------+
    1 row in set (0.00 sec)

    参考文档oracle官方手册

    https://docs.oracle.com/en/middleware/goldengate/core/21.3/gghdb/using-oracle-goldengate-mysql.html

  • 相关阅读:
    判断 undefined and ( == null) and (!something) and ( == null)
    textarea高度自适应自动展开
    退出 js和Jquery区别
    javascript高级程序设计 学习笔记 第五章 下
    Bind, Call and Apply in JavaScript
    javascript高级程序设计 学习笔记 第五章 上
    小程序入门---登录流程
    Array类型 JS
    深入浅出妙用 Javascript 中 apply、call、bind
    微信公众号开发(与angular框架相结合)
  • 原文地址:https://www.cnblogs.com/sandata/p/15665557.html
Copyright © 2020-2023  润新知