达梦数据单机转守护集群搭建
部署达梦数据库数据守护集群前,应当先对现场的网络及系统环境等进行统一规划,这里为了方便结合实例进行阐述。
|
|
|
|
192.168.33.160 |
192.168.33.170 |
|
192.168.33.191 |
192.168.33.192 |
|
DW1_01 |
DW1_01B |
|
5236 |
5236 |
|
5336 |
5336 |
|
5436 |
5436 |
|
5536 |
5536 |
|
45331 |
|
|
GDW1 |
|
|
/home/dmdba/dmdbms |
|
|
/home/dmdba/dmdbms/data/ |
|
|
51200 |
|
|
192.168.33.170 |
说明:具体规划及部署方式以现场环境为准。
心跳网络方面:
①集群间的心跳网络要走数据,最好走两个交换机,来实现冗余和负载均衡
。
②需要把服务器多个心跳网卡绑定为一个逻辑网卡来使用(比如bond方式)。③交换机速度建议至少为千兆。
存储方面:
①需要在每台机器上挂在独立存储,其中主机所在机器挂载的存储建议大一些。②需要格式化好,且所有机器挂载路径保持一致。③在空间不够用时,要求支持在挂载目录上直接进行扩充。④文件系统建议使用ext4。
心跳网络方面:
①关闭其中一台交换机或者模拟其中一条线路故障,是否能做到网络方面的冗余。②测试心跳网络的稳定性,会不会出现断连或者丢包等情况。
存储方面:
反复重启集群机器,检查存储是否会出现只读、脱挂、挂载路径是否会发生改变等情况。
详细内容请参考《操作系统环境准备》。
详细内容请参考《数据库软件的安装》。(主备机都需要安装达梦单机)
-
单机转主备集群搭建(
DM8两节点V4.0自动切换模式)
SQL> SP_SET_PARA_VALUE (2,’PORT_NUM’,5236); 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);
RMAN> backup database ‘/data/dmdata/DAMENG/dm.ini’ backupset ‘/data/full’;
—把备份拷贝到备机
注:主机的dm.ini文件INSTANCE_NAME参数值应当与集群规划的主机实例名相同 |
此外,生产环境上还应设置重演日志的相关参数:
-
REDOS_BUF_SIZE
:待重演日志堆积的内存限制,堆积的日志缓冲区占用内存超过此限制,则新的日志将会被延迟加入重演队列,等待重演释放部分内存后再加入。
-
REDOS_BUF_NUM
:待重演日志缓冲区允许堆积的数目限制,超过限制则新的日志将会被延迟加入重演队列,等待堆积数减少后再加入。
-
REDOS_MAX_DELAY
:备库重演日志缓冲区的时间限制,超过此限制则认为重演异常,服务器自动宕机,防止日志堆积、主库不能及时响应用户请求。
注意:
REDOS_BUF_SIZE
和
REDOS_BUF_NUM
同时起作用,只要达到一个条件即会触发延迟处理。
以上参数建议值如下:
|
更多参数详细内容请参照《系统管理员手册》,手册位于$DM_HOME/doc目录下。
–关闭前台实例服务。
[dmdba@~]# vi /data/dmdata/DAMENG/dmarch.ini [ARCHIVE_LOCAL] ARCH_TYPE = LOCAL #本地归档类型 ARCH_DEST = /data/dmdata/DAMENG/arch/ #本地归档存放路径 ARCH_FILE_SIZE = 1024 #单个归档大小,单位MB ARCH_SPACE_LIMIT = 51200 #归档上限,单位MB [ARCHIVE_REALTIME] ARCH_TYPE = REALTIME #实时归档类型 ARCH_DEST = DW1_01B #实时归档目标实例名
|
[dmdba@~]# vi /data/dmdata/DAMENG/dmmal.ini MAL_CHECK_INTERVAL = 10 #MAL链路检测时间间隔 MAL_CONN_FAIL_INTERVAL = 10 #判定MAL链路断开的时间 MAL_TEMP_PATH = /home/dmdba/dmdbms/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 = DW1_01 #实例名,和 dm.ini的INSTANCE_NAME一致 MAL_HOST = 192.168.33.191 #MAL系统监听TCP连接的IP地址 MAL_PORT = 5336 #MAL系统监听TCP连接的端口 MAL_INST_HOST = 192.168.33.160 #实例的对外服务IP地址 MAL_INST_PORT = 5236 #实例对外服务端口,和dm.ini的PORT_NUM一致 MAL_DW_PORT = 5436 #实例对应的守护进程监听TCP连接的端口 MAL_INST_DW_PORT = 5536 #实例监听守护进程TCP连接的端口 [MAL_INST2] MAL_INST_NAME = DW1_01B MAL_HOST = 192.168.33.192 MAL_PORT = 5336 MAL_INST_HOST = 192.168.33.170 MAL_INST_PORT = 5236 MAL_DW_PORT = 5436
|
[dmdba@~]# vi /data/dmdata/DAMENG/dmwatcher.ini [GDW1] DW_TYPE = GLOBAL #全局守护类型
DW_MODE = DW_ERROR_TIME = 20 #远程守护进程故障认定时间 INST_ERROR_TIME = 20 #本地实例故障认定时间 INST_RECOVER_TIME = 60 #主库守护进程启动恢复的间隔时间 INST_OGUID = 45331 #守护系统唯一OGUID值 INST_INI = /data/dmdata/DAMENG/dm.ini #dm.ini文件路径 INST_AUTO_RESTART = 1 #打开实例的自动启动功能 INST_STARTUP_CMD = /home/dmdba/dmdbms/bin/dmserver #命令行方式启动 RLOG_SEND_THRESHOLD = 0 #指定主库发送日志到备库的时间阈值,默认关闭 RLOG_APPLY_THRESHOLD = 0 #指定备库重演日志的时间阈值,默认关闭
|
注意:DM8里不在生成
dmwatcher.ctl
文件。
[dmdba@~]# scp -r /data/dmdata/DAMENG dmdba@192.168.33.170:/data/dmdata/ |
[root@~]# /home/dmdba/dmdbms/script/root/dm_service_installer.sh -t dmserver -p DW1_01 -dm_ini /data/dmdata/DAMENG/dm.ini -m mount [root@~]# /home/dmdba/dmdbms/script/root/dm_service_installer.sh -t dmwatcher -p Watcher -watcher_ini /data/dmdata/DAMENG/dmwatcher.ini
|
备注:删除自启(不需要做)
[root@~]# /home/dmdba/dmdbms/script/root/dm_service_uninstaller.sh -n DmServiceDW1_01
[root@~]#/ home/dmdba/dmdbms/script/root/dm_service_uninstaller.sh -n DmWatcherServiceWatcher
|
[dmdba@~]# vi /data/dmdata/DAMENG/dm.ini INSTANCE_NAME = DW1_01B #数据库实例名 |
[dmdba@~]# vi /data/dmdata/DAMENG/dmarch.ini [ARCHIVE_LOCAL] ARCH_TYPE = LOCAL #本地归档类型 ARCH_DEST = /data/dmdata/DAMENG/arch/ #本地归档存放路径 ARCH_FILE_SIZE = 1024 #单个归档大小,单位MB ARCH_SPACE_LIMIT = 51200 #归档上限,单位MB [ARCHIVE_REALTIME] ARCH_TYPE = REALTIME #实时归档类型 ARCH_DEST = DW1_01 #实时归档目标实例名 |
-
-
-
配置
dmmal.ini,dmwatcher.ini相同配置文件
-
-
与A机器DW1_01的dmmal.ini、dmwatcher.ini相同。
[root@~]# /home/dmdba/dmdbms/script/root/dm_service_installer.sh -t dmserver -p DW1_01B -dm_ini /data/dmdata/DAMENG/dm.ini -m mount [root@~]# /home/dmdba/dmdbms/script/root/dm_service_installer.sh -t dmwatcher -p Watcher -watcher_ini /data/dmdata/DAMENG/dmwatcher.ini
|
备注:删除自启(此处不做)
[root@~]# /home/dmdba/dmdbms/script/root/dm_service_uninstaller.sh -n DmServiceDW1_01B [root@~]# /home/dmdba/dmdbms/script/root/dm_service_uninstaller.sh -n DmWatcherServiceWatcher
|
-
-
-
恢复数据
(dmap服务需要是启动着的)
-
-
RMAN> restore database ‘/data/dmdata/DAMENG/dm.ini’ from backupset ‘/data/full’; RMAN> recover database ‘/data/dmdata/DAMENG/dm.ini’ from backupset ‘/data/full’;
RMAN> recover database ‘/data/dmdata/DAMENG/dm.ini’ update db_magic;
|
-
在各节点数据库的
bin
目录中
存放非确认监视器配置文件。
注意:建议在各节点上至少防止一个非确认监视器,以免确认监视器机器故障时,无法进行及时切机。
-
在
确认监视器
机器上(非集群节点) 注册确认监视器自启服务。
[dmdba@~]# vi /home/dmdba/dmdbms/bin/dmmonitor.ini MON_DW_CONFIRM = 1 #0为非确认,1为确认 MON_LOG_PATH = ../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.33.191:5436 #IP对应MAL_HOST,PORT对应MAL_DW_PORT MON_DW_IP = 192.168.33.192:5436 |
[root@~]# /home/dmdba/dmdbms/script/root/dm_service_installer.sh -t dmmonitor -p Monitor -monitor_ini /home/dmdba/dmdbms/bin/dmmonitor.ini
|
备注:删除自启(此处不做)
[root@~]# /home/dmdba/dmdbms/script/root/dm_service_uninstaller.sh -n DmMonitorServiceMonitor
|
|
|
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:不可接管】 |
[dmdba@~]# /home/dmdba/dmdbms/bin/DmServiceDW1_01 start [dmdba@~]# /home/dmdba/dmdbms/bin/disql SYSDBA/SYSDBA@192.168.33.160:5236 SQL> SP_SET_OGUID(45331); SQL> ALTER DATABASE PRIMARY;
SP_SET_OGUID(45331); ALTER DATABASE PRIMARY;
[dmdba@~]# /home/dmdba/dmdbms/bin/DmServiceDW1_01B start [dmdba@~]# /home/dmdba/dmdbms/bin/disql SYSDBA/SYSDBA@192.168.33.170:5236 SQL> SP_SET_OGUID(45331); SQL> ALTER DATABASE STANDBY;
SP_SET_OGUID(45331); ALTER DATABASE STANDBY;
|
A/B机器:[dmdba@~]# /home/dmdba/dmdbms/bin/DmWatcherServiceWatcher start
|
[dmdba@~]# /home/dmdba/dmdbms/bin/DmMonitorServiceMonitor start
前台启动:[dmdba@~]# /home/dmdba/dmdbms/bin/dmmonitor /home/dmdba/dmdbms/bin/dmmonitor.ini |
启动:
A/B机器守护进程
A/B机器:[dmdba@~]# /home/dmdba/dmdbms/bin/DmWatcherServiceWatcher start
|
停止:
A/B机器守护进程→A机器DW1_01主库→B机器DW1_01B备库
A/B机器:[dmdba@~]# /home/dmdba/dmdbms/bin/DmWatcherServiceWatcher stop A机器:[dmdba@~]# /home/dmdba/dmdbms/bin/DmServiceDW1_01 stop B机器:[dmdba@~]# /home/dmdba/dmdbms/bin/DmServiceDW1_01B stop |
在/etc目录下会自动生成集群的dm_svc.conf配置文件,请自行复制它到客户端机器的相关目录下:
Linux环境:dm_svc.conf放在应用服务器/etc目录下。
Windows32环境:dm_svc.conf放在应用服务器System32目录下。
Windows64环境:dm_svc.conf放在应用服务器System32和SysWOW64目录下。
[root@~]# vi /etc/dm_svc.conf TIME_ZONE=(+8:00) LANGUAGE=(cn)
|
相关参数说明请查询手册。
-
-
JDBC
应用连接
-
使用对应的DM的jdbc驱动,然后URL改为数据守护服务名连接。
<DRIVER>dm.jdbc.driver.DmDriver</DRIVER> <URL>jdbc:dm://DW1</URL> |
达梦数据库 – 新一代大型通用关系型数据库 | 达梦在线服务平台 (dameng.com)