达梦8数据库单机转主备集群参考文档

  • Post author:
  • Post category:其他



达梦数据单机转守护集群搭建



  1. 部署前准备


    1. 集群规划

部署达梦数据库数据守护集群前,应当先对现场的网络及系统环境等进行统一规划,这里为了方便结合实例进行阐述。


A


机器


B


机器


业务


IP

192.168.33.160

192.168.33.170


心跳


IP

192.168.33.191

192.168.33.192


实例名

DW1_01

DW1_01B


实例端口

5236

5236


MAL


端口

5336

5336


MAL


守护进程端口

5436

5436


守护进程端口

5536

5536


OGUID

45331


守护组

GDW1


安装目录

/home/dmdba/dmdbms


实例目录

/home/dmdba/dmdbms/data/


归档上限

51200


确认监视器


IP

192.168.33.170

说明:具体规划及部署方式以现场环境为准。










    1. 硬件环境建议


心跳网络方面:

①集群间的心跳网络要走数据,最好走两个交换机,来实现冗余和负载均衡





②需要把服务器多个心跳网卡绑定为一个逻辑网卡来使用(比如bond方式)。③交换机速度建议至少为千兆。


存储方面:

①需要在每台机器上挂在独立存储,其中主机所在机器挂载的存储建议大一些。②需要格式化好,且所有机器挂载路径保持一致。③在空间不够用时,要求支持在挂载目录上直接进行扩充。④文件系统建议使用ext4。










    1. 硬件环境环境验证


心跳网络方面:

①关闭其中一台交换机或者模拟其中一条线路故障,是否能做到网络方面的冗余。②测试心跳网络的稳定性,会不会出现断连或者丢包等情况。


存储方面:

反复重启集群机器,检查存储是否会出现只读、脱挂、挂载路径是否会发生改变等情况。


    1. 操作系统配置

详细内容请参考《操作系统环境准备》。


    1. 安装达梦数据库

详细内容请参考《数据库软件的安装》。(主备机都需要安装达梦单机)


  1. 单机转主备集群搭建(

    DM8两节点V4.0自动切换模式)








    1. 配置A

      (有数据的)机器








      1. 数据

        备份





修改dm.ini

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参数值应当与集群规划的主机实例名相同


此外,生产环境上还应设置重演日志的相关参数:


  1. REDOS_BUF_SIZE


    :待重演日志堆积的内存限制,堆积的日志缓冲区占用内存超过此限制,则新的日志将会被延迟加入重演队列,等待重演释放部分内存后再加入。

  2. REDOS_BUF_NUM


    :待重演日志缓冲区允许堆积的数目限制,超过限制则新的日志将会被延迟加入重演队列,等待堆积数减少后再加入。

  3. REDOS_MAX_DELAY


    :备库重演日志缓冲区的时间限制,超过此限制则认为重演异常,服务器自动宕机,防止日志堆积、主库不能及时响应用户请求。


注意:


REDOS_BUF_SIZE





REDOS_BUF_NUM


同时起作用,只要达到一个条件即会触发延迟处理。


以上参数建议值如下:


SP_SET_PARA_VALUES(2,’REDO_BUF_NUM’,9999);


SP_SET_PARA_VALUES(2,’REDOS_BUF_SIZE’,10240);


SP_SET_PARA_VALUES(2,’REDOS_MAX_DELAY’,180);

更多参数详细内容请参照《系统管理员手册》,手册位于$DM_HOME/doc目录下。

–关闭前台实例服务。








      1. 替换dmarch.ini

[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  #实时归档目标实例名








      1. 创建dmmal.ini

[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


MAL_INST_DW_PORT         = 5536








      1. 创建dmwatcher.ini

[dmdba@~]# vi /data/dmdata/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                = /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


文件。







      1. 拷贝实例

[dmdba@~]# scp -r /data/dmdata/DAMENG dmdba@192.168.33.170:/data/dmdata/








      1. 注册服务

[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








    1. 配置B

      机器








      1. 修改dm.ini

[dmdba@~]# vi /data/dmdata/DAMENG/dm.ini

INSTANCE_NAME              = DW1_01B  #数据库实例名








      1. 替换dmarch.ini

[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  #实时归档目标实例名








      1. 配置

        dmmal.ini,dmwatcher.ini相同配置文件

与A机器DW1_01的dmmal.ini、dmwatcher.ini相同。








      1. 注册服务

[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








      1. 恢复数据

        (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;








    1. 配置监视器


  1. 在各节点数据库的


    bin




    目录中




    存放非确认监视器配置文件。



注意:建议在各节点上至少防止一个非确认监视器,以免确认监视器机器故障时,无法进行及时切机。



  1. 确认监视器

    机器上(非集群节点) 注册确认监视器自启服务。








      1. 创建dmmonitor.ini

[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








      1. 注册服务

[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








      1. 监视器使用


命令


含义

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:不可接管】










    1. 启动服务及查看信息










      1. 启动数据库并修改参数









      2. 启动守护进程


–A


机器

[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;


–B


机器

[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










      1. 启动监视器

[dmdba@~]# /home/dmdba/dmdbms/bin/DmMonitorServiceMonitor start

前台启动:[dmdba@~]# /home/dmdba/dmdbms/bin/dmmonitor /home/dmdba/dmdbms/bin/dmmonitor.ini










      1. 启停集群


启动:

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








  1. 配置应用连接

在/etc目录下会自动生成集群的dm_svc.conf配置文件,请自行复制它到客户端机器的相关目录下:

Linux环境:dm_svc.conf放在应用服务器/etc目录下。

Windows32环境:dm_svc.conf放在应用服务器System32目录下。

Windows64环境:dm_svc.conf放在应用服务器System32和SysWOW64目录下。








    1. 创建dm_svc.conf

[root@~]# vi /etc/dm_svc.conf

TIME_ZONE=(+8:00)

LANGUAGE=(cn)


DW1=(192.168.33.160:5236,192.168.33.170:5236)


[DW1]


LOGIN_MODE=(1)


SWITCH_TIME=(300)


SWITCH_INTERVAL=(200)

相关参数说明请查询手册。








    1. JDBC

      应用连接

使用对应的DM的jdbc驱动,然后URL改为数据守护服务名连接。

<DRIVER>dm.jdbc.driver.DmDriver</DRIVER>

<URL>jdbc:dm://DW1</URL>


达梦数据库 – 新一代大型通用关系型数据库 | 达梦在线服务平台 (dameng.com)



版权声明:本文为weixin_49512910原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。