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

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S