达梦DM8 数据复制系统搭建

2024-04-29 04:32

本文主要是介绍达梦DM8 数据复制系统搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、达梦数据复制简介

达梦数据复制(DATA REPLICATION)是一个分担系统访问压力、加快异地访问响应速度、提高数据可靠性的解决方案。将一个服务器实例上的数据变更复制到另外的服务器实例。可以用于解决大、中型应用中出现的因来自不同地域、不同部门、不同类型的数据访问请求导致数据库服务器超负荷运行、网络阻塞、远程用户的数据响应迟缓的问题。
数据复制系统由以下部件构成:
1.复制服务器;
2.复制节点;
3.各实例站点间通讯的 MAL 系统。
除了系统管理员通过复制服务器定义复制和处理异常外,其他部分的处理及主从服务器之间复制操作对于用户是透明的。整个复制环境的配置境况如下图所示。
在这里插入图片描述
DM 复制系统架构图
在整个环境中有且仅有一台复制服务器(RPS),用户通过 RPS定义复制及复制环境,但RPS并不参与到复制过程中。
DM中,将复制逻辑日志按照配置归档到本站点指定目录称为本地归档,将日志的发送称为日志的远程归档。

二、DM数据复制系统搭建

1、实验环境:

虚拟机软件:VirtualBox 6.1
数据库:DM8 64位,安装包名称为dm8_setup_rh7_64_ent_8.1.1.88.iso 
主机操作系统:CentOS Linux release 7.2.1511 (Core),64位

2、资源规划
配置一个复制服务器、一个主服务器、一个从服务器,相关的IP、端口等规划见下表。
在这里插入图片描述
3、配置 dm.ini
复制服务器

INSTANCE_NAME = REP-SERVER 
PORT_NUM = 5236 
MAL_INI = 1 

主服务器

INSTANCE_NAME = REP-MASTER
PORT_NUM = 5236 
MAL_INI = 1

从服务器

INSTANCE_NAME = REP-SLAVE
PORT_NUM = 5236 
MAL_INI = 1

4、配置dmmal.ini

MAL_CHECK_INTERVAL = 5
MAL_CONN_FAIL_INTERVAL = 5
[MAL_INST1]
MAL_INST_NAME		=	REP-SERVER
MAL_HOST		=	10.0.3.109
MAL_PORT		=	5241
MAL_INST_PORT		=	5236
MAL_INST_HOST		=	192.168.56.109[MAL_INST2]
MAL_INST_NAME		=	REP-MASTER
MAL_HOST		=	10.0.3.110
MAL_PORT		=	5242
MAL_INST_PORT		=	5236
MAL_INST_HOST		=	192.168.56.110[MAL_INST3]
MAL_INST_NAME		=	REP-SLAVE
MAL_HOST		=	10.0.3.111
MAL_PORT		=	5243
MAL_INST_PORT		=	5236
MAL_INST_HOST		=	192.168.56.111

5、复制服务器初始化
如果是第一次使用复制服务器,需要对复制服务器执行初始化操作。通过执行系统函数SP_INIT_REP_SYS(create_flag)来初始化复制服务器。其主要作用是创建复制用户(SYSREP/SYSREP)和创建复制服务器上需要的系统表。SP_INIT_REP_SYS 的参数 create_flag 为 1 时表示创建用户和系统表,为 0 时表示删除用户和系统表。
6、环境的配置

SP_INIT_REP_SYS(1);
SP_RPS_ADD_GROUP('MASTER_TO_SLAVE', '主从同步复制');
SP_RPS_SET_BEGIN('MASTER_TO_SLAVE');
SP_RPS_ADD_REPLICATION ('MASTER_TO_SLAVE', 'REPM2S', 'M 到 S 的同步复制', 'REP-MASTER', 'REP-SLAVE', NULL, '/dm8/data/DAMENG/arch');
SP_RPS_ADD_SCH_MAP('REPM2S', 'SYSDBA', 'SYSDBA', 0);

在这个步骤中出现了一个问题:由于防火墙没有关闭,执行SP_RPS_ADD_REPLICATION这个过程时,一直提示/dm8/data/DAMENG/arch目录无效,如下:

SQL> SP_RPS_ADD_REPLICATION ('MASTER_TO_SLAVE', 'REPM2S', 'M 到 S 的同步复制', 'REP-MASTER', 'REP-SLAVE', NULL, '/dm8/data/DAMENG/arch');
SP_RPS_ADD_REPLICATION ('MASTER_TO_SLAVE', 'REPM2S', 'M 到 S 的同步复制', 'REP-MASTER', 'REP-SLAVE', NULL, '/dm8/arch');
[-2401]:Database file path [/dm8/data/DAMENG/arch] is invalid.
used time: 1.123(ms). Execute id is 0.

多次更换目录和调整目录权限后依然存在这个问题,最后将防火墙关闭后这个错误才解决。
7、系统功能简单测试
在主服务器REP-MASTER实例中创建测试表并插入数据:
在这里插入图片描述
主服务器实例中测试表中数据如下:
在这里插入图片描述
登录从服务器查看数据是否已经复制过来:
在这里插入图片描述

这篇关于达梦DM8 数据复制系统搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/945109

相关文章

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Python极速搭建局域网文件共享服务器完整指南

《Python极速搭建局域网文件共享服务器完整指南》在办公室或家庭局域网中快速共享文件时,许多人会选择第三方工具或云存储服务,但这些方案往往存在隐私泄露风险或需要复杂配置,下面我们就来看看如何使用Py... 目录一、android基础版:HTTP文件共享的魔法命令1. 一行代码启动HTTP服务器2. 关键参

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速

使用Go实现文件复制的完整流程

《使用Go实现文件复制的完整流程》本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中,这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等,文中通过代码示例... 目录案例说明涉及China编程知识点示例代码代码解析示例运行练习扩展小结案例说明我们将通过标准库 os

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处