注册
达梦数据库主备搭建
培训园地/ 文章详情 /

达梦数据库主备搭建

王靖文 2022/11/09 1375 0 0

1安装前准备
1.1集群规划
A机器 B机器
业务IP 192.168.1.12 192.168.1.13
心跳IP 192.168.1.12 192.168.1.13
实例名 DMSVR01 DMSVR02
实例端口 5237 5237
MAL端口 5336 5336
MAL守护进程端口 5436 5436
守护进程端口 5536 5536
OGUID 45331
守护组 GDW1
安装目录 /dm8/data
实例目录 /dm8/data/data
归档上限 51200
确认监视器IP 192.168.1.14
说明:具体规划及部署方式以现场环境为准。

1.2集群架构

1.3硬件环境建议
心跳网络方面:①集群间的心跳网络要走数据,最好走两个交换机,来实现冗余和负载均衡。②需要把服务器多个心跳网卡绑定为一个逻辑网卡来使用(比如bond方式)。③交换机速度建议至少为千兆。
存储方面:①需要在每台机器上挂在独立存储,其中主机所在机器挂载的存储建议大一些。②需要格式化好,且所有机器挂载路径保持一致。③在空间不够用时,要求支持在挂载目录上直接进行扩充。④文件系统建议使用ext4。

1.4硬件环境环境验证
心跳网络方面:①关闭其中一台交换机或者模拟其中一条线路故障,是否能做到网络方面的冗余。②测试心跳网络的稳定性,会不会出现断连或者丢包等情况。
存储方面:反复重启集群机器,检查存储是否会出现只读、脱挂、挂载路径是否会发生改变等情况。

2配置A机器
2.1开启归档,修改dm.ini参数
–修改dm.ini
SQL> SP_SET_PARA_VALUE (2,‘PORT_NUM’,5237);
SQL> SP_SET_PARA_VALUE (2,‘DW_INACTIVE_INTERVAL’,60);
SQL> SP_SET_PARA_VALUE (2,‘ALTER_MODE_STATUS’,0);
SQL> SP_SET_PARA_VALUE (2,‘ENABLE_OFFLINE_TS’,2);
SQL> SP_SET_PARA_VALUE (2,‘MAL_INI’,1);
SQL> SP_SET_PARA_VALUE (2,‘RLOG_SEND_APPLY_MON’,64);
关闭前台实例服务

2.2替换dmarch.ini
[dmdba@~]# vi /dm8/data/data/DAMENG/dmarch.ini
[ARCHIVE_LOCAL]
ARCH_TYPE = LOCAL #本地归档类型
ARCH_DEST = /data/dmdbms/data/DAMENG/arch/ #本地归档存放路径
ARCH_FILE_SIZE = 1024 #单个归档大小,单位MB
ARCH_SPACE_LIMIT = 51200 #归档上限,单位MB
[ARCHIVE_REALTIME]
ARCH_TYPE = REALTIME #实时归档类型
ARCH_DEST = DMSVR02 #实时归档目标实例名

2.3创建dmmal.ini
[dmdba@~]# vi /dm8/data/data/DAMENG/dmmal.ini
MAL_CHECK_INTERVAL = 10 #MAL链路检测时间间隔
MAL_CONN_FAIL_INTERVAL = 10 #判定MAL链路断开的时间
MAL_TEMP_PATH = /dm8/data/data/malpath/ #临时文件目录
MAL_BUF_SIZE = 512 #单个MAL缓存大小,单位MB
MAL_SYS_BUF_SIZE = 2048 #MAL总大小限制,单位MB
MAL_COMPRESS_LEVEL = 0 #MAL消息压缩等级,0表示不压缩

[MAL_INST1]
MAL_INST_NAME = DMSVR01 #实例名,和 dm.ini的INSTANCE_NAME一致
MAL_HOST = 192.168.1.12 #MAL系统监听TCP连接的IP地址
MAL_PORT = 5336 #MAL系统监听TCP连接的端口
MAL_INST_HOST = 192.168.1.12 #实例的对外服务IP地址
MAL_INST_PORT = 5237 #实例对外服务端口,和dm.ini的PORT_NUM一致
MAL_DW_PORT = 5436 #实例对应的守护进程监听TCP连接的端口
MAL_INST_DW_PORT = 5536 #实例监听守护进程TCP连接的端口
[MAL_INST2]
MAL_INST_NAME = DMSVR02
MAL_HOST = 192.168.1.13
MAL_PORT = 5336
MAL_INST_HOST = 192.168.1.13
MAL_INST_PORT = 5237
MAL_DW_PORT = 5436
MAL_INST_DW_PORT = 5536

2.4创建dmwatcher.ini
[dmdba@~]# vi /dm8/data/data/DAMENG/dmwatcher.ini
[GDW1]
DW_TYPE = GLOBAL #全局守护类型
DW_MODE = AUTO #故障自动切换模式
DW_ERROR_TIME = 20 #远程守护进程故障认定时间
INST_ERROR_TIME = 20 #本地实例故障认定时间
INST_RECOVER_TIME = 60 #主库守护进程启动恢复的间隔时间
INST_OGUID = 45331 #守护系统唯一OGUID值
INST_INI = /dm8/data/data/DAMENG/dm.ini #dm.ini文件路径
INST_AUTO_RESTART = 1 #打开实例的自动启动功能
INST_STARTUP_CMD = /dm8/data/bin/dmserver #命令行方式启动
RLOG_SEND_THRESHOLD = 0 #指定主库发送日志到备库的时间阈值,默认关闭
RLOG_APPLY_THRESHOLD = 0 #指定备库重演日志的时间阈值,默认关闭

2.5拷贝实例
[dmdba@~]# scp -r /dm8/data/data/DAMENG dmdba@192.168.1.13:/dm8/data/data/

2.6注册服务
[root@~]# /dm8/data/script/root/dm_service_installer.sh -t dmserver -p DMSVR01 -dm_ini /dm8/data/data/DAMENG/dm.ini -m mount
[root@~]# /dm8/data/script/root/dm_service_installer.sh -t dmwatcher -p Watcher -watcher_ini /dm8/data/data/DAMENG/dmwatcher.ini
备注:删除自启
[root@~]# /dm8/data/script/root/dm_service_uninstaller.sh -n DmServiceDMSVR01
[root@~]# /dm8/data/script/root/dm_service_uninstaller.sh -n DmWatcherServiceWatcher

3配置B机器
3.1修改dm.ini
[dmdba@~]# vi /dm8/data/data/DAMENG/dm.ini
INSTANCE_NAME = DMSVR02 #数据库实例名

3.2替换dmarch.ini
[dmdba@~]# vi /dm8/data/data/DAMENG/dmarch.ini
[ARCHIVE_LOCAL]
ARCH_TYPE = LOCAL #本地归档类型
ARCH_DEST = /dm8/arch #本地归档存放路径
ARCH_FILE_SIZE = 1024 #单个归档大小,单位MB
ARCH_SPACE_LIMIT = 51200 #归档上限,单位MB
[ARCHIVE_REALTIME]
ARCH_TYPE = REALTIME #实时归档类型
ARCH_DEST = DMSVR01 #实时归档目标实例名

3.3相同配置项
与A机器DW1_01的dmmal.ini、dmwatcher.ini相同

3.4注册服务
[root@~]# /dm8/data/script/root/dm_service_installer.sh -t dmserver -p DMSVR02 -dm_ini /dm8/data/data/DAMENG/dm.ini -m mount
[root@~]# /dm8/data/script/root/dm_service_installer.sh -t dmwatcher -p Watcher -watcher_ini /dm8/data/data/DAMENG/dmwatcher.ini
备注:删除自启
[root@~]# /dm8/data/script/root/dm_service_uninstaller.sh -n DmServiceDMSVR02
[root@~]# /dm8/data/script/root/dm_service_uninstaller.sh -n DmWatcherServiceWatcher
[dmdba@~]# /dm8/data/data/bin/dmrman CTLSTMT=“RESTORE DATABASE ‘/dm8/data/data/DAMENG/dm.ini’ FROM BACKUPSET ’ /dm8/data/data/DAMENG/bak/DB_DAMENG_FULL_20221030_084146_569151/'”
[dmdba@~]# /dm8/data/bin/dmrman CTLSTMT=“RECOVER DATABASE ‘/dm8/data/data/DAMENG/dm.ini’ FROM BACKUPSET ’ /dm8/data/data/DAMENG/bak/DB_DAMENG_FULL_20221030_084146_569151/'”
[dmdba@~]# /dm8/data/bin/dmrman CTLSTMT=“RECOVER DATABASE ‘/dm8/data/data/DAMENG/dm.ini’ UPDATE DB_MAGIC”

4配置监视器
1、在各节点数据库的bin目录中 存放非确认监视器配置文件。
2、在确认监视器机器上(非集群节点) 注册确认监视器自启服务。
通常我们是把确认监视器注册成服务后台运行,前台则启动一个非确认监视器用来查看数据库状态信息
4.1创建dmmonitor.ini
[dmdba@~]# vi /dm8/data/dmmonitor_0.ini
MON_DW_CONFIRM = 0 #0为非确认,1为确认
MON_LOG_PATH = /dm8/data/bin/log #监视器日志文件存放路径
MON_LOG_INTERVAL = 60 #每隔 60s 定时记录系统信息到日志文件
MON_LOG_FILE_SIZE = 512 #单个日志大小,单位MB
MON_LOG_SPACE_LIMIT = 2048 #日志上限,单位MB

[GDW1]
MON_INST_OGUID = 45331 #组GDW1的唯一OGUID 值
MON_DW_IP = 192.168.1.12:5436 #IP对应MAL_HOST,PORT对应MAL_DW_PORT
MON_DW_IP = 192.168.1.13:5436

4.2注册服务
[root@~]# /dm8/data/script/root/dm_service_installer.sh -t dmmonitor -p Monitor -monitor_ini /dm8/data/bin/dmmonitor.ini
备注:删除自启
[root@~]# /dm8/data/script/root/dm_service_uninstaller.sh -n DmMonitorServiceMonitor

4.3监视器使用
命令 含义
list 查看守护进程的配置信息
show global info 查看所有实例组的信息
tip 查看系统当前运行状态
login 登录监视器
logout 退出登录
choose switchover GDW1 主机正常:查看可切换为主机的实例列表
switchover GDW1.实例名 主机正常:使用指定组的指定实例,切换为主机
choose takeover GDW1 主机故障:查看可切换为主机的实例列表
takeover GDW1.实例名 主机故障:使用指定组的指定实例,切换为主机
choose takeover force GDW1 强制切换:查看可切换为主机的实例列表
takeover force GDW1.实例名 强制切换:使用指定组的指定实例,切换为主机
主机故障后,在备机执行SELECT SF_DW_CHECK_TAKEOVER();【1:可接管 0:不可接管】

5启动服务及查看信息
5.1启动数据库并修改参数
A机器
[dmdba@~]# /dm8/data/bin/DmServiceDMSVR01 start
[dmdba@~]# /dm8/data/bin/disql SYSDBA/DM01SYSDBA@192.168.1.12:5237
SQL> SP_SET_OGUID(45331);
SQL> ALTER DATABASE PRIMARY;

B机器
[dmdba@~]# /dm8/data/bin/DmServiceDMSVR02 start
[dmdba@~]# /dm8/data/bin/disql SYSDBA/DM01SYSDBA@192.168.1.13:5237
SQL> SP_SET_OGUID(45331);
SQL> ALTER DATABASE STANDBY;

5.2启动守护进程
A/B机器:[dmdba@~]# /dm8/data/bin/DmWatcherServiceWatcher start

5.3启动监视器
关于达梦监视器dmmonitor
https://blog.csdn.net/weixin_52843944/article/details/118192331
[dmdba@~]# /dm8/data/bin/DmMonitorServiceMonitor start
前台启动:[dmdba@~]# /dm8/data/bin/dmmonitor /dm8/data/bin/dmmonitor.ini
tip查看系统当前运行状态

5.4启停集群
启动:A/B机器守护进程
A/B机器:[dmdba@~]# /dm8/data/bin/DmWatcherServiceWatcher start

停止:A/B机器守护进程→A机器DW1_01主库→B机器DW1_01B备库
A/B机器:[dmdba@~]# /data/dmdbms/bin/DmWatcherServiceWatcher stop
A机器:[dmdba@~]# /data/dmdbms/bin/DmServiceDW1_01 stop
B机器:[dmdba@~]# /data/dmdbms/bin/DmServiceDW1_01B stop

6手动切换主备库
确认主备集群服务状态正常,确认监视器已启动。
主库服务,数据守护状态:
[dmdba@localhost ~]$ ps -ef|grep dms
[dmdba@localhost ~]$ ps -ef|grep dmw

备库服务,数据守护状态:
[dmdba@localhost ~]$ ps -ef|grep dms
[dmdba@localhost ~]$ ps -ef|grep dmw

确认监视器状态:
[dmdba@localhost ~]$ ps -ef|grep dmm

前台方式启动监视器:
[dmdba@localhost bin]$ cd /dm8/data/bin
[dmdba@localhost bin]$ ./dmmonitor dmmonitor.ini
可以看到DM1是主库,DM2是备库,主备集群状态正常

进行手动主备切换:
login
用户名:
密码:
switchover GDW1.DMSVR02

查看主备状态已切换成功

查看此时DMSVR01为备库,DMSVR02是主库

评论
后发表回复

作者

文章

阅读量

获赞

扫一扫
联系客服