DM主备集群部署(2节点)

本文详细介绍了如何在两台服务器上部署达梦数据库的主备集群,包括IP规划、端口设置、目录结构、软件安装、实例初始化、数据库备份与还原、配置文件修改以及守护进程和监视器的设置和启动过程。
摘要由CSDN通过智能技术生成

1 主备集群规划

1.1 服务器IP规划

类别实例名服务器地址心跳IP
主库ZB1192.168.0.15192.168.100.129
备库ZB2192.168.0.16192.168.100.130

1.2 端口规划

名称端口
PORT_NUM5236
MAL_PORT7336
MAL_DW_PORT7536
MAL_INST_DW_PORT7436
MAL_INST_PORT5236

1.3 目录规划

目录路径
安装目录/dm
数据文件目录/dm/data
备份目录/dm/dbbak/dmbak
归档目录/dm/data/DAMENG/dmarch

2 集群部署

2.1 数据库软件安装

先安装好数据库软件

注意:两台服务器都需要安装

2.2 初始化实例

2个节点都有实例初始化,执行以下命令:
主机ZB1:

[dmdba@localhost ~]$ cd /dm/bin
[dmdba@localhost bin]$./dminit path=/dm/data page_size=32 log_size=1024 instance_name=ZB1

开启服务

[dmdba@localhost bin]$ cp service_template/DmService dmserverd
[dmdba@localhost bin]$ vim dmserverd
INI_PATH=/dm/data/DAMENG/dm.ini
[dmdba@localhost bin]$ dmserverd start

开机自启配置

[root@localhost bin]# cp dmserverd /etc/init.d/
[root@localhost bin]# chkconfig --add dmserverd
[root@localhost bin]# chkconfig --list

备机ZB2:

[dmdba@localhost ~]$ cd /dm/bin
[dmdba@localhost bin]$ ./dminit path=/dm/data page_size=32 log_size=1024 instance_name=ZB2

开启服务

[dmdba@localhost bin]$ cp service_template/DmService dmserverd
[dmdba@localhost bin]$ vim dmserverd
INI_PATH=/dm/data/DAMENG/dm.ini
[dmdba@localhost bin]$ dmserverd start

开机自启配置

[root@localhost bin]# cp dmserverd /etc/init.d/
[root@localhost bin]# chkconfig --add dmserverd
[root@localhostbin]# chkconfig --list

2.3 脱机备份主机数据库

在主机ZB1上执行以下命令,确认主库dmap服务已启动:

ps -ef|grep dmap

若未启动,则先启动 DMAP 服务,使用dmdba用户切换到安装目录的 bin 下执行以下命令:

./DmAPService start

若已启动,则执行以下命令进行脱机备份

[dmdba@localhost bin]$ ./dmserverd stop
[dmdba@localhost bin]$ ./dmrman use_ap=2
[dmdba@localhost bin]$backup database '/dm/data/DAMENG/dm.ini' backupset '/dm/dbbak/dmbak/bakfull';

2.4 脱机还原备机数据库

将备份的文件/dm/dbbak/dmbak/bakfull拷贝到备库服务器上。

[dmdba@localhost dmbak]# scp -r bakfull/ dmdba@192.168.0.16:/dm/dbbak/dmbak

在备机ZB2上,使用 dmrman 工具还原备库,dmdba 用户执行:

[dmdba@localhost bin]$ ./dmserverd stop
[dmdba@localhost bin]$ ./dmrman
##执行restore
RMAN> restore database '/dm/data/DAMENG/dm.ini' from backupset '/dm/dbbak/dmbak/bakfull';
##执行recover
RMAN> recover database '/dm/data/DAMENG/dm.ini' from backupset '/dm/dbbak/dmbak/bakfull';
##执行recover update db_magic
RMAN> recover database '/dm/data/DAMENG/dm.ini' update db_magic;

2.5 配置文件修改

2.5.1 修改dm.ini参数

在ZB1和ZB2上分别修改dm.ini参数值:

vi /dm/data/DAMENG/dm.ini

MAL_INI = 1
ARCH_INI = 1
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2

2.5.2 配置归档配置文件 dmarch.ini

在ZB1和ZB2上分别修改dmarch.ini参数值:

##ZB1
[dmdba@localhost DAMENG]$ vi /dm/data/DAMENG/dmarch.ini
##ZB2
[dmdba@localhost DAMENG]$ vi /dm/data/DAMENG/dmarch.ini

主机ZB1上添加以下内容:

[ARCHIVE_REALTIME]
ARCH_TYPE     = REALTIME  #实时归档类型
aRCH_DEST     = ZB2   #实时归档目标实例名(主库侧填写备库实例名)
[ARCHIVE_LOCAL1]
ARCH_TYPE     = LOCAL #本地归档类型
ARCH_DEST     = /dm/data/DAMENG/dmarch #本地归档文件存放路径
ARCH_FILE_SIZE    = 128 #单位 MB,本地单个归档文件最大值
ARCH_SPACE_LIMIT  = 10240    #单位 MB,0 表示无限制,范围 1024~4294967294 MB

备机ZB2上添加以下内容:

[ARCHIVE_REALTIME]
ARCH_TYPE     = REALTIME  #实时归档类型
aRCH_DEST     = ZB1   #实时归档目标实例名(主库侧填写备库实例名)
[ARCHIVE_LOCAL1]
ARCH_TYPE     = LOCAL #本地归档类型
ARCH_DEST     = /dm/data/DAMENG/dmarch #本地归档文件存放路径
ARCH_FILE_SIZE    = 128 #单位 MB,本地单个归档文件最大值
ARCH_SPACE_LIMIT  = 10240    #单位 MB,0 表示无限制,范围 1024~4294967294 MB  

2.5.3 配置MAL系统配置文件 dmmal.ini

在实例目录下新建文件 dmmal.ini,执行以下命令。

[dmdba@localhost DAMENG]$ vi /dm/data/DAMENG/dmmal.ini

##注意:主备库2个节点文件内容要相同,内容如下:

MAL_CHECK_INTERVAL   = 5
MAL_CONN_FAIL_INTERVAL  = 15
[MAL_INST1]
  MAL_INST_NAME = ZB1
  MAL_HOST     = 192.168.100.129
  MAL_PORT     = 7336
  MAL_INST_HOST   = 192.168.0.15
  MAL_INST_PORT   = 5236
  MAL_DW_PORT   = 7536
  MAL_INST_DW_PORT = 7436
[MAL_INST2]
  MAL_INST_NAME = ZB2
  MAL_HOST      = 192.168.100.130
  MAL_PORT          = 7336
  MAL_INST_HOST         = 192.168.0.16
  MAL_INST_PORT         = 5236
  MAL_DW_PORT  = 7536
  MAL_INST_DW_PORT = 7436

2.5.4 配置守护进程配置文件 dmwatcher.ini

在实例目录下新建文件 dmwatcher.ini,执行以下命令:

vi /dm/data/DAMENG/dmwatcher.ini

##注意:主备库2个节点文件内容相同(由于实例路径的原因),内容如下:

[GRP_DW]
DW_TYPE    = GLOBAL  #全局守护类型
DW_MODE    = AUTO  #自动切换模式
DW_ERROR_TIME     = 10  #远程守护进程故障认定时间
INST_RECOVER_TIME  = 60  #主库守护进程启动恢复的间隔时间
INST_ERROR_TIME   = 10  #本地实例故障认定时间
INST_OGUID         = 453331  #守护系统唯一 OGUID 值
INST_INI           = /dm/data/DAMENG/dm.ini  # dm.ini 配置文件>路径
INST_AUTO_RESTART  = 1   #打开实例的自动启动功能
INST_STARTUP_CMD   = /dm/bin/dmserverd  #命令行方式启动

2.5.5 修改主备库状态和oguid

修改主库oguid和数据库状态,在ZB1上执行以下命令
(1)主库mount方式后台启动
在ZB1上修改/dm/bin/dmserverd中START_MODE为mount,保存修改后,执行命令:

./dmserverd start  #启动主库数据库后台服务

(2)使用disql工具连接主库

[dmdba@localhost bin]$ ./disql SYSDBA/SYSDBA

(3)修改oguid

SQL> sp_set_oguid(453331);

(4)修改数据库模式为primary

SQL> alter database primary;

修改备库oguid和数据库状态,在ZB2上执行以下命令
(1)备库mount方式后台启动
在ZB2上修改/dm/bin/dmserverd中START_MODE为mount,保存修改后,执行命令:

./dmserverd start  #启动主库数据库后台服务

(2)使用disql工具连接备库

[dmdba@localhost bin]$ ./disql SYSDBA/SYSDBA

(3)修改oguid

sp_set_oguid(453331);

(4)修改数据库模式为standby

alter database standby;

2.5.6 修改后台启动脚本

(1)守护进程后台启动脚本
在ZB1和ZB2上的目录/dm/bin/service_template拷贝DmWatcherService文件到/ dmdbms/bin目录下,然后修改DmWatcherService中 INI_PATH为ZB1和ZB2指定守护进程配置文件dmwatcher.ini的路径(比如/dm/data/DAMENG/dmwatcher.ini)。

[dmdba@localhost bin]$ cp /service_template/DmWatcherService DmWatcherService
[dmdba@localhost bin]$ vi DmWatcherService
INI_PATH=/dm/data/DAMENG/dmwatcher.ini

(2)监视器进程后台脚本
在要部署的监视服务器ZB2上的/dm/bin/service_template拷贝DmMonitorService到/dm/bin目录下,然后修改DmMonitorService中INI_PATH为监视器配置文件dmmonitor.ini路径(比如/dm/data/DAMENG/dmmonitor.ini).

[dmdba@localhost bin]$ cp /service_template/DmMonitorService DmMonitorService
[dmdba@localhost bin]$ vi DmMonitorService
INI_PATH=/dm/data/DAMENG/dmmonitor.ini

[dmdba@localhost bin]$ cd /dm/data/DAMENG/
[dmdba@localhost DAMENG]$ vi dmmonitor.ini
MON_DW_CONFIRM    = 1 #确认监视器模式
MON_LOG_PATH    = /dm/data/DAMENG/log  #监视器日志文件存放路径
MON_LOG_INTERVAL  = 60 #每隔 60 s 定时记录系统信息到日志文件
MON_LOG_FILE_SIZE   = 200 #每个日志文件最大 32 MB
MON_LOG_SPACE_LIMIT  = 1024  #不限定日志文件总占用空间
[GRP_DW]
MON_INST_OGUID    = 453331 #组 GRP_DW 的唯一 OGUID 值
#以下配置为监视器到组 GRP_DW 的守护进程的连接信息,以“IP:PORT”的形式配置
#IP 对应 dmmal.ini 中的 MAL_HOST,PORT 对应 dmmal.ini 中的 MAL_DW_PORT
MON_DW_IP     = 192.168.100.129:7536
MON_DW_IP     = 192.168.100.130:7536

2.6 启动集群

(1)启动守护进程
dmdba 用户切换到数据库安装目录的 bin 下执行以下命令(主备库都执行):

##ZB1
[dmdba@localhost bin]$ ./DmWatcherService start
##ZB2
[dmdba@localhost bin]$ ./DmWatcherService start

守护进程启动后,会将 Mount 的实例 Open。

(2)启动监视器进程
建议配置在第三台独立的服务器上(需安装和主备相同 版本的DM 数据库软件(不必初始化实例),且与主备心跳网络端口开放),守护进程配置为自动切换时,必须配置确认监视器。
使用执行以下命令,启动监视器。

##ZB2
[dmdba@localhost bin]$ ./dmmonitor /dm/data/DAMENG/dmmonitor.ini

输入 show 命令查看集群状态:
其中守护进程状态 WSTATUS 为 OPEN,实例状态 ISTATUS 为 OPEN,归档类型 RTYPE 为 TIMELY,归档状态 RSTAT 为VALID。

输入 tip 命令查看系统当前运行状态:
看到实例状态均为OPEN即成功
在这里插入图片描述

达梦数据库 | 达梦在线服务平台

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值