达梦数据库-主备搭建

作为一个达梦的初学者,写这篇文章的目的是为了把学到的新知识做个总结梳理,在整理中查缺补漏,也希望大家看了我的文章能有收获,如有错误的地方欢迎指出。

--------------------------------------------------------------------------------------------------------------------------------

一、相关原理介绍

日志缓冲区:数据库操作时产生的日志不会立即被写入磁盘的REDO日志,会先存放在内存里的日志缓冲区,通过修改dm.ini中的RLOG_POOL_SIZE参数来调整大小

Redo日志:即重做日志,它包含了所有物理数据页的修改内容, DML 操作、DDL 操作,最终都会转化为对物理数据页的修改,这些修改都会反映到 Redo 日志中,并且数据的变动都是先写入到 Redo 日志,后同步至数据文件中。可以通过语句select * from v$rlogfile;查看日志信息。

归档日志:上述重做日志是循环使用的,当重做日志被写满后,会根据检查点覆盖之前的内容,当开启归档后,会在覆盖前将重做日志数据复制到归档日志中。

MAL系统:基于 TCP 协议实现的一种内部通信机制,DM 通过 MAL 系统实现 Redo 日志传输,以及其他一些实例间的消息通讯。

Redo日志包:即Rlog_PKG,是DM数据库批量保存REDO日志的数据单元,一物理事务PTX为单位保存日志,一个日志包内可以连续保存一个或多个PTX.DM 数据守护系统中,主库以RLOG_PKG 为最小单位发送 Redo 日志到备库。

守护进程(dmwatcher):是数据库守护系统的核心工具,监控数据库的实例运行状态和主备库数据库的同步情况,在出现故障时启动各种处理预案。

监视器(dmmonitor):用来监控守护系统内守护进程、数据库实例学习,执行用户输入命令、监控实例故障、实现自动切换等。支持两种模式:监控模式和确认模式(1套集群环境只能配置1个确认模式)

实时归档(REALTIME):主库在redo日志(RLOG_PKG)写入redo-log文件前,将redo日志发送到备库。实时归档分类两种模式:事务一致和高性能,默认高性能模式。1

即时归档(TIMELY):主库在redo日志(RLOG_PKG)写入redo-log文件后,将redo日志发送到备库。即时归档分为两种模式:事务一致和高性能,默认事务一致模式。0

事务一致模式:备库收到主库发送的Redo日志,并重演完成后再响应主库。

高性能模式:备库收到主库发送的redo日志后,马上响应主库,再启动日志重演。

建议主备集群:实时归档+高性能

-------------------------------理论知识就介绍这么多,接下来上机操作--------------------------------------------

二、安装部署

2.1  初始化两台数据库

IP分别为192.168.112.140、192.168.112.141   初始化后需要正常启停一次。

2.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.1.1 调整一下数据库参数(非必须)

        使用脚本根据服务器内存磁盘空间等优化数据库参数

2.2 主库操作

2.2.1 通过dmrman对主库进行备份

2.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.2.3 注册守护进程:

./dm_service_installer.sh -t dmwatcher -p Watcher -watcher_ini /dm8/data/DAMENG/dmwatcher.ini

 2.3 备库操作

2.3.1通过SCP命令将主库的配置文件(dmarch.ini/dmmal.ini/dmwatcher.ini)+备份文件copy到备库安装目录下,做以下修改:

2.3.2 修改dm.ini和dmarch.ini

        dm.ini文件

INSTANCE_NAME = dmserver2
MAL_INI = 1
ARCH_INI = 1
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2

        dmarch.ini文件:

[ARCHIVE_REALTIME]
ARCH_TYPE     = REALTIME  #实时归档类型
ARCH_DEST     = DMSERVER1   #实时归档目标实例名(主库侧填写备库实例名)
[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

 2.3.3 注册守护进程:

./dm_service_installer.sh -t dmwatcher -p Watcher -watcher_ini /dm8/data/DAMENG/dmwatcher.ini

2.3.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.4 配置监视器

2.4.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.4.2 注册服务

./dm_service_installer.sh -t dmmonitor -p Monitor -monitor_ini /dm8/bin/dmmonitor.ini

2.5 配置数据库修改参数

2.5.1 配置主库、备库

--主库
--将数据库起到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.2  启动服务

第一步启动主库数据库服务 ./DmServiceDMSERVER1 start

第二步启动备库数据库服务 ./DmServiceDMSERVER2 start

第三步启动主库数据库守护进程服务 ./DmWatcherServiceWatcher start

第四步启动主库数据库守护进程服务 ./DmWatcherServiceWatcher start

第五步启动确认监视器:./DmMonitorServiceMonitor start

          前台启动非确认模式:./dmmonitor /dm8/bin/dmmonitor_manual.ini

 

      达梦社区地址:https://eco.dameng.com

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值