一、环境介绍
主库:
pub 192.168.115.23
已安装数据库软件及实例
备库:
pub 192.168.115.24
已安装数据库软件
监视器:
pub 192.168.115.24
已安装数据库软件
此处3台主机公网和私网均使用pub网卡,生产环境慎重。
此处3台主机已要关闭防火墙或者指定开放端口,生产环境慎重。
建议使用如下命令开放防火墙端口
firewall-cmd --zone=public --add-port=5236/tcp --permanent
firewall-cmd --zone=public --add-port=15238/tcp --permanent
firewall-cmd --zone=public --add-port=15240/tcp --permanent
firewall-cmd --zone=public --add-port=5240/tcp --permanent
二、主库配置
--primary
1.停止数据库实例并进行一次全量冷备
mkdir /backup
chown -R dmdba.dinstall /backup/
su - dmdba
DmServiceDMSERVER stop
dmrman
backup database '/dm8/data/DAMENG/dm.ini' backupset '/backup/FULLBAK';
--primary
2.编辑dm.ini参数文件
su - dmdba
cd /dm8/data/DAMENG/
vi dm.ini
修改以下5个参数:
INSTANCE_NAME = DM01 #实例名
ALTER_MODE_STATUS = 0 #不允许用户通过SQL更改数据库模式
ENABLE_OFFLINE_TS = 1 #不允许表空间脱机
MAL_INI = 1 #打开MAL系统(即数据守护)
ARCH_INI = 1 #打开归档
--primary
3.编辑dmmal.ini参数文件
su - dmdba
cd /dm8/data/DAMENG/
grep -E "=" /dm8/samples/ini_script/UTF-8/dmmal_example.ini>dmmal.ini
sed -i 's/^#//g' dmmal.ini #执行两次剔除掉行首的#
vi dmmal.ini
[dmdba@localhost DAMENG]$ more dmmal.ini
MAL_CHECK_INTERVAL = 5 #MAL链路检测时间间隔
MAL_CONN_FAIL_INTERVAL = 5 #判断MAL链路断开时间
[MAL_INST1]
MAL_INST_NAME = DM01 #实例名,与dm.imi中INSTANCE_NAME保持一致
MAL_HOST = 192.168.115.23 #MAL监测地址 1号节点IP
MAL_PORT = 15238 #MAL监听TCP端口
MAL_INST_HOST = 192.168.115.23 #实例对外服务地址
MAL_INST_PORT = 5236 #实例对外服务端口
MAL_DW_PORT = 15240 #本地MAL监听端口
MAL_INST_DW_PORT = 5240 #实例监听MAL端口
[MAL_INST2]
MAL_INST_NAME = DM02
MAL_HOST = 192.168.115.24
MAL_PORT = 15238
MAL_INST_HOST = 192.168.115.24
MAL_INST_PORT = 5236
MAL_DW_PORT = 15240
MAL_INST_DW_PORT = 5240
[dmdba@localhost DAMENG]$
--primary
4.编辑dmarch.ini参数文件
su - dmdba
cd /dm8/data/DAMENG/
grep -E "=" /dm8/samples/ini_script/UTF-8/dmarch_example.ini
vi dmarch.ini
[ARCHIVE_LOCAL1]
ARCH_TYPE = LOCAL
ARCH_DEST = /dm8/data/DAMENG/arch
ARCH_FILE_SIZE = 128
ARCH_SPACE_LIMIT = 0
[ARCHIVE_REALTIME]
ARCH_TYPE = REALTIME
ARCH_DEST = DM02
--primary
5.编辑dmwatcher.ini参数文件
su - dmdba
cd /dm8/data/DAMENG/
grep -E "=" /dm8/samples/ini_script/UTF-8/dmwatcher_example.ini
sed -i 's/^#//g' dmwatcher.ini #执行两次剔除掉行首的#
vi dmwatcher.ini
[GRP1]
DW_TYPE =GLOBAL #全局守护类型
DW_MODE =AUTO #自动切换模式
DW_ERROR_TIME =10 #远程守护进程故障确认时间
INST_ERROR_TIME =10 #本地实例故障确认时间
INST_OGUID =8888 #守护进程OGUID
INST_INI =/dm8/data/DAMENG/dm.ini #dm.ini配置文件路径
INST_AUTO_RESTART =1 #打开实例自动启动功能
INST_STARTUP_CMD =/dm8/bin/dmserver #命令行方式启动
INST_RECOVER_TIME =0 #自动主库发送日志到备库的时间阈值 默认关闭
INST_SERVICE_IP_CHECK =0 #指定备库重演日志的时间阈值 默认关闭
三、备库配置
--standby
1.拷贝主库全量冷备文件
mkdir /backup
chown -R dmdba.dinstall /backup/
su - dmdba
scp -r dmdba@192.168.115.23:/backup/* /backup
--standby
2.还原全量备份文件
su - dmdba
dmrman
restore database to '/dm8/data/DAMENG' from backupset '/backup/FULLBAK';
--standby
3.恢复全量备份文件
su - dmdba
dmrman
recover database '/dm8/data/DAMENG/dm.ini' update db_magic;
--primary
4.从主库拷贝参数文件到备库
su - dmdba
cd /dm8/data/DAMENG
scp dmmal.ini dmarch.ini dmwatcher.ini dmdba@192.168.115.24:/dm8/data/DAMENG
--standby
5.修改dm.ini参数文件
su - dmdba
cd /dm8/data/DAMENG
vi dm.ini
修改以下5个参数:
INSTANCE_NAME = DM02 #实例名
ALTER_MODE_STATUS = 0 #不允许用户通过SQL更改数据库模式
ENABLE_OFFLINE_TS = 2 #不允许表空间脱机
MAL_INI = 1 #打开MAL系统(即数据守护)
ARCH_INI = 1 #打开归档
--standby
6.修改dmarch.ini参数文件
su - dmdba
cd /dm8/data/DAMENG
vi dmarch.ini
修改以下参数
ARCH_DEST = DM01
--standby
7.确认dmmal.ini和dmwatcher.ini参数文件内容(dmmal.ini无需修改、dmwatcher.ini确认命令行启动路径)
su - dmdba
cd /dm8/data/DAMENG
more dmmal.ini
more dmwatcher.ini
四、启动数据守护
--primary
1.主库启动至mount状态并修改数据库为primary模式
su - dmdba
cd /dm8/bin
DmServiceDMSERVER start mount
disql SYSDBA/Dameng123
alter database primary;
--standby
2.备库启动至mount状态并修改数据库为standby模式
su - dmdba
/dm8/bin/dmserver /dm8/data/DAMENG/dm.ini mount
注意:前台方式启动不可关闭此启动ssh窗口
disql SYSDBA/Dameng123
alter database standby;
--two hosts
3.修改oguid为dmwatcher.ini中的设定值
su - dmdba
disql sysdba/Dameng123
alter system set 'ALTER_MODE_STATUS'=1;
sp_set_oguid(8888);
alter system set 'ALTER_MODE_STATUS'=0;
--two hosts
4.启动数据守护
注意:此步前主备库均仍处于mount状态,当主库启动数据守护、备库数据守护启动后,主备库均由mount状态自动提升为OPEN状态
--primary
(1)主机启动
su - dmdba
cd /dm8/bin
./dmwatcher /dm8/data/DAMENG/dmwatcher.ini
注意:前台方式启动不可关闭此启动ssh窗口
--standby
(2)备机启动
su - dmdba
cd /dm8/bin
./dmwatcher /dm8/data/DAMENG/dmwatcher.ini
注意:前台方式启动不可关闭此启动ssh窗口
--primary
(3)再次查看主机数据守护中的数据库状态已由MOUNT状态变为OPEN
五、监视器配置
--monitor
1.编辑dmmonitor.ini参数文件
su - dmdba
grep -E "=" /dm8/samples/ini_script/UTF-8/dmmonitor_example.ini > dmmonitor.ini
sed -i 's/^#//g' /home/dmdba/dmmonitor.ini #执行两次剔除掉行首的#
vi dmmonitor.ini
MON_DW_CONFIRM = 1
MON_LOG_PATH = /dm8/log
MON_LOG_INTERVAL = 60
MON_LOG_FILE_SIZE = 32
MON_LOG_SPACE_LIMIT = 0
[GRP1]
MON_INST_OGUID = 8888
MON_DW_IP =192.168.115.23:15240
MON_DW_IP =192.168.115.24:15240
--monitor
2.启动确认监视器
su - dmdba
cd /dm8/bin
./dmmonitor /home/dmdba/dmmonitor.ini
--monitor
3.设置非确认监视器用于后期查看数据守护状态
su - dmdba
cp dmmonitor.ini dmmonitor02.ini
vi dmmonitor02.ini
修改以下一项内容:
MON_DW_CONFIRM = 0
--monitor
4.通过非确认监视器查看数据守护状态
cd /dm8/bin
./dmmonitor /home/dmdba/dmmonitor02.ini
--primary
5.主库可查看归档目标是否有效
select * from v$arch_status;
六、关闭数据守护
--monitor
1.关闭确认监视器(防止自动接管)
--standby
2.关闭备库数据守护
--primary
3.关闭主库数据守护
--primary
4.关闭主库实例
--standby
5.关闭备库实例
七、注册服务
--primary
1.主库注册数据守护服务至操作系统
su - root
cd /dm8/script/root/
./dm_service_installer.sh -t dmwatcher -watcher_ini /dm8/data/DAMENG/dmwatcher.ini -p DW01
--primary
2.主库卸载原有数据服务,并注册新的数据库服务至操作系统
su - root
cd /dm8/script/root/
ll /dm8/bin/DmServiceDMSERVER
./dm_service_uninstaller.sh -n DmServiceDMSERVER
./dm_service_installer.sh -t dmserver -dm_ini /dm8/data/DAMENG/dm.ini -p DM01
--standby
3.备库注册数据守护服务至操作系统
su - root
cd /dm8/script/root/
./dm_service_installer.sh -t dmwatcher -watcher_ini /dm8/data/DAMENG/dmwatcher.ini -p DW02
--standby
4.备库注册数据库服务至操作系统
su - root
cd /dm8/script/root/
./dm_service_installer.sh -t dmserver -dm_ini /dm8/data/DAMENG/dm.ini -p DM02
--monitor
5.监视器监视服务至操作系统
su - root
cd /dm8/script/root/
./dm_service_installer.sh -t dmmonitor -monitor_ini /home/dmdba/dmmonitor.ini -p DMMONITOR
八、启动数据守护
没有严格的顺序要求
--primary
1.启动主库实例
su - dmdba
cd /dm8/bin
./DmServiceDM01 start
--standby
2.启动备库实例
su - dmdba
cd /dm8/bin
./DmServiceDM02 start
--primary
3.启动主库数据守护
su - dmdba
cd /dm8/bin
./DmWatcherServiceDW01 start
--standby
4.启动备库数据守护
su - dmdba
cd /dm8/bin
./DmWatcherServiceDW02 start
5.启动确认监视器
su - dmdba
cd /dm8/bin
./DmMonitorServiceDMMONITOR start
--primary
6.主库可查看归档目标是否有效
--monitor
7.通过非确认监视器查看数据守护状态
cd /dm8/bin
./dmmonitor /home/dmdba/dmmonitor02.ini
九、测试数据同步
--primary
1.主库
--standby
2.备库
十、主备切换
--monitor
1.通过非确认监视器手动切换主备状态
cd /dm8/bin
./dmmonitor /home/dmdba/dmmonitor02.ini
(1)choose switchover #查看可以切换到那些备库
(2)login #登录SYSDBA用户
(3)switchover #开始切换
(4)show #再次查看主备状态
文章
阅读量
获赞