DM主备集群部署(2节点)
1 主备集群规划
1.1 服务器IP规划
类别 | 实例名 | 服务器地址 | 心跳IP |
---|---|---|---|
主库 | ZB1 | 192.168.0.15 | 192.168.100.129 |
备库 | ZB2 | 192.168.0.16 | 192.168.100.130 |
1.2 端口规划
名称 | 端口 |
---|---|
PORT_NUM | 5236 |
MAL_PORT | 7336 |
MAL_DW_PORT | 7536 |
MAL_INST_DW_PORT | 7436 |
MAL_INST_PORT | 5236 |
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即成功