达梦数据库实时主备搭建

目录

环境说明

搭建环境部署

配置本地归档

配置 dm.ini,打开 ARCH_INI 参数

配置 dmarch.ini

备份还原数据库

联机备份还原

脱机备份还原

数据准备

配置主库

配置dm.ini

创建dmmal.ini

配置 dmarch.ini

配置 dmwatcher.ini

启动数据库到mount下,修改OGUID及数据库模式

配置备库

配置 dm.ini

配置 dmmal.ini

配置 dmarch.ini

配置 dmwatcher.ini

启动数据库到mount下,修改OGUID及数据库模式

配置监视器

启动守护和监视器

测试守护是否同步可用


环境说明

准备两台机器用来部署主备库,第三台机器用来部署确认监视器。其中主备库配置两块网卡,一块接入内部网络交换模块,一块接入到外部交换机

其他部署环境根据实际情况修改。

实时主备搭建

机器名

初始状态

内部通信IP

外部通行IP

操作系统

zk

主库

192.168.6.1(ip别名zk)

192.168.6.11

Linux

bk

备库

192.168.6.2(ip别名bk)

192.168.6.22

Linux

jsq

监视器

192.168.6.3

192.168.6.3

Linux

搭建环境部署

配置本地归档

配置 dm.ini,打开 ARCH_INI 参数

ARCH_INI = 1

配置 dmarch.ini

[ARCHIVE_LOCAL1]

ARCH_TYPE = LOCAL #本地归档类型

ARCH_DEST = /dm8/data/DAMENG/arch #本地归档文件存放路径

ARCH_FILE_SIZE = 128 #单位 Mb,本地单个归档文件最大值

ARCH_SPACE_LIMIT = 0 #单位 Mb,0 表示无限制,范围 1024~2147483647M

备份还原数据库

联机备份还原

1. 对主库进行联机备份操作

BACKUP DATABASE BACKUPSET '/dm8/data/BACKUP_FILE_01';

2. 拷贝备份文件到备库所在机器

3. 执行脱机数据库还原与恢复(还原恢复需要关闭数据库)

scp -r /dm8/data/BACKUP_FILE_01 dmdba@bk:/dm8/data/BACKUP_FILE_01

./dmrman CTLSTMT="RESTORE DATABASE '/dm8/data/DAMENG/dm.ini' FROM BACKUPSET '/dm8/data/BACKUP_FILE_01'"

./dmrman CTLSTMT="RECOVER DATABASE '/dm8/data/DAMENG/dm.ini' FROM BACKUPSET '/dm8/data/BACKUP_FILE_01'"

./dmrman CTLSTMT="RECOVER DATABASE '/dm8/data/DAMENG/dm.ini' UPDATE DB_MAGIC"

脱机备份还原

1. 正常关闭数据库

2. 进行脱机备份(/dm8/bin目录下)

3. 拷贝备份文件到备库所在机器

./dmrman CTLSTMT="BACKUP DATABASE '/dm8/data/DAMENG/dm.ini' FULL TO BACKUP_FILE1 BACKUPSET '/dm8/data/BACKUP_FILE_01'"

scp -r /dm8/data/BACKUP_FILE_01 dmdba@bk:/dm8/data/BACKUP_FILE_01

4. 执行脱机数据库还原与恢复

./dmrman CTLSTMT="RESTORE DATABASE '/dm8/data/DAMENG/dm.ini' FROM BACKUPSET '/dm8/data/BACKUP_FILE_01'"

脱机备份未生产redo日志,故可省略恢复数据库的操作步骤。

数据库更新

./dmrman CTLSTMT="RECOVER DATABASE '/dm8/data/DAMENG/dm.ini' UPDATE DB_MAGIC"

数据准备

在机器上初始化库至目录/dm8/data:

./dminit path=/dm8/data

配置主库

配置dm.ini

安装实例目录(/dm8/data/DAMENG,下同)下的dm.ini修改参数如下:

#实例名,建议使用―组名_守护环境_序号‖的命名方式,总长度不能超过 16

INSTANCE_NAME = zk

PORT_NUM = 5236 #数据库实例监听端口

DW_INACTIVE_INTERVAL = 60 #接收守护进程消息超时时间

ALTER_MODE_STATUS = 0 #不允许手工方式修改实例模式/状态/OGUID

ENABLE_OFFLINE_TS = 2 #不允许备库 OFFLINE 表空间

MAL_INI = 1 #打开 MAL 系统

ARCH_INI = 1 #打开归档配置

RLOG_SEND_APPLY_MON = 64 #统计最近 64 次的日志发送信息

创建dmmal.ini

在数据库实例目录下创建dmmal.ini,内容如下:

MAL_CHECK_INTERVAL = 5 #MAL 链路检测时间间隔

MAL_CONN_FAIL_INTERVAL = 5 #判定 MAL 链路断开的时间

[MAL_INST1]

 MAL_INST_NAME = zk #实例名,和 dm.ini 中的 INSTANCE_NAME 一致

 MAL_HOST = 192.168.6.1 #MAL 系统监听 TCP 连接的 IP 地址

 MAL_PORT = 61141 #MAL 系统监听 TCP 连接的端口

 MAL_INST_HOST = 192.168.6.11 #实例的对外服务 IP 地址

 MAL_INST_PORT = 5236 #实例的对外服务端口,和 dm.ini 中的 PORT_NUM 一致

 MAL_DW_PORT = 52141 #实例本地的守护进程监听 TCP 连接的端口

MAL_INST_DW_PORT = 33141 #实例监听守护进程 TCP 连接的端口

[MAL_INST2]

 MAL_INST_NAME = bk

MAL_HOST = 192.168.6.2

 MAL_PORT = 61142

 MAL_INST_HOST = 192.168.6.22

 MAL_INST_PORT = 5236

 MAL_DW_PORT = 52142

MAL_INST_DW_PORT = 33142

配置 dmarch.ini

修改 dmarch.ini,配置本地归档和实时归档:

[ARCHIVE_REALTIME]

ARCH_TYPE = REALTIME #实时归档类型

ARCH_DEST = bk #实时归档目标实例名

[ARCHIVE_LOCAL1]

ARCH_TYPE = LOCAL #本地归档类型

ARCH_DEST = /dm8/data/DAMENG/arch #本地归档文件存放路径

ARCH_FILE_SIZE = 128 #单位 Mb,本地单个归档文件最大值

ARCH_SPACE_LIMIT = 0 #单位 Mb,0 表示无限制,范围 1024~2147483647M

配置 dmwatcher.ini

修改 dmwatcher.ini 配置守护进程,配置为全局守护类型,使用自动切换模式:

[GRP1]

DW_TYPE = GLOBAL #全局守护类型

DW_MODE = AUTO #自动切换模式

DW_ERROR_TIME = 10 #远程守护进程故障认定时间

INST_RECOVER_TIME = 60 #主库守护进程启动恢复的间隔时间

INST_ERROR_TIME = 10 #本地实例故障认定时间

INST_OGUID = 453331 #守护系统唯一 OGUID 值

INST_INI = /dm8/data/DAMENG/dm.ini #dm.ini 配置文件路径

INST_AUTO_RESTART = 1 #打开实例的自动启动功能

INST_STARTUP_CMD = /dm8/bin/dmserver #命令行方式启动

RLOG_SEND_THRESHOLD = 0 #指定主库发送日志到备库的时间阈值,默认关闭

RLOG_APPLY_THRESHOLD = 0 #指定备库重演日志的时间阈值,默认关闭

启动数据库到mount下,修改OGUID及数据库模式

./dmserver /dm8/data/DAMENG/dm.ini mount

SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);

sp_set_oguid(453331);

alter database primary;

SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);

配置备库

配置 dm.ini

dm.ini修改如下:

#实例名,建议使用―组名_守护环境_序号‖的命名方式,总长度不能超过 16

INSTANCE_NAME = bk

PORT_NUM = 5236#数据库实例监听端口

DW_INACTIVE_INTERVAL = 60 #接收守护进程消息超时时间

ALTER_MODE_STATUS = 0 #不允许手工方式修改实例模式/状态/OGUID

ENABLE_OFFLINE_TS = 2 #不允许备库 OFFLINE 表空间

MAL_INI = 1 #打开 MAL 系统

ARCH_INI = 1 #打开归档配置

RLOG_SEND_APPLY_MON = 64 #统计最近 64 次的日志重演信息

配置 dmmal.ini

备库的dmmal.ini和主库一致,直接复制即可,可主库通过scp命令发送到备库实现:

scp -r /dm8/data/DAMENG/dmmal.ini dmdba@bk:/dm8/data/DAMENG/dmmal.ini

配置 dmarch.ini

修改 dmarch.ini,配置本地归档和实时归档:

[ARCHIVE_REALTIME]

ARCH_TYPE = REALTIME #实时归档类型

ARCH_DEST = zk #实时归档目标实例名

[ARCHIVE_LOCAL1]

ARCH_TYPE = LOCAL #本地归档类型

ARCH_DEST = /dm8/data/DAMENG/arch #本地归档文件路径

ARCH_FILE_SIZE = 128 #单位 Mb,本地单个归档文件最大值

ARCH_SPACE_LIMIT = 0 #单位 Mb,0 表示无限制,范围 1024~2147483647M

配置 dmwatcher.ini

[GRP1]

DW_TYPE = GLOBAL #全局守护类型

DW_MODE = AUTO #自动切换模式

DW_ERROR_TIME = 10 #远程守护进程故障认定时间

INST_RECOVER_TIME = 60 #主库守护进程启动恢复的间隔时间

INST_ERROR_TIME = 10 #本地实例故障认定时间

INST_OGUID = 453331 #守护系统唯一 OGUID 值

INST_INI = /dm8/data/DAMENG/dm.ini #dm.ini 配置文件路径

INST_AUTO_RESTART = 1 #打开实例的自动启动功能

INST_STARTUP_CMD = /dm8/bin/dmserver #命令行方式启动

RLOG_APPLY_THRESHOLD = 0 #指定备库重演日志的时间阈值,默认关闭

启动数据库到mount下,修改OGUID及数据库模式

./dmserver /dm8/data/DAMENG/dm.ini mount

SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);

sp_set_oguid(453331);

alter database  standby;

SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);

配置监视器

以配置单实例监视器为例,在jsq这台机器上配置监视器:

修改 dmmonitor.ini 配置确认监视器(在/dm8/data目录下创建):

MON_DW_CONFIRM = 1 #确认监视器模式

MON_LOG_PATH = /dm8/data/log #监视器日志文件存放路径

MON_LOG_INTERVAL = 60 #每隔 60s 定时记录系统信息到日志文件

MON_LOG_FILE_SIZE = 32 #每个日志文件最大 32M

MON_LOG_SPACE_LIMIT = 0 #不限定日志文件总占用空间

[GRP1]

MON_INST_OGUID = 453331 #组 GRP1 的唯一 OGUID 值 #以下配置为监视器到组 GRP1 的守护进程的连接信息,以―IP:PORT‖的形式配置

#IP 对应 dmmal.ini 中的 MAL_HOST,PORT 对应 dmmal.ini 中的 MAL_DW_PORT

MON_DW_IP = 192.168.6.1:52141#内网ip

MON_DW_IP = 192.168.6.2:52142#内网ip

启动守护和监视器

启动各个主备库上的守护进程(先主后备),最后再启动监视器:

./dmwatcher /dm8/data/DAMENG/dmwatcher.ini

./dmmonitor /dm8/data/dmmonitor.ini

测试守护是否同步可用

在监视器中输入show命令查看是否同步:

在监视器中输入tip命令查看守护集群是否正常

 

https://eco.dameng.com

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值