基于银河麒麟系统ARM架构安装达梦数据库并配置主从模式
达梦数据库简要概述
达梦数据库(DM Database)是一款由武汉达梦公司开发的关系型数据库管理系统,支持多种高可用性和数据同步方案。在主从模式(也称为 Master-Slave 或 Primary-Secondary 模式)中,主要通过以下几种方式来实现数据的复制和高可用性:
主从复制模式概述
-
实时归档
- 在这种模式下,主库(Primary)将日志信息实时发送到备库(Secondary)。一旦主库发生事务操作,相关的日志会立即被传输到备库,并在备库上重演这些日志,以保持数据的一致性。
-
即时归档
- 即时归档要求主库在每次提交事务前等待备库确认已经收到并记录了相关日志信息。这种方式提供了更高的数据一致性保证,但可能会影响性能,因为它增加了事务提交的延迟。
-
定时归档
- 定时归档允许配置一个时间间隔,在这个间隔内主库会批量地向备库发送日志文件。这种方式适合于对数据一致性要求不是极高,且希望减少网络流量和提高效率的情况。
-
异步归档
- 异步归档不要求主库等待备库的确认即可完成事务提交。这提高了主库的性能,但是降低了数据同步的及时性,因为如果主库出现故障,最近的一些更新可能还未被复制到备库。
主从模式的优点
- 高可用性:当主服务器出现故障时,可以快速切换到备用服务器,减少停机时间。
- 负载均衡:可以通过只读副本分担查询负载,减轻主服务器的压力。
- 灾难恢复:提供了一种有效的灾难恢复机制,确保数据的安全性和可恢复性。
注意事项
- 需要根据实际的应用场景选择合适的复制策略,平衡好数据一致性、性能以及可用性的需求。
- 在配置主从复制时,还需要考虑网络带宽、延迟等因素的影响,以确保数据能够高效准确地同步。
一、查看使用的linux版本以及架构信息

二、下载指定版本

三、修改主机名
主库 192.168.116.99 实例名 dmdb-0001 从库 192.168.116.34 实例名 dmdb-0002
四、关闭防火墙
systemctl stop firewalld && systemctl disable firewalld
五、创建dmdba用户和组
创建用户所在的组,命令如下:
groupadd dinstall -g 2001
创建用户,命令如下:
useradd -G dinstall -m -d /data/dmdba -s /bin/bash -u 2001 dmdba

修改用户密码,命令如下:
passwd dmdba
注意:密码需要字母大小写加数字特殊字符

六、修改主从的 文件
使用 root 用户打开 /etc/security/limits.conf 文件进行修改,命令如下:
vim /etc/security/limits.conf
在最后添加下面的语句,需添加的语句如下:
dmdba soft nice 0dmdba hard nice 0dmdba soft as unlimiteddmdba hard as unlimiteddmdba soft fsize unlimiteddmdba hard fsize unlimiteddmdba soft nproc 65536dmdba hard nproc 65536dmdba soft nofile 65536dmdba hard nofile 65536dmdba soft core unlimiteddmdba hard core unlimiteddmdba soft data unlimiteddmdba hard data unlimited
切换到 dmdba 用户,查看是否生效,命令如下:
su dmdbaulimit -a
不生效的话重启服务器
七、规划相关目录
可根据实际需求规划安装目录,本示例使用默认配置 DM 数据库安装在 /data/dmdba 文件夹下。
1、实例存储目录
mkdir -p /data/dmdba/dmdata
2、归档存储目录
mkdir -p /data/dmdba/arch
2、备份存储目录
mkdir -p /data/dmdba/dmbak
新建的路径目录权限的用户修改为 dmdba,用户组修改为 dinstall。
chown -R dmdba:dinstall /data/dmdba/
给路径下的文件设置 755 权限。
chmod -R 755 /data/dmdba


初始化数据库
./dminit PATH=/data/dmdba/dmdata PAGE_SIZE=32 CHARSET=1 CASE_SENSITIVE=0 SYSDBA_PWD=大小写特殊字符加数字 SYSAUDITOR_PWD=大小写特殊字符加数字 DB_NAME=dm INSTANCE_NAME=dm1 PORT_NUM=5236

dmdba用户前台启动实例主从库都执行一下,生成实例对应文件,启动后关闭即可

八、主库进行脱机备份
脱机备份前要关闭数据库实例,否则备份会出错,为了保证数据同步前的一致性。
在主库 data/dmdba/dmdbms/bin目录下执行
cd /data/dmdba/dmdbms/bin./dmrmanBACKUP DATABASE '/data/dmdba/dmdata/dm/dm.ini' FULL BACKUPSET '/data/dmdba/dmbak/full_database';

然后把主库备份文件发送到从库
scp -r /data/dmdba/dmbak/full_database 192.168.116.34:/data/dmdba/dmbak/full_database
然后来到从库进行恢复操作
cd /data/dmdba/dmdbms/bin./dmrmanRESTORE DATABASE '/data/dmdba/dmdata/dm/dm.ini' FROM BACKUPSET '/data/dmdba/dmbak/full_database';RECOVER DATABASE '/data/dmdba/dmdata/dm/dm.ini' UPDATE DB_MAGIC;

九、修改并编辑数据库配置文件编辑
实例配置文件:dm.ini
归档配置文件:dmarch.ini
MAL系统配置文件:dmmal.ini
守护进程配置文件:dmwatcher.ini
监视器配置文件:dmmonitor.ini
1、主库修改/data /dmdba/dmdata/dm/dm.ini
INSTANCE_NAME = dm1 #修改实例名MAL_INI = 1 #打开 MAL 系统ARCH_INI = 1 #打开归档配置ALTER_MODE_STATUS = 0 #不允许手工方式修改实例模式/状态/OGUIDENABLE_OFFLINE_TS = 2 #不允许备库 OFFLINE 表空间
2、从库修改/data /dmdba/dmdata/dm/dm.ini
INSTANCE_NAME = dm2 #修改实例名MAL_INI = 1 #打开 MAL 系统ARCH_INI = 1 #打开归档配置ALTER_MODE_STATUS = 0 #不允许手工方式修改实例模式/状态/OGUIDENABLE_OFFLINE_TS = 2 #不允许备库 OFFLINE 表空间
3、主库配置归档配置文件/data /dmdba/dmdata/dm/dmarch.ini
[ARCHIVE_REALTIME]ARCH_TYPE = REALTIME #归档类型ARCH_DEST = dm2 #归档目标实例名(主库侧填写备库实例名)[ARCHIVE_LOCAL1]ARCH_TYPE = LOCAL #本地归档类型ARCH_DEST = /data/dmdba/arch/ #本地归档文件存放路径ARCH_FILE_SIZE = 128 #单位 MB,本地单个归档文件最大值ARCH_SPACE_LIMIT = 0 #单位 MB,0 表示无限制,范围 1024~4294967294 MB
4、从库配置归档配置文件/data /dmdba/dmdata/dm/dmarch.ini
[ARCHIVE_REALTIME]ARCH_TYPE = REALTIMEARCH_DEST = dm1[ARCHIVE_LOCAL1]ARCH_TYPE = LOCALARCH_DEST = /data/dmdba/arch/ARCH_FILE_SIZE = 128ARCH_SPACE_LIMIT = 0
5、MAL系统配置文件/data/dmdba/dmdata/dm/dmmal.ini
主从库配置一样
MAL_CHECK_INTERVAL = 5 # MAL链路检测时间间隔MAL_CONN_FAIL_INTERVAL = 5 # 判定 MAL链路断开的时间[MAL_INST1]MAL_INST_NAME = dm1 #与 dm.ini中的 INSTANCE_NAME一致MAL_HOST = 主库IP # MAL系统监听 TCP 内部网络 IPMAL_PORT = 61141 # MAL系统监听 TCP连接的端口MAL_INST_HOST = 主库IP #实例的对外服务 IP地址MAL_INST_PORT = 5236 #与 dm.ini中的 PORT_NUM一致MAL_DW_PORT = 52141 #实例对应的守护进程监听 TCP 端口MAL_INST_DW_PORT = 33141[MAL_INST2]MAL_INST_NAME = dm2 #与 dm.ini中的 INSTANCE_NAME 一致MAL_HOST = 从库IP # MAL系统监听 TCP内部网络 IPMAL_PORT = 61141 # MAL系统监听 TCP连接的端口MAL_INST_HOST = 从库IP #实例的对外服务 IP地址MAL_INST_PORT = 5236 #与 dm.ini中的 PORT_NUM一致MAL_DW_PORT = 52141 #实例对应的守护进程监听 TCP端口MAL_INST_DW_PORT = 33141
6、守护进程配置文件 /data/dmdba/dmdata/dm/dmwatcher.ini
主从库配置一样
[GRP_RW]DW_TYPE = GLOBAL #全局守护类型DW_MODE = AUTO #自动切换模式DW_ERROR_TIME = 10 #远程守护进程故障认定时间INST_RECOVER_TIME = 60 #主库守护进程启动恢复的间隔时间INST_ERROR_TIME = 10 #本地实例故障认定时间INST_OGUID = 453331 #守护系统唯一 OGUID 值INST_INI = /data/dmdba/dmdata/dm/dm.ini # dm.ini 配置文件路径INST_AUTO_RESTART = 1 #打开实例的自动启动功能INST_STARTUP_CMD = /data/dmdba/dmdbms/bin/dmserver #命令行方式启动
7、监视器配置文件 /data/dmdba/dmdata/dm/dmmonitor.ini
可以放主库也可以放从库,更可以放第三台机上
MON_DW_CONFIRM = 1 #确认监视器模式MON_LOG_PATH = /data/dmdba/dmdata/dmmonitor_auto/log #监视器日志文件存放路径可以自定义,没有自行创建MON_LOG_INTERVAL = 60 #每隔 60 s 定时记录系统信息到日志文件MON_LOG_FILE_SIZE = 32 #每个日志文件最大 32 MBMON_LOG_SPACE_LIMIT = 0 #不限定日志文件总占用空间[GRP_RW]MON_INST_OGUID = 453331 #组 GRP_RW 的唯一 OGUID 值#以下配置为监视器到组 GRP_RW 的守护进程的连接信息,以“IP:PORT”的形式配置#IP 对应 dmmal.ini 中的 MAL_HOST,PORT 对应 dmmal.ini 中的 MAL_DW_PORTMON_DW_IP = 主库:52141MON_DW_IP = 从库:52141
十、启动主从数据库
主库启动(以挂载的形式启动)
cd /data/dmdba/dmdbms/bin./dmserver /data/dmdba/dmdata/dm/dm.ini mount
启动成功后新开一个窗口,切换dmdba用户
使用disql工具连接数据库注意使用cd /data/dmdba/dmdbms/bin
./disql
用户/密码是前面初始化时设置的密码
从库启动(以挂载的形式启动)
cd /data/dmdba/dmdbms/bin./dmserver /data/dmdba/dmdata/dm/dm.ini mount
启动成功后新开一个窗口,切换dmdba用户
使用disql工具连接数据库注意使用cd /data/dmdba/dmdbms/bin
./disql
用户/密码是前面初始化时设置的密码
十一、配置主从模式
主库执行操作
SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);sp_set_oguid(453331); #修改 oguidalter database primary; #修改为 primary 模式SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);
执行完以上操作记得exit退出sql命令行
从库执行操作
SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);sp_set_oguid(453331); #修改 oguidalter database standby; #修改为 standby 模式SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);
执行完以上操作记得exit退出sql命令行
启动守护进程
主从库使用dmdba用户执行相同操作
cd /data/dmdba/dmdbms/bin./dmwatcher /data/dmdba/dmdata/dm/dmwatcher.ini
启动监视器
在安装有监视器的机器执行新开一个窗口注意使用dmdba用户
cd /data/dmdba/dmdbms/bin./dmmonitor /data/dmdba/dmdata/dm/dmmonitor.ini

监视器显示WSTATUS(OPEN)、ISTATUS(OPEN)、RTYPE(REALTIME)、RSTAT(VALID)有数据表名主从搭建完成。
验证数据同步状态
主库使用dmdba用户登录然后再用disql工具连接
创建表插入数据
cd /data/dmdba/dmdbms/bin./disql
用户/密码是前面初始化时设置的密码
create table test(id int, name varchar2(30)); #创建表insert into test values (1, 'one'); #插入数据select * from test; #查看表数据commit;
select * from date;
从库验证创建的表以及插入的数据
从库使用dmdba用户登录数据库再用用disql工具查看同步数据
./disql
用户/密码是前面初始化时设置的密码
注册服务
上面操作都是前台启动的方式,关闭窗口就会退出,下面我们将启动命令注册为系统服务。
主从库都操作使用root用户到数据库安装目录
注册守护进程服务
cd /data/dmdba/dmdbms/script/root/./dm_service_installer.sh -t dmwatcher -p dmrw -dm_ini /data/dmdba/dmdata/dm/dm.ini -watcher_ini /data/dmdba/dmdata/dm/dmwatcher.ini
注册数据库实例服务
./dm_service_installer.sh -t dmserver -p dmrw -dm_ini /data/dmdba/dmdata/dm/dm.ini
注册监视器服务(只在安装监视器的机器上执行)
./dm_service_installer.sh -t dmmonitor -p confirm -dm_ini /data/dmdba/dmdata/dm/dm.ini -monitor_ini /data/dmdba/dmdata/dm/dmmonitor.ini
使用启动命令启动服务
先将之前用前台启动的窗口关掉
启动数据库(主从都启动)
systemctl start DmServicedmrw
启动守护进程(主从都启动)
systemctl start DmWatcherServicedmrw
启动监视器(主库启动)
systemctl start DmMonitorServiceconfirm
注意启动和关闭顺序
启动 主库启动 → 从库启动 → 主库守护进程 → 从库守护进程 → 监视器
停止 监视器 → 主库守护进程 → 从库守护进程 → 从库停止 → 主库停止
相关文章:
基于银河麒麟系统ARM架构安装达梦数据库并配置主从模式
达梦数据库简要概述 达梦数据库(DM Database)是一款由武汉达梦公司开发的关系型数据库管理系统,支持多种高可用性和数据同步方案。在主从模式(也称为 Master-Slave 或 Primary-Secondary 模式)中,主要通过…...
【AWS入门】AWS云计算简介
【AWS入门】AWS云计算简介 A Brief Introduction to AWS Cloud Computing By JacksonML 什么是云计算?云计算能干什么?我们如何利用云计算?云计算如何实现? 带着一系列问题,我将做一个普通布道者,引领广…...
适合企业内训的AI工具实操培训教程(37页PPT)(文末有下载方式)
详细资料请看本解读文章的最后内容。 资料解读:适合企业内训的 AI 工具实操培训教程 在当今数字化时代,人工智能(AI)技术迅速发展,深度融入到各个领域,AIGC(人工智能生成内容)更是成…...
【数据结构与算法】Java描述:第四节:二叉树
一、树的相关概念 编程中的树是模仿大自然中的树设计的,呈现倒立的结构,我们着重掌握 二叉树 。 1.1 基本概念: 结点的度:一个结点有几个子结点,度就是几; 如上图:A的度为3 树的度࿱…...
【一起来学kubernetes】14、StatefulSet使用详解
一、核心特性二、架构与组件三、生命周期管理四、典型应用场景**五、注意事项与最佳实践六、对比Deployment一、应用场景二、Pod管理三、部署与更新策略四、其他特性 七、常见问题八、拓展 前文中我们介绍了k8s中常用的一种控制器 Deployment,与之向对应的ÿ…...
Day5 结构体、文字显示与GDT/IDT初始化
文章目录 1. harib02b用例(使用结构体)2. harib02c用例3. harib02d用例(显示字符图案)3. harib02e用例(增加字符图案)4. harib02g用例4.1 显示字符串4.2 显示变量值 5. harib02h用例(显示鼠标&a…...
AI第一天 自我理解笔记--微调大模型
目录 1. 确定目标:明确任务和数据 2. 选择预训练模型 3. 数据预处理 (1) 数据清洗与格式化 (2) 划分数据集 (3) 数据加载与批处理 4. 构建微调模型架构 (1) 加载预训练模型 (2) 修改模型尾部(适配任务) (3) 冻结部分层(可…...
ClientAbortException问题分析
最近遇到一个问题,在设备采数据数据上报后频繁发生ClientAbortException异常,一种处理方案是ClientAbortException 问题分析-CSDN博客 一、ClientAbortException 的触发与影响 1. 定义与场景 ClientAbortException 是后端服务器(如 Tomc…...
系统思考全球化落地
感谢加密货币公司Bybit的再次邀请,为全球团队分享系统思考课程!虽然大家来自不同国家,线上学习的形式依然让大家充满热情与互动,思维的碰撞不断激发新的灵感。 尽管时间存在挑战,但我看到大家的讨论异常积极ÿ…...
【开原宝藏】30天学会CSS - DAY1 第一课
下面提供一个由浅入深、按步骤拆解的示例教程,让你能从零开始,逐步理解并实现带有旋转及悬停动画的社交图标效果。为了更简单明了,以下示例仅创建四个图标(Facebook、Twitter、Google、LinkedIn),并在每一步…...
钉钉项目报销与金蝶系统高效集成技术解析
钉钉报销【项目报销类】集成到金蝶付款单【画纤骨】的技术实现 在企业日常运营中,数据的高效流转和准确对接是提升业务效率的关键。本文将分享一个具体的系统对接集成案例:如何将钉钉平台上的项目报销数据无缝集成到金蝶云星空的付款单系统中。本次方案…...
Python——代码格式
代码格式 良好的代码格式可以提升代码的可读性。和其他语言不同,Python 代码的格式是 Python 语法的组成之一,不符合 Python 代码无法正常运行。 注释 注释是代码中穿插的辅佐性质的文字,用于标识代码的含义和功能,可以提高程序…...
Datawhale coze-ai-assistant:Task 1 了解 AI 工作流 + Coze的介绍
学习网址:Datawhale-学用 AI,从此开始 工作流(Workflow)是指完成一项任务或目标时,按照特定顺序进行的一系列活动或步骤。它强调在计算机应用环境下的自动化,通过将复杂的任务拆分成多个简单的步骤,每一步都…...
深度学习 Deep Learning 第3章 概率论与信息论
第三章 概率与信息论 概述 本章介绍了概率论和信息论的基本概念及其在人工智能和机器学习中的应用。概率论为处理不确定性提供了数学框架,使我们能够量化不确定性和推导新的不确定陈述。信息论则进一步帮助我们量化概率分布中的不确定性。在人工智能中,…...
GStreamer —— 2.15、Windows下Qt加载GStreamer库后运行 - “播放教程 1:Playbin 使用“(附:完整源码)
运行效果 介绍 我们已经使用了这个元素,它能够构建一个完整的播放管道,而无需做太多工作。 本教程介绍如何进一步自定义,以防其默认值不适合我们的特定需求。将学习: • 如何确定文件包含多少个流,以及如何切换 其中。…...
MYsql—1
1.mysql的安装 在windows下安装mysql,直接官网搜索即可:http://www.mysql.com/,自己找想要的版本进行download,官网长这样 安装路径需要是英文路径,设置默认即可,若安装执行内容时报错,则AltCt…...
位运算(基础算法)
按位与AND( & ) 只有当两个位都为1时,结果才为1,否则为0。结果不会变大 按位或 OR( | ) 只有当两个位中有一个为1时,结果才为1,否则为0。结果不会变小 按位异或 XOR ( ^ ) 只…...
硬件地址反序?用位操作为LED灯序“纠偏”。反转二进制数即可解决
特别有意思,LED的灯序与其硬件地址刚好相反,没办法直接通过加1实现二进制进位的亮灯操作,查了一些资料说用数组和switch实现,觉得太麻烦了,思索良久,就想到了反转二进制数解决这个问题。 reverse_bits( )是…...
如何让ai问答机器人通人性?
领域专用的问答机器人,数据是灵魂。通用模型的问题在于,它们虽然知识广博,但对特定领域的深度理解不足。解决这个问题的第一步,就是构建一个高质量的领域知识库。 数据要精准且全面 想让机器人真正“懂”一个领域,数…...
AI绘画笔记--基础知识
一.什么是AI绘画 AI绘画或者说AI生图,本质上来说还是图像生成技术,是一种基于深度学习的人工智能技术,通过提前大量学习学习图像特征,生成符合提示词的新图像。 整个流程可以简化理解为:人们首先让深度学习模型读取大量…...
图解AUTOSAR_CP_BSWMulticoreLibrary
AUTOSAR BSW 多核库详解 AUTOSAR基础软件多核操作库详细解析 目录 架构概述 1.1. 组件架构 1.2. API结构 1.3. 错误处理流程详细设计 2.1. 基础数据类型 2.2. 接口说明 2.3. 错误处理机制使用指南 3.1. 配置说明 3.2. 典型应用场景 3.3. 注意事项 1. 架构概述 1.1. 组件架构 …...
热key探测技术架构设计与实践
参考: 得物热点探测技术架构设计与实践 Redis数据倾斜与JD开源hotkey源码分析揭秘 京东热点检测 HotKey 学习笔记 hotkey: 京东App后台中间件,毫秒级探测热点数据,毫秒级推送至服务器集群内存,大幅降低热key对数据层查询压力 …...
【微服务】java中http调用组件深入实战详解
目录 一、前言 二、http调用概述 2.1 什么是http调用 2.1.1 http调用步骤 2.2 HTTP调用特点 2.3 HTTP调用应用场景 三、微服务场景下http调用概述 3.1 微服务开发中http调用场景 3.2 微服务组件中http的应用 四、常用的http调用组件 4.1 java中常用的http组件介绍 4…...
Python数据结构 ——字典
1.以下关于Python字典变量的定义中,正确的是()。 A. d={[1,2]:1, [3,4]:3} B. d={1:as, 2:sf} C. d = {(1,2):1, (3,4):3} D. d={‘python’:1, 2:[tea, cat]} 答案:C。在Python中,字典是存储可变数量键值对的数据结构,通过字典类型实现映射,键必须是唯一的,必须是不可变数据…...
32、构造函数
1、用构造函数反复创建多个相同结果的对象 问题 如果想反复创建多个相同结构,但是内容不同的对象时,用{}创建会代码重复,及其不便于维护! 解决 今后只要想反复创建同一类型的多个相同结构不同内容的对象时,都用构造函…...
编程环境搭建专栏目录汇总
1.WindowsvscodeclineMCP配置 2. Cline使用openrouter报错:Error Unexpected API Response: The language model did not provide any assista...
app.config.globalProperties
目录 一:基础使用 1、简介 2、使用 3、打印结果: 二:封装 1、创建一个.ts文件(utils/msg.ts) 2、在main.ts中全局注册 3、在页面中使用 4、打印结果 一:基础使用 1、简介 app.config.globalProperties 是 Vue 3 应用实例(app)的一个配置属性&…...
C# GeneticSharp包
可以直接从nuget安装GeneticSharp包 GeneticSharp 遗传算法类库 GeneticSharp 是什么 GeneticSharp 是一个C#的遗传算法类库, 遗传算法Java著名的JMetal, Python也有JMetalPy和PyMoo, C#相对差一截, 稍微有名的是GeneticSharp库. GeneticSharp 的弱点: 不支持多目标优化没…...
Leetcode做题记录----3
1474、删除链表M个节点之后的N个节点 思路: 1、两个循环解决问题 第一个循环移动M个位置,第二个循环确定移动N个位置后的,然后将M位置的节点的next指向,N位置后的节点即可 2、注意边界条件和判空处理 代码实现: pub…...
React(二):JSX语法解析+综合案例
事件绑定 this绑定方式 问题:在事件执行后,需获取当前类的对象中相关属性,此时需要this——当打印时,发现this为undefined,这又是为啥? 假设有一个btnClick函数,但它并不是我们主动调用的,而是…...
