注册
DM8到DM8部署DMHS
技术分享/ 文章详情 /

DM8到DM8部署DMHS

上善若水 2022/12/21 1434 2 0

环境准备
源端数据库安装dm8数据库并模拟业务数据
创建测试表TEST_LJK
Create table test_ljk(id int,name varchar(20));
插入数据
Insert into test_ljk(id,name) values(1,’Joy’);
Insert into test_ljk(id,name) values(1,’Emily’);
Insert into test_ljk(id,name) values(1,’Tom’);

需求:
增加一台主机作为目标端,同样部署dm8数据库,实现从源端到目标端的数据同步

Dm8数据库安装参考:
https://blog.csdn.net/xiaoke_2013/article/details/127763539

主机信息:
image.png

源端和目标端安装DMHS
源端和目标端上传DMHS安装包,并修改所属用户和组(dmdba:dinstall)
[root@dm001 bin]# cd /dmdbms/dm_x/
[root@dm001 dm_x]# ll
-rwxrwxr-x 1 dmdba dinstall 490681665 Nov 22 10:27 dmhs_V4.2.98_dm8_rev117136_rh6_64_veri_20221020_sp1.bin
[root@dm001 dm_x]# ./dmhs_V4.2.98_dm8_rev117136_rh6_64_veri_20221020_sp1.bin

image.png

image.png
image.png
image.png

image.png
image.png
image.png

源端
image.png
源端和目标端安装DMHS时,主机IP和内置数据库IP填写各自主机IP
例:目标端
image.png

image.png
image.png
image.png
image.png
image.png
image.png

源端和目标端调整配置文件
[root@dm001 ~]# vim /dmdbms/dm8/data/DAMENG/dm.ini
ARCH_INI = 1 ##开启归档
RLOG_APPEND_LOGIC = 1 ##开启逻辑日志
FAST_COMMIT = 0 #必须为 0,否则会导致逻辑日志不全而影响同步。
调整后,重启数据库服务

验证参数是否生效
SQL> SELECT ARCH_DEST, ARCH_FILE_SIZE FROM SYS.V$DM_ARCH_INI WHERE ARCH_TYPE=‘LOCAL’ AND ARCH_IS_VALID=‘Y’;
SQL> SELECT PARA_VALUE FROM SYS.V$DM_INI WHERE PARA_NAME = ‘RLOG_APPEND_LOGIC’;
SQL> select para_value from v$dm_ini where para_name = ‘FAST_COMMIT’;
源端执行DDL脚本
如果要求 DDL 同步,那么需要创建 DDL 触发器和辅助表。创建的脚本参见 DMHS 安
装目录下 scripts 子目录中“ddl_sql_dm8.sql”。注意创建时需要使用 SYSDBA 用户。

执行DDL脚本时,创建9张辅助表和4张触发器
(建议使用manager管理工具SYSDBA登录执行,命令行执行会提示输入值且创建后缺少部分表)
`/home/dmdba/dmhs/scripts/ddl_sql_dm8.sql

查看创建的辅助表
select owner, table_name from dba_tables where owner = ‘SYSDBA’ and table_name like ‘DMHS%’ and status = ‘VALID’;
image.png
查看创建的触发器
select owner, trigger_name from dba_triggers where owner = ‘SYSDBA’ and trigger_name like ‘DMHS%’ and status = ‘Y’;
image.png
源端和目标端配置dmhs.hs文件
源端
<?xml version=“1.0” encoding=“GB2312”?>
<dmhs>
<base>
<lang>ch</lang>
<mgr_port>5345</mgr_port>
<ckpt_interval>60</ckpt_interval>
<siteid>1</siteid>
</base>
<cpt>
<db_type>dm8</db_type>
<db_server>127.0.0.1</db_server>
<db_user>SYSDBA</db_user>
<db_pwd>1qaz2wsx3edc</db_pwd>
<db_port>5236</db_port>
<parse_thr>1</parse_thr>
<ddl_mask>op:obj</ddl_mask> <!–DDL配置项–>
<arch><!–归档清理配置项–>
<clear_interval>600</clear_interval>
<clear_flag>0</clear_flag>
<dir>/dmdbms/dm8</dir>
</arch>
<send><!-- 发送模块配置–>
<ip>192.168.229.132</ip>
<mgr_port>5345</mgr_port>
<data_port>5346</data_port>
<trigger>1</trigger><!-- 是否忽略触发器,默认为0,限定值0,1 -->
<constraint>1</constraint><!-- 是否忽略约束,默认为0,限定值0,1 -->
<identity>1</identity>
<filter><!–过滤配置项–>
<enable><!-- 白名单,所有允许同步的表 -->
<item>SYSDBA.*</item>
</enable>
</filter>
<map><!–映射配置项–>
</map>
</send>
</cpt>
</dmhs>

目标端
<?xml version=“1.0” encoding=“GB2312”?>
<dmhs>
<base>
<lang>ch</lang>
<mgr_port>5345</mgr_port>
<ckpt_interval>60</ckpt_interval>
<siteid>2</siteid>
<version>2.0</version>
</base>
<exec>
<recv>
<data_port>5346</data_port>
</recv>
<db_type>dm8</db_type>
<db_server>127.0.0.1</db_server>
<db_user>SYSDBA</db_user>
<db_pwd>SYSDBA</db_pwd>
<db_port>5236</db_port>
<db_name></db_name>
<exec_thr>4</exec_thr>
<exec_sql>1024</exec_sql>
<exec_trx> 5000 </exec_trx>
<exec_rows>1000</exec_rows>
</exec>
</dmhs>

现对以上的基本配置作如下几点说明:

  1. siteid 全局唯一,即 DMHS 同步系统涉及的所有节点的 siteid 必须全局唯一,不允
    许有重复值。
  2. DDL 配置项,如果不需要DDL 同步,那么就配置为空,即<ddl_mask></ddl_mask>,
    相应地DMHS DDL 触发器和辅助表也不需要创建。
  3. 归档清理配置项,clear_flag 为 1 表示清除,即DMHS 将同步完成的归档文件删除;
    为2,表示将同步完成的归档移到 bak_dir 目录下;为0,表示不作任何操作。
  4. 过滤配置项,本示例配置了白名单,即 enable,也可以配置黑名单,详见 DMHS
    用户手册。其过滤的规则是:先判断白名单,然后判断黑名单。如果存在重叠的情况,那么
    也是会被过滤的。
  5. 映射配置项,表示存在不同模式之间的表同步,例如本示例中源端的 SYSDBA 模
    式下的表映射成目的端的DMHS 模式下同名的表。
    源端和目标端配置环境变量
    [root@dm001 ~]# cat .bash_profile
    export PATH
    export LD_LIBRARY_PATH=“$LD_LIBRARY_PATH:/dmdbms/dm8/bin:$DMHS_HOME/bin:$DMHS_HOME/db/bin”
    export DM_HOME=“/dmdbms/dm8”
    export PATH=$DM_HOME/bin:$DM_HOME/tool:$PATH:$DMHS_HOME/bin:$DMHS_HOME/db/bin
    export DMHS_HOME=/home/dmdba/dmhs
    export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$DMHS_HOME/bin:$DMHS_HOME/db/bin
    [root@dm001 ~]#
    启动dmhs服务
    目标端
    [root@dms1 tool]# cd /home/dmdba/dmhs/bin
    [root@dms1 bin]# ./dmhs_server dmhs.hs
    image.png
    源端
    [root@dm001 ~]# cd /home/dmdba/dmhs/bin
    [root@dm001 bin]# ./dmhs_server dmhs.hs
    image.png
    初始装载
    初始装载是将源端数据库中的初始数据装载到目的端数据库,使 DMHS 同步的时刻源 和目的端的同步表数据一致。装载前源端 DMHS 服务和目的端DMHS 服务都需要开启。本实验的目的端 DMHS 使用的是和源端相同环境的 DM8 数据库。
    目标端
    [root@dms1 bin]# ./dmhs_console
    image.png
    源端:
    image.png
    注:初始装载
    DMHS >copy 0 “sch.name=‘SYSDBA’” DICT|LSN|CREATE|INSERT|INDEX
    说明:sch.name 为模式名。
    测试同步
    源端查看test_ljk并插入新的数据
    image.png
    目标端查看test_ljk,可看到成功同步数据
    image.png
    至此,DMHS部署完成!
    源端和目标端DMHS注册服务
    [root@dm001 bin]# cd /home/dmdba/dmhs/scripts/root
    [root@dm001 root]# ./dmhs_service_installer.sh -t dmhs_server -a true -p HMS -x /home/dmdba/dmhs/bin/dmhs.hs -d /home/dmdba/dmhs/bin
    Created symlink /etc/systemd/system/multi-user.target.wants/DmhsServiceHMS.service → /usr/lib/systemd/system/DmhsServiceHMS.service.
    创建服务(DmhsServiceHMS)完成
    [root@dm001 root]# cd /home/dmdba/dmhs/bin/
    [root@dm001 bin]# ./DmhsServiceHMS start
    遇到的问题
    执行clear exec lsn
    image.png
    需要dm到dm的oci文件libdmoci.so,dmhs安装好以后放置在bin目录下,
    [dmdba@dm001 bin]$ pwd
    /home/dmdba/dmhs/bin
    [dmdba@dm001 bin]$ ll libdmoci.so
    -rw-r–r-- 1 root root 10397703 Nov 22 15:29 libdmoci.so
    [dmdba@dm001 bin]$
评论
后发表回复

作者

文章

阅读量

获赞

扫一扫
联系客服