达梦数据库主备

注意
目前最多支持 1 主 8 备、主机可读写、备机只读。实际部署中可选择实时主备方式和异步主备方式,我们建议在主备机间网络延时较低的场合(例如同机房或者专线)使用实时主备,否则选用采用异步主备方式。


主备库、监视器三机安装数据库软件,主备库初始化数据库
1、开启归档日志,配置远程归档
2、修改主库参数

3、主备库修改配置文件

4、主备库dawacher

5、配置dmmonitor监视器

6、注册服务

7、设置开机启动

8、提供对外服务

准备工作

服务器硬件需求
按实际业务需求,选择合适的服务器,准备 3 台服务器,一台主库服务器,一台备库服务器,一台监视器服务器,服务器参数建议如下:

 
 警告:守护进程配置自动切换时,必须在监视器服务器上配置确认监视器,并且保证网络高可用。
系统要求
DM 数据库安装在 Linux 操作系统所需条件:glibc 2.3 以上,内核 2.6,预先安装 UnixODBC,系统性能监控等组件。

                          
网络要求
主、备、确认监视器之间要求所有端口都开放(4*2个)
对外服务集群只开放数据库端口(2个)

用户和组
DM 数据库不应该使用 root 用户安装和维护。需要在安装之前为 DM 数据库创建一个专用的系统用户 (dmdba) 和用户组 (dinstall)。
groupadd dinstall                            #####新建用户组 dinstall
useradd  -g dinstall -m -d /home/dmdba -s /bin/bash  dmdba        #####新建用户 dmdba
passwd dmdba                            #######修改 dmdba 用户密码。

vi /etc/security/limits.conf                        #######修改 dmdba 用户资源限制
dmdba soft core unlimited
dmdba hard core unlimited
dmdba soft nofile 65536
dmdba hard nofile 65536
dmdba soft nproc  65536
dmdba hard nproc  65536
dmdba soft stack  65536
dmdba hard stack  65536

vi /etc/systemd/system.conf                ######当数据库服务以server或者systemctl启动时,以此限制为主,重启方可生效
DefaultLimitNPROC=65535
DefaultLimitNOFILE=65535

vi /etc/sysctl.conf                     ######内存参数检查
新增
vm.overcommit_memory=0
sysctl -p 使配置文件生效。


 vi /home/dmdba/.bash_profile                    #########修改环境变量
export DM_HOME=/home/dmdba/dmdbms
export PATH=$PATH:$DM_HOME/bin
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$DM_HOME/bin
 

数据库安装


三机均安装数据库软件,主备库初始化数据库实例

主备库初始化数据

./dminit path=/home/dmdba/dmdbms db_name=dmrw page_size=32
注意
初始化的实例必须先启动一次,才能脱机备份
ps -ef|grep dmap
  
./DmAPService start        ######启动 dmap 服务
关闭主数据库后,使用 dmrman 工具脱机备份主库,dmdba 用户到安装目录的 bin 下执行以下命令:
 ./dmrman CTLSTMT="BACKUP DATABASE  '/home/dmdba/dmdbms/dmrw/dm.ini'  FULL TO BACKUP_FILE1 BACKUPSET '/home/dmdba/bakfull'"
scp -r /home/dmdba/bakfull 备库IP:/home/dmdba        #####传输备份
关闭备数据库
./dmrman CTLSTMT="RESTORE DATABASE '/home/dmdba/dmdbms/dmrw/dm.ini'  FROM BACKUPSET '/home/dmdba/bakfull'"
./dmrman CTLSTMT="RECOVER DATABASE '/home/dmdba/dmdbms/dmrw/dm.ini'  FROM BACKUPSET '/home/dmdba/bakfull'"
./dmrman CTLSTMT="RECOVER DATABASE '/home/dmdba/dmdbms/dmrw/dm.ini'  UPDATE DB_MAGIC"

主备库配置文件

修改主库dm.ini参数
INSTANCE_NAME = dmrw1            #####修改实例名
MAL_INI = 1                    #####开启MAL系统
ARCH_INI = 1                    #####开启归档    
ALTER_MODE_STATUS = 0            #####    不允许手动修改实例模式/状态/OGUID
ENABLE_OFFLINE_TS = 2                #####不允许备库offline表空间
 修改备库dm.ini参数
INSTANCE_NAME = dmrw2
MAL_INI = 1
ARCH_INI = 1
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2

配置主库dmarch.ini(新建ini文件,若开启归档配置,则可直接修改ini文件)
vi /home/dmdba/dmdbms/dmrw/dmarch.ini

 [ARCHIVE_REALTIME]
ARCH_TYPE     = REALTIME              #实时归档类型
ARCH_DEST     = dmrw2               #实时归档目标实例名(主库侧填写备库实例名)
[ARCHIVE_LOCAL1] 
ARCH_TYPE     = LOCAL                 #本地归档类型
ARCH_DEST     = /home/dmdba/dmdbms/arch     #本地归档文件存放路径
ARCH_FILE_SIZE    = 512             #单位 Mb,本地单个归档文件最大值
ARCH_SPACE_LIMIT  = 10240                #单位 Mb,0 表示无限制,范围 1024~4294967294M
 

配置备库dmarch.ini(新建ini文件,若开启归档配置,则可直接修改ini文件)
vi /home/dmdba/dmdbms/dmrw/dmarch.ini

 [ARCHIVE_REALTIME]
ARCH_TYPE     = REALTIME              #实时归档类型
ARCH_DEST     = dmrw1               #实时归档目标实例名(备库侧填写主库实例名)
[ARCHIVE_LOCAL1] 
ARCH_TYPE     = LOCAL                 #本地归档类型
ARCH_DEST     = /home/dmdba/dmdbms/arch     #本地归档文件存放路径
ARCH_FILE_SIZE    = 512             #单位 Mb,本地单个归档文件最大值
ARCH_SPACE_LIMIT  = 10240                #单位 Mb,0 表示无限制,范围 1024~4294967294M

配置MAL系统配置文件 dmmal.ini(新建ini文件---主备库一致)
vi /home/dmdba/dmdbms/dmrw/dmmal.ini
 
MAL_CHECK_INTERVAL   = 5              #MAL 链路检测时间间隔
MAL_CONN_FAIL_INTERVAL  = 5          #判定 MAL 链路断开的时间
[MAL_INST1]
  MAL_INST_NAME = dmrw1             #与 dm.ini 中的 INSTANCE_NAME 一致
  MAL_HOST     = 10.0.0.11              #MAL 系统监听 TCP 内部网络 IP
  MAL_PORT     = 61141                 #MAL 系统监听 TCP 连接的端口
  MAL_INST_HOST   = 192.168.56.11          #实例的对外服务 IP 地址
  MAL_INST_PORT   = 5236             #与 dm.ini 中的 PORT_NUM 一致
  MAL_DW_PORT   = 52141             #实例对应的守护进程监听 TCP 端口
  MAL_INST_DW_PORT = 33141
[MAL_INST2]
  MAL_INST_NAME = dmrw2             #与 dm.ini 中的 INSTANCE_NAME 一致
  MAL_HOST      = 10.0.0.12              # MAL 系统监听 TCP 内部网络 IP
  MAL_PORT          = 61141             #MAL 系统监听 TCP 连接的端口
  MAL_INST_HOST   = 192.168.56.12          #实例的对外服务 IP 地址
  MAL_INST_PORT         = 5236             #与 dm.ini 中的 PORT_NUM 一致
  MAL_DW_PORT  = 52141             #实例对应的守护进程监听 TCP 端口
  MAL_INST_DW_PORT = 33141
 
配置守护进程配置文件 dmwatcher.ini(新建ini文件---主备库一致)
vi /home/dmdba/dmdbms/dmrw/dmwatcher.ini
 
[GRP_RW] 
DW_TYPE    = GLOBAL                              #全局守护类型
DW_MODE    = AUTO                               #自动切换模式---MANUAL手动切换
DW_ERROR_TIME     = 10                          #远程守护进程故障认定时间
INST_RECOVER_TIME  = 60                                #主库守护进程启动恢复的间隔时间
INST_ERROR_TIME   = 10                          #本地实例故障认定时间
INST_OGUID         = 453331                         #守护系统唯一 OGUID 值,如果有多套主备oguid要区分
INST_INI           = /home/dmdba/dmdbms/dmrw/dm.ini             #dm.ini 配置文件路径
INST_AUTO_RESTART  = 1                           #打开实例的自动启动功能
INST_STARTUP_CMD   = /home/dmdba/dmdbms/bin/dmserver         #命令行方式启动改成DmService启动:/opt/dmdbms/bin/DmServiceNBXXW start
 
以 mount 方式启动数据库实例(主备库都执行)

./dmserver /home/dmdba/dmdbms/dmrw/dm.ini mount
 
./disql SYSDBA/SYSDBA
 sp_set_oguid(453331);                ######修改oguid
alter database primary;                ######主库修改为primary角色

 启动守护进程dmwatcher(主备库都执行)
./dmwatcher /home/dmdba/dmdbms/dmrw/dmwatcher.ini
 
 守护进程启动后,会将 mount 的实例 open

监视器配置

守护进程配置为自动切换时,必须配置确认监视器。在主备服务器以外的服务器上(需安装有 DM 数据库软件,且与主备心跳网络端口开放)。

新建确认监视器配置文件 dmmonitor.ini

vi /home/dmdba/dmdbms/dmmonitor.ini
 
MON_DW_CONFIRM    = 1                       #确认监视器模式
MON_LOG_PATH    = /home/dmdba/dmdbms/log             #监视器日志文件存放路径
MON_LOG_INTERVAL  = 60                     #每隔 60s 定时记录系统信息到日志文件
MON_LOG_FILE_SIZE   = 32                     #每个日志文件最大 32MB
MON_LOG_SPACE_LIMIT  = 0                      #不限定日志文件总占用空间
[GRP_RW] 
 MON_INST_OGUID    = 453331                     #组 GRP_RW 的唯一 OGUID 值
#以下配置为监视器到组 GRP_RW 的守护进程的连接信息,以“IP:PORT”的形式配置
#IP 对应 dmmal.ini 中的 MAL_HOST,PORT 对应 dmmal.ini 中的 MAL_DW_PORT
 MON_DW_IP     = 10.0.0.11:52141
 MON_DW_IP     = 10.0.0.12:52141
 
启动监视器
./dmmonitor /home/dmdba/dmdbms/dmmonitor.ini
 
启动后输入 show 命令查看集群状态

确认监视器后台服务启动后,是无法查看show状态的,如果想查看状态需要在前台新建一个普通的监视器,

vi /home/dmdba/dmdbms/dmmonitor1.ini
 
MON_DW_CONFIRM    = 0                       #普通监视器模式
MON_LOG_PATH    = /home/dmdba/dmdbms/log             #监视器日志文件存放路径
MON_LOG_INTERVAL  = 60                     #每隔 60s 定时记录系统信息到日志文件
MON_LOG_FILE_SIZE   = 32                     #每个日志文件最大 32MB
MON_LOG_SPACE_LIMIT  = 0                      #不限定日志文件总占用空间
[GRP_RW] 
 MON_INST_OGUID    = 453331                     #组 GRP_RW 的唯一 OGUID 值
#以下配置为监视器到组 GRP_RW 的守护进程的连接信息,以“IP:PORT”的形式配置
#IP 对应 dmmal.ini 中的 MAL_HOST,PORT 对应 dmmal.ini 中的 MAL_DW_PORT
 MON_DW_IP     = 10.0.0.11:52141
 MON_DW_IP     = 10.0.0.12:52141
 
启动监视器
./dmmonitor /home/dmdba/dmdbms/dmmonitor1.ini

exit或ctr+c退出


注册服务

以上启动为前台方式启动,仅用户搭建过程中验证配置。配置没问题后需要将实例,守护进程和确认监视器注册为系统服务。使用 root 用户,到数据库安装目录的 script/root 下,执行。

注册守护进程服务(主备库都执行)

./dm_service_installer.sh -t dmwatcher -p dmrw -watcher_ini /home/dmdba/dmdbms/dmrw/dmwatcher.ini
 
注册数据库实例服务(主备库都执行)

./dm_service_installer.sh -t dmserver -p dmrw -m mount -dm_ini /home/dmdba/dmdbms/dmrw/dm.ini

 注册监视器服务(只需在监视器服务器上执行),执行以下命令

./dm_service_installer.sh -t dmmonitor -p confirm -monitor_ini /home/dmdba/dmdbms/dmmonitor.ini
 
以服务方式启动
启动数据库实例,执行以下命令:

systemctl start DmServicedmrw
 或    DmServicedmrw start

启动守护进程,执行以下命令:

systemctl start DmWatcherServicedmrw
 或    DmWatcherServicedmrw start

启动监视器,执行以下命令:

systemctl start DmMonitorServiceconfirm
 或    DmMonitorServiceconfirm start
 

重启

主备集群重启有顺序要求:

关闭监视器:systemctl stop DmMonitorServiceconfirm
关闭主库守护进程:systemctl stop DmWatcherServicedmrw
关闭备库守护进程:systemctl stop DmWatcherServicedmrw
关闭主库实例:systemctl stop DmServicedmrw
关闭备库实例:systemctl stop DmServicedmrw

启动主库实例:systemctl start DmServicedmrw
启动备库实例:systemctl start DmServicedmrw
启动主库守护进程:systemctl start DmWatcherServicedmrw
启动备库守护进程:systemctl start DmWatcherServicedmrw
启动监视器:systemctl start DmMonitorServiceconfirm
 

客户端访问

32 位的 DM 安装在 Win64 操作平台下,此文件位于 %SystemRoot%\SysWOW64 目录;
在 Linux 平台下,此文件位于/etc 目录。
文件内容:

# 以#开头的行表示是注释
# 全局配置区
DMRW=(192.168.56.11:5236,192.168.56.12:5236)
TIME_ZONE=(+480) #表示+8:00 时区
LOGIN_ENCRYPT=(0)
DIRECT=(Y)
# 服务配置区
[DMRW]
TIME_ZONE=(+540) #表示+9:00 时区
LOGIN_MODE=(1)
SWITCH_TIME=(3)
SWITCH_INTERVAL=(10)
 
客户端程序连接数据库时,需要指定 ip 端口处替换为服务名即可,例如:

disql SYSDBA/SYSDBA@DMRW

注意
当修改了 dm_svc.conf 内容后,需要重启客户端程序,修改的配置才能生效

LOGIN_MODE
服务名方式登录,始终会优先登录主库;LOGIN_MODE 表示是否仅登录主库或者备库, 可以配置为 0、1 或 2。
0 表示优先登录主库,没有可用主库情况下登录备库;
1 表示不登 录 Standby 模式的库,如果系统中只有 Standby 模式的库,登录失败并报错;
2 表示仅 登录 Standby 模式的库。
默认值为 0。
 

 

 

 

 

 

 


 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值