搭建DM实时主备-数据准备

本文详细介绍了达梦数据库(DM)主备库数据同步的三种方法:数据文件拷贝、联机备份与脱机还原、脱机备份与脱机还原。通过具体步骤指导如何确保主备库数据的一致性,适用于不同场景的数据同步需求。

注:配置数据守护之前,必须先同步实例数据,确保两者保持完全一致;主库可以是新初始化的数据,也可以是正在生产、使用中的数据。DM 提供了两种方式初始化同步实例数据,数据文件拷贝以及备份还原方式。
建议三种方式优先级 数据拷贝>脱机备份、脱机还原>联机备份、脱机还原

一 数据拷贝

1.1 初始化主库

注:主备库数据库软件已安装,只初始化主库实例

$ cd /opt/dmdbms/bin

$ ./dminit PATH=/opt/dmdbms/data CHARSET=1

注:根据需要选择参数进行初始化,对于新初始化的库,首次启动不允许使用 mount 方式需要先正常启动并正常退出,然后才允许 mount 方式启动。

$ ./dmserver /opt/dmdbms/data/DAMENG/dm.ini

在这里插入图片描述
输入 exit 关闭前台进程
在这里插入图片描述

1.2 找到存放数据文件的目录

注:此处为测试环境,数据文件都存放在data文件夹下,所以将data文件夹传输至备库即可

$ cd ../

在这里插入图片描述

$ scp -r data/ dmdba@192.168.189.92:/opt/dmdbms/

注:本次为dmdba用户传送至dmdba用户,所以备机data文件夹所属用户组不用重新授权,如果用root用户传送,需要重新授权

# cd /opt/dmdbms
# chown -R dmdba:dinstall data/

在这里插入图片描述

1.3 检查数据一致性

注:必须已mount方式启动主备库实例
主库:

$ /opt/dmdbms/bin
$ ./dmserver /opt/dmdbms/data/DAMENG/dm.ini mount

在这里插入图片描述
另开窗口

# /opt/dmdbms/bin
# ./disql

在这里插入图片描述
备库:

$ /opt/dmdbms/bin
$ ./dmserver /opt/dmdbms/data/DAMENG/dm.ini mount

另开窗口

# /opt/dmdbms/bin
# ./disql

分别在主备库disql中输入一下sql

SQL> select file_LSN, cur_LSN from v$rlog;

注:主库和备库的 FILE_LSN和 CUR_LSN 值相同,可以确保数据完全一致
主库:
在这里插入图片描述
备库:
在这里插入图片描述
分别在主备库disql中输入一下sql

SQL> select permanent_magic;

注:检查实例的永久魔数是否一致

主库:
在这里插入图片描述
备库:
在这里插入图片描述
主备库的FILE_LSN和 CUR_LSN 值相同且永久魔数一致情况下可进行主备库的配置工作

二 联机备份、脱机还原

注:此种情况适用于生产环境正在使用的数据库且不能停止实例服务,确保主库本地归档开启且为连续归档
主库实例初始化完成且有数据,备库需要初始化实例,参数与主库参数保持一致

2.1 主库联机备份

进入主库disql

# cd /opt/dmdbms/bin
# ./disql
SQL> BACKUP DATABASE BACKUPSET '/opt/dmdbms/data/BACKUP_FILE_01';

在这里插入图片描述
使用root用户

$ cd /opt/dmdbms/data/
$ scp -r BACKUP_FILE_01 dmdba@192.168.189.92:/opt/dmdbms/data/

在这里插入图片描述

2.2 备库脱机还原

$ cd /opt/dmdbms/bin
$ ./dmrman CTLSTMT="RESTORE DATABASE '/opt/dmdbms/data/DAMENG/dm.ini' FROM BACKUPSET '/opt/dmdbms/data/BACKUP_FILE_01'"
$ ./dmrman CTLSTMT="RECOVER DATABASE '/opt/dmdbms/data/DAMENG/dm.ini' FROM BACKUPSET '/opt/dmdbms/data/BACKUP_FILE_01'"
$ ./dmrman CTLSTMT="RECOVER DATABASE '/opt/dmdbms/data/DAMENG/dm.ini' UPDATE DB_MAGIC"

在这里插入图片描述
在这里插入图片描述

三 脱机备份、脱机还原

3.1 主库脱机备份

正常关闭数据库

$ service DmServiceDAMENG stop

查看DmAPService服务是否运行

$ service DmAPService status

在这里插入图片描述
执行以下语句进行脱机备份

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

在这里插入图片描述
拷贝到备库对应目录

$ cd /opt/dmdbms/data/
$ scp -r BACKUP_FILE_01/ dmdba@192.168.189.92:/opt/dmdbms/data/

在这里插入图片描述

3.2 备库脱机还原

确保备库数据库处于关闭状态

$ cd /opt/dmdbms/bin
$ ./dmrman CTLSTMT="RESTORE DATABASE '/opt/dmdbms/data/DAMENG/dm.ini' FROM BACKUPSET '/opt/dmdbms/data/BACKUP_FILE_01'"
$ ./dmrman CTLSTMT="RECOVER DATABASE '/opt/dmdbms/data/DAMENG/dm.ini' FROM BACKUPSET '/opt/dmdbms/data/BACKUP_FILE_01'"
$ ./dmrman CTLSTMT="RECOVER DATABASE '/opt/dmdbms/data/DAMENG/dm.ini' UPDATE DB_MAGIC"

在这里插入图片描述

在这里插入图片描述

3.3 检查数据一致性

注:必须已mount方式启动主备库实例
主库:

$ /opt/dmdbms/bin
$ ./dmserver /opt/dmdbms/data/DAMENG/dm.ini mount

在这里插入图片描述
另开窗口

# /opt/dmdbms/bin
# ./disql

在这里插入图片描述
备库相同操作
分别在主备库disql中输入一下sql

SQL> select file_LSN, cur_LSN from v$rlog;
SQL> select permanent_magic;

主库:
在这里插入图片描述
备库:
在这里插入图片描述
主备库的FILE_LSN和 CUR_LSN 值相同且永久魔数一致情况下可进行主备库的配置工作

### 在 Windows 环境下配置 DM 数据库集群 #### 一、前期准备 在开始部署之前,需确认网络环境和磁盘 I/O 的性能满足需求[^1]。对于 Windows 平台上的达梦数据库 (DM),同样需要完成必要的硬件与软件环境检查。 - **操作系统版本**: 确认已安装支持的 Windows 版本。 - **存储空间分配**: 创建用于存放数据库实例、归档日志以及数据的具体路径。虽然上述 Linux 命令无法直接应用于 Windows,但可以手动创建对应的文件夹结构并设置权限[^2]。 以下是推荐的目录布局: ```plaintext C:\dm8\dminstall -- 达梦数据库软件安装位置 C:\dm8\dmdata -- 实例数据文件存放位置 C:\dm8\dmarch -- 归档日志存放位置 C:\dm8\dmbak -- 份文件存放位置 ``` 通过资源管理器或者命令提示符执行如下操作来建立这些目录: ```cmd mkdir C:\dm8\dminstall mkdir C:\dm8\dmdata mkdir C:\dm8\dmarch mkdir C:\dm8\dmbak ``` 接着调整安全属性以便 `dmdba` 用户能够访问以上各目录。这一步骤可通过右键点击目标文件夹 -> 属性 -> 安全选项卡来进行设定。 #### 二、安装过程概述 按照官方文档指引下载适合当前系统的 DM 软件包,并依据向导逐步推进至结束阶段。在此期间指定先前定义好的各个路径作为相应组件的目标地址。 #### 三、参数调优及初始化脚本编写 为了实现高效的同步复制机制,在节点上编辑配置文件 (`dm.ini`) 中的关键条目比如 `SYNC_MODE`, `ARCH_INI` 和 `HOT_BACKUP` 参数值以适应实际业务场景的需求。另外还需撰写启动服务批处理文件 (.bat), 方便日常运维管理工作开展。 示例代码片段展示如何修改部分重要字段: ```ini [DATABASE] ... SYNC_MODE=1 ; 设置为模式下的强制同步方式 ARCH_INI=1 ; 开启归档功能开关 HOT_BACKUP=0 ; 关闭热份特性(视具体应用而定) ... ``` 最后利用工具生成初始控制文件(`create_controlfile.sql`) 同时加载基础表空间元信息到新构建出来的次级站点之上。 #### 四、测试验证环节 当所有前置条件均已达成之后即可尝试发起连接请求检验整个架构是否正常运作起来。借助 SQL 工具窗口输入简单的查询语句观察返回结果集是否存在差异现象从而判断状态健康程度。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值