环境说明 1.准备三台机器 DW_P、DW_S1、DW_M,DW_P 和 DW_S1 用来部署主备库,DW_M 用来部署确认监视器。其中 DW_P 和 DW_S1 配置两块网卡,一块接入内部网络交换模块,一块接入到外部交换机,DW_M 接入内部网络。
三台机器都事先安装了 DM,安装路径为'/dm8',执行程序保存在'/dm/bin'目录中,数据存放路径为'/dm/data'。
各主备库的实例名建议采用“组名_守护环境_序号”的方式命名,方便按组区分不同实例,注意总长度不能超过 16。本示例中组名为“GRP1”,配置为实时主备,主库命名为“GRP1_RT_01”,备库命名为“GRP1_RT_02”。
2.配置环境和检查说明:
机器名 IP 地址 初始状态 操作系统 备注
DW_P 192.168.174.100
192.168.37.100 主库 GRP1_RT_01 Kylin Linux Advanced Server release V10 (Sword) 192.168.174.100
外部服务 IP;
192.168.37.100 内部通信 IP
DW_S1 192.168.174.99
192.168.37.99 备库 GRP1_RT_02 Kylin Linux Advanced Server release V10 (Sword) 192.168.174.99
外部服务 IP;
192.168.37.99内部通信 IP
DW_M 192.168.174.98 确认监视器 Kylin Linux Advanced Server release V10 (Sword)
检查:ping IP(主机备机监视机都需要检查)
2. 端口规划
实例名 PORT_NUM MAL_INST_DW_PORT MAL_HOST MAL_PORT MAL_DW_PORT
GRP1_RT_01 32141 33141 192.168.37.100 61141 52141
GRP1_RT_02 32142 33142 192.168.37.99 61142 52142
在各个节点安装数据库,并初始化,主节点备份并把备份集传到备节点上,执行操作还原。 1.安装步骤请参考:单机
2.初始化数据库:/dm8/bin/dminit PATH=/home/dmdba/data/ INSTANCE_NAME=GRP1_RT_01 PAGE_SIZE=32 EXTENT_SIZE=32 LOG_SIZE=2048(主库备库都需要,注意实例名称)
3.启动服务:
/dm8/bin/dmserver /home/dmdba/data/DAMENG/dm.ini
4.开启归档:
4.1 复制一个新会话窗口
4.2 登录数据库:disql SYSDBA/SYSDBA(密码有特殊字符需要用‘””’包裹)
4.3开启归档并备份:
ALTER DATABASE MOUNT;
ALTER DATABASE ARCHIVELOG;
ALTER DATABASE ADD ARCHIVELOG 'DEST=/home/dmdba/data/DAMENG/arch, TYPE=LOCAL, FILE_SIZE=1024, SPACE_LIMIT=51200';
ALTER DATABASE OPEN;
备份:BACKUP DATABASE BACKUPSET '/home/dmdba/data/DAMENG/bak/BACKUP_FILE';
(备份失败可能是该路径不具备写权限)
4.4 直接关闭数据库:Ctrl +z
5.将备份文档传到备库
cd /home/dmdba/data/DAMENG/bak/BACKUP_FILE
scp -r ../BACKUP_FILE/ 192.168.174.99:/home/dmdba/data/DAMENG/bak/
6.切换到备库:su - dmdba
根据传过来的备份集恢复:
/dm8/bin/dmrman CTLSTMT="RESTORE DATABASE '/home/dmdba/data/DAMENG/dm.ini' FROM BACKUPSET '/home/dmdba/data/DAMENG/bak/BACKUP_FILE'"
/dm8/bin/dmrman CTLSTMT="RECOVER DATABASE '/home/dmdba/data/DAMENG/dm.ini' UPDATE DB_MAGIC"
修改和添加相关文件 1.修改dm.ini(主备库都需要)
vim /home/dmdba/data/DAMENG/dm.ini
参数名 参数值
INSTANCE_NAME GRP1_RT_01/GRP1_RT_02
PORT_NUM 5236
DW_INACTIVE_INTERVAL 60
ALTER_MODE_STATUS 0
ENABLE_OFFLINE_TS 2
MAL_INI 1
ARCH_INI 1
RLOG_SEND_APPLY_MON 64
2.修改dmarch.ini(主备库都需要)
vim /home/dmdba/data/DAMENG/dmarch.ini
ARCH_WAIT_APPLY = 0 #0:高性能 1:事务一致
[ARCHIVE_LOCAL]
ARCH_TYPE = LOCAL #本地归档类型
ARCH_DEST = /home/dmdba/data/DAMENG/arch/ #本地归档存放路径
ARCH_FILE_SIZE = 1024 #单个归档大小,单位 MB
ARCH_SPACE_LIMIT = 51200 #归档上限,单位 MB
ARCH_FLUSH_BUF_SIZE = 2
ARCH_HANG_FLAG = 1
[ARCHIVE_REALTIME1]
ARCH_TYPE = REALTIME #实时归档类型
ARCH_DEST = GRP1_RT_02 #实时归档目标实例名(主备名字调换)
3创建 dmmal.ini
vim /home/dmdba/data/DAMENG/dmmal.ini
修改并添加以下内容
MAL_CHECK_INTERVAL = 10 #MAL 链路检测时间间隔
MAL_CONN_FAIL_INTERVAL = 10 #判定 MAL 链路断开的时间
MAL_TEMP_PATH = /home/dmdba/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 = GRP1_RT_01 #实例名,和 dm.ini 的 INSTANCE_NAME 一致
MAL_HOST = 192.168.37.100 #MAL 系统监听 TCP 连接的 IP 地址
MAL_PORT = 5336 #MAL 系统监听 TCP 连接的端口
MAL_INST_HOST = 192.168.174.100 #实例的对外服务 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 = GRP1_RT_02
MAL_HOST = 192.168.37.99
MAL_PORT = 5336
MAL_INST_HOST = 192.168.174.99
MAL_INST_PORT = 5236
MAL_DW_PORT = 5436
MAL_INST_DW_PORT = 5536
3.创建 dmwatcher.ini
vim /home/dmdba/data/DAMENG/dmwatcher.ini
添加以下内容:
[GRP1]
DW_TYPE = GLOBAL #全局守护类型
DW_MODE = AUTO #MANUAL:故障手切 AUTO:故障自切
DW_ERROR_TIME = 20 #远程守护进程故障认定时间
INST_ERROR_TIME = 20 #本地实例故障认定时间
INST_RECOVER_TIME = 60 #主库守护进程启动恢复的间隔时间
INST_OGUID = 45331 #守护系统唯一 OGUID 值
INST_INI = /home/dmdba/data/DAMENG/dm.ini #dm.ini 文件路径
INST_AUTO_RESTART = 1 #打开实例的自动启动功能
INST_STARTUP_CMD = /home/dmdba/bin/dmserver #命令行方式启动
RLOG_SEND_THRESHOLD = 0 #指定主库发送日志到备库的时间阈值,默认关闭
RLOG_APPLY_THRESHOLD = 0 #指定备库重演日志的时间阈值,默认关闭
添加dmmonitor配置文件 添加dmmonitor.ini文件
vim /home/dmdba/dm8/bin/dmmonitor.ini
MON_DW_CONFIRM = 0 #0:非确认(故障手切) 1:确认(故障自切)
MON_LOG_PATH = ../log #监视器日志文件存放路径
MON_LOG_INTERVAL = 60 #每隔 60s 定时记录系统信息到日志文件
MON_LOG_FILE_SIZE = 512 #单个日志大小,单位 MB
MON_LOG_SPACE_LIMIT = 2048 #日志上限,单位 MB
[GRP1]
MON_INST_OGUID = 45331 #组 GRP1 的唯一 OGUID 值(必须和主备库相同)
MON_DW_IP = 192.168.174.100:5436 #IP 对应 MAL_HOST,PORT 对应 MAL_DW_PORT
MON_DW_IP = 192.168.174.99:5436
使用mount模式启动和修改相关参数
1、主库:
/dm8/bin/dmserver /home/dmdba/data/DAMENG/dm.ini mount
SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);
SP_SET_OGUID(45331);(主备一致)
ALTER DATABASE PRIMARY;
SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);
2、备库:
/dm8/bin/dmserver /home/dmdba/data/DAMENG/dm.ini mount
SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);
SP_SET_OGUID(45331);(主备一致)
ALTER DATABASE STANDBY;
SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);
3、主备库节点启动dmwatcher 1、主库备库节点分别复制一个ssh链接。
2、执行:/dm8/bin/dmwatcher /home/dmdba/data/DAMENG/dmwatcher.ini
启动dmmonitor cd /home/dmdba/dm8/bin
/dm8/bin/dmmonitor /home/dmdba/dm8/bin/dmmonitor.ini
注册实例 1.注册dmserver 实例
/dm8/script/root/dm_service_installer.sh -t dmserver -p GRP1_RT_02(需要修改) -dm_ini /home/dmdba/data/DAMENG/dm.ini -m mount
2.注册dmwatcher 实例
/dm8/script/root/dm_service_installer.sh -t dmwatcher -p Watcher -watcher_ini /home/dmdba/data/DAMENG/dmwatcher.ini
4.注册dmmonitor 实例
/dm8/script/root/dm_service_installer.sh -t dmmonitor -p Monitor -dmmonitor _ini /home/dmdba/data/DAMENG/dmwatcher.ini
以服务的方式启动
1、启动:/dm8/bin/服务名 start
2、关闭:/dm8/bin/服务名 stop
3、重启:/dm8/bin/服务名 restart
文章
阅读量
获赞