达梦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

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat

linux系统中java的cacerts的优先级详解

《linux系统中java的cacerts的优先级详解》文章讲解了Java信任库(cacerts)的优先级与管理方式,指出JDK自带的cacerts默认优先级更高,系统级cacerts需手动同步或显式... 目录Java 默认使用哪个?如何检查当前使用的信任库?简要了解Java的信任库总结了解 Java 信

C#利用Free Spire.XLS for .NET复制Excel工作表

《C#利用FreeSpire.XLSfor.NET复制Excel工作表》在日常的.NET开发中,我们经常需要操作Excel文件,本文将详细介绍C#如何使用FreeSpire.XLSfor.NET... 目录1. 环境准备2. 核心功能3. android示例代码3.1 在同一工作簿内复制工作表3.2 在不同

C#使用iText获取PDF的trailer数据的代码示例

《C#使用iText获取PDF的trailer数据的代码示例》开发程序debug的时候,看到了PDF有个trailer数据,挺有意思,于是考虑用代码把它读出来,那么就用到我们常用的iText框架了,所... 目录引言iText 核心概念C# 代码示例步骤 1: 确保已安装 iText步骤 2: C# 代码程

Pandas处理缺失数据的方式汇总

《Pandas处理缺失数据的方式汇总》许多教程中的数据与现实世界中的数据有很大不同,现实世界中的数据很少是干净且同质的,本文我们将讨论处理缺失数据的一些常规注意事项,了解Pandas如何表示缺失数据,... 目录缺失数据约定的权衡Pandas 中的缺失数据None 作为哨兵值NaN:缺失的数值数据Panda

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

k8s搭建nfs共享存储实践

《k8s搭建nfs共享存储实践》本文介绍NFS服务端搭建与客户端配置,涵盖安装工具、目录设置及服务启动,随后讲解K8S中NFS动态存储部署,包括创建命名空间、ServiceAccount、RBAC权限... 目录1. NFS搭建1.1 部署NFS服务端1.1.1 下载nfs-utils和rpcbind1.1