根据实际项目经验来看,达梦数据库做主备模式运行还是比较稳定的一种方式,对于正式环境或者测试环境来说都是可采纳的一种模式,达梦今年更新的版本也做了很大的改动,不仅消除了旧版本中存在的一些bug,也对参数和格式进行了调整,有需要的伙伴可以到官网查看相关的文档了解更多的细节。
在没有任何其他的意外情况下,达梦主备数据库通常不会出现什么异常情况,但是在某些情况下,比如机房断电未提前通知,主备库异常关闭,监视器异常关闭,长时间断电导致监视器不能正常将主备库拉起,也就出现了主备数据库不一致的情况,或者由于运维人员对于数据库不熟悉,在一些重要升级或者其他操作下,关闭数据库的顺序不对,长时间停库后,也可能导致主备库之间不一致。以上情况下,可通过以下步骤进行恢复。
正式环境不能随意停止主库的运行,那就在此基础上:
1、先尝试重启数据库服务以及守护进程,查看是否能使数据库重新主备同步;
2、尝试后发现无果,进行主库备份还原至备库,将主库上的全备文件上传到备库所在服务器,还原步骤如下:
(1)停备库数据库
cd /data/dmdbms/bin
./DmServiceDAMENG stop(2)将主库的备份传送至备库
cd /bak
scp DB_DAMENG_FULL_2024_04_15_23_00_55 备库IP:/data/backup(3)备库还原备份数据
cd /data/dmdbms/bin
./dmrman
check backupset '/data/backup/DB_DAMENG_FULL_2024_04_15_23_00_55'./dmrman CTLSTMT="RESTORE DATABASE '/data/DAMENG/dm.ini' FROM BACKUPSET '/data/backup/DB_DAMENG_FULL_2024_04_15_23_00_55'"
./dmrman CTLSTMT="RECOVER DATABASE '/data/DAMENG/dm.ini' FROM BACKUPSET '/data/backup/DB_DAMENG_FULL_2024_04_15_23_00_55'"
./dmrman CTLSTMT="RECOVER DATABASE '/data/DAMENG/dm.ini' UPDATE DB_MAGIC"(4)启动备库,修改状态
cd /data/dmdbms/bin
./DmServiceDAMENG start
登录进数据库:
SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);
alter database standby;
SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);(5)备库启动dmwatcher
cd /data/dmdbmd/bin
./DmWatcherServiceDAMENG start(6)检查非确认监视器中数据库状态是否为standby,是否为valid
3、重启服务和守护进程后,通过监视器发现RSTAT仍为“INVALID”
将备库踢出集群,在添加回来:
detach database xxx;
attach database xxx
4、然后发现主库一直处于recovery状态,于是查看select * from v$recover_status;
等待recover_percent属性达到100%,主库即完成recover
5、再次检查数据库状态,确认监视器中显示状态均为VAILD即表示主备库已恢复正常,可通过在主库添加测试表,确认数据是否正常同步。