注册
达梦数据库主备搭建
技术分享/ 文章详情 /

达梦数据库主备搭建

小煎蛋🍳 2023/06/06 2166 0 1

1 、初始化两台数据库
初始化除了安装数据库,调整服务器参数,内容如下
修改 /etc/security/limits.conf
# End of file 前面增加以下代码:
dmdba soft nofile 65535
dmdba hard nofile 65535
dmdba soft nproc 65535
dmdba hard nproc 65535
root soft nofile 65535
root hard nofile 65535
root soft nproc 65535
root hard nproc 65535
修改/etc/systemd/system.conf
增加 DefaultTasksMax=infinity
DefaultLimitCORE=infinity
DefaultLimitNOFILE=100000
DefaultLimitNPROC=100000
修改完并重启服务器参数生效。

2 主库操作

2.1 通过dmrman对主库进行备份
2.2 修改/创建参数文件(修改内容如下)
dm.ini文件:
INSTANCE_NAME = dmserver1
MAL_INI = 1
ARCH_INI = 1
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2
dmarch.ini文件:
[ARCHIVE_REALTIME]
ARCH_TYPE = REALTIME #实时归档类型
ARCH_DEST = DMSERVER2 #实时归档目标实例名(主库侧填写备库实例名)
[ARCHIVE_LOCAL1]
ARCH_TYPE = LOCAL #本地归档类型
ARCH_DEST = /dm/data/dmdbms/arch #本地归档文件存放路径
ARCH_FILE_SIZE = 128 #单位 MB,本地单个归档文件最大值
ARCH_SPACE_LIMIT = 10240 #单位 MB,0 表示无限制,范围 1024~4294967294 MB
dmmal.ini文件
MAL_CHECK_INTERVAL = 5 #MAL 链路检测时间间隔
MAL_CONN_FAIL_INTERVAL = 5 #判定 MAL 链路断开的时间
[MAL_INST1]
MAL_INST_NAME = DMSERVER1 #与 dm.ini 中的 INSTANCE_NAME 一致
MAL_HOST = 192.168.112.140 #MAL 系统监听 TCP 内部网络 IP
MAL_PORT = 5336 #MAL 系统监听 TCP 连接的端口
MAL_INST_HOST = 192.168.112.140 #实例的对外服务 IP 地址
MAL_INST_PORT = 5236 #与 dm.ini 中的 PORT_NUM 一致
MAL_DW_PORT = 5436 #实例对应的守护进程监听 TCP 端口
MAL_INST_DW_PORT = 5536
[MAL_INST2]
MAL_INST_NAME = DMSERVER2 #与 dm.ini 中的 INSTANCE_NAME 一致
MAL_HOST = 192.168.112.141 # MAL 系统监听 TCP 内部网络 IP
MAL_PORT = 5336 #MAL 系统监听 TCP 连接的端口
MAL_INST_HOST = 192.168.112.141 #实例的对外服务 IP 地址
MAL_INST_PORT = 5236 #与 dm.ini 中的 PORT_NUM 一致
MAL_DW_PORT = 5436 #实例对应的守护进程监听 TCP 端口
MAL_INST_DW_PORT = 5536
dmwatcher.ini文件:

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

./dm_service_installer.sh -t dmwatcher -p Watcher -watcher_ini /dm8/data/DAMENG/dmwatcher.ini
2.4备库操作
2.4.1通过SCP命令将主库的配置文件(dmarch.ini/dmmal.ini/dmwatcher.ini)+备份文件copy到备库安装目录下,做以下修改:
2.4.2 修改dm.ini和dmarch.ini
INSTANCE_NAME = dmserver2
MAL_INI = 1
ARCH_INI = 1
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2

dmarch.ini文件:

ARCH_TYPE = REALTIME #实时归档类型
ARCH_DEST = DMSERVER1 #实时归档目标实例名(主库侧填写备库实例名)
ARCH_TYPE = LOCAL #本地归档类型
ARCH_DEST = /dm/data/dmdbms/arch #本地归档文件存放路径
ARCH_FILE_SIZE = 128 #单位 MB,本地单个归档文件最大值
ARCH_SPACE_LIMIT = 10240 #单位 MB,0 表示无限制,范围 1024~4294967294 MB
2.4.3 注册守护进程:
./dm_service_installer.sh -t dmwatcher -p Watcher -watcher_ini /dm8/data/DAMENG/dmwatcher.ini
2.4.4 通过rman还原备库

打开RMAN:
RMAN> RESTORE DATABASE '备库DM.INI目录' FROM BACKUPSET '备份目录';
RMAN> RECOVER DATABASE '备库DM.INI目录' FROM BACKUPSET '备份目录';
RMAN> recover database '备库DM.INI目录' update db_magic

2.5 配置监视器

2.5.1 创建dmmonitor.ini文件
MON_DW_CONFIRM = 0 #确认监视器模式
MON_LOG_PATH = /dm8/log #监视器日志文件存放路径
MON_LOG_INTERVAL = 60 #每隔 60 s 定时记录系统信息到日志文件
MON_LOG_FILE_SIZE = 512 #每个日志文件最大 32 MB
MON_LOG_SPACE_LIMIT =2048 #不限定日志文件总占用空间
[GRP_RW]
MON_INST_OGUID = 20220530 #组 GRP_RW 的唯一 OGUID 值
以下配置为监视器到组 GRP_RW 的守护进程的连接信息,以“IP:PORT”的形式配置
#IP 对应 dmmal.ini 中的 MAL_HOST,PORT 对应 dmmal.ini 中的 MAL_DW_PORT
MON_DW_IP = 192.168.112.140:5436
MON_DW_IP = 192.168.112.141:5436
2.5.2 注册服务
./dm_service_installer.sh -t dmmonitor -p Monitor -monitor_ini /dm8/bin/dmmonitor.ini
2.5.3 配置主库、备库
--主库
--将数据库起到mount
./dmserver /home/dmdba/dmdbms/dmrw/dm.ini mount
./disql SYSDBA/SYSDBA
sp_set_oguid(20220530);
alter database primary;
停库

--备库
--将数据库起到mount
./dmserver /home/dmdba/dmdbms/dmrw/dm.ini mount
./disql SYSDBA/SYSDBA
sp_set_oguid(20220530);
alter database standby;
停库
2.5.4 启动服务

第一步启动主库数据库服务 ./DmServiceDMSERVER1 start
第二步启动备库数据库服务 ./DmServiceDMSERVER2 start
第三步启动主库数据库守护进程服务 ./DmWatcherServiceWatcher start
第四步启动主库数据库守护进程服务 ./DmWatcherServiceWatcher start
第五步启动确认监视器:./DmMonitorServiceMonitor start

评论
后发表回复

作者

文章

阅读量

获赞

扫一扫
联系客服