部署达梦数据库主从配置详细操作DM8

服务器配置

主库 192.168.81.128 实例名 dm-1    从库 192.168.81.129  实例名 dm-2

以下安装部署主从服务器都操作

关闭防火墙

systemctl stop firewalld  &&  systemctl disable firewalld

注意安装前必须创建 dmdba 用户,禁止使用 root 用户安装数据库。

创建用户所在的组,命令如下:

groupadd dinstall -g 2001

创建用户,命令如下:

useradd  -G dinstall -m -d /home/dmdba -s /bin/bash -u 2001 dmdba

修改用户密码,命令如下:

passwd dmdba

修改文件打开最大数

在 Linux、Solaris、AIX 和 HP-UNIX 等系统中,操作系统默认会对程序使用资源进行限制。如果不取消对应的限制,则数据库的性能将会受到影响。

使用 root 用户打开 /etc/security/limits.conf 文件进行修改,命令如下:

vim /etc/security/limits.conf

在最后添加下面的语句,需添加的语句如下:

dmdba  soft      nice       0

dmdba  hard      nice       0

dmdba  soft      as         unlimited

dmdba  hard      as         unlimited

dmdba  soft      fsize      unlimited

dmdba  hard      fsize      unlimited

dmdba  soft      nproc      65536

dmdba  hard      nproc      65536

dmdba  soft      nofile     65536

dmdba  hard      nofile     65536

dmdba  soft      core       unlimited

dmdba  hard      core       unlimited

dmdba  soft      data       unlimited

dmdba  hard      data       unlimited

重启服务器后永久生效。

切换到 dmdba 用户,查看是否生效,命令如下:

su dmdba

ulimit -a

参数配置已生效。

目录规划

  1. 可根据实际需求规划安装目录,本示例使用默认配置 DM 数据库安装在 /home/dmdba 文件夹下。

2.规划创建实例保存目录、归档保存目录、备份保存目录。

实例存储目录

mkdir -p /home/dmdba/dmdata   

归档存储目录

mkdir -p /home/dmdba/arch

备份存储目录

mkdir -p /home/dmdba/dmbak

新建的路径目录权限的用户修改为 dmdba,用户组修改为 dinstall。

chown -R dmdba:dinstall /home/dmdba/

给路径下的文件设置 755 权限。

chmod -R 755 /home/dmdba

数据库安装命令行安装

下载达梦安装包(镜像)

产品下载 | 达梦数据库

下载后上传到服务器上解压zip包

unzip dm8_20240408_x86_rh7_64.zip

挂载镜像

切换到 root 用户,将 DM 数据库的 iso 安装包保存在/mnt载镜像:

mount -o loop dm8_20240408_x86_rh7_64.iso /mnt/

切换到dmdba 用户下,在 /mnt 目录下使用命令行安装数据库,执行以下命令安装 DM 数据库。

su - dmdba

cd /mnt

mkdir -p /home/dmdba/dmdbms  创建默认安装目录

chown -R dmdba:dinstall /home/dmdba/   给到达梦用户和组权限

执行安装命令

./DMInstall.bin -i

按需求选择安装语言,没有 key 文件选择 "n",时区按需求选择一般选择 “21”,安装类型选择“1”,安装目录按实际情况配置。

注意数据库安装完成后,需要切换至 root 用户执行上图中的命令 /home/dmdba/dmdbms/script/root/root_installer.sh 创建 DmAPService,否则会影响数据库备份。

exit 退出 dmdba用户root用户执行

/home/dmdba/dmdbms/script/root/root_installer.sh

初始化数据库实例

主库进入/home/dmdba/dmdbms/bin目录下执行:

cd /home/dmdba/dmdbms/bin



./dminit PATH=/home/dmdba/dmdata db_name=dm instance_name=dm1

从库进入/home/dmdba/dmdbms/bin目录下执行:

cd /home/dmdba/dmdbms/bin



./dminit PATH=/home/dmdba/dmdata db_name=dm instance_name=dm2

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

cd /home/dmdba/dmdbms/bin

./dmserver /home/dmdba/dmdata/dm/dm.ini

启动完成后 ctrl +c 或者 exit 都可以退出

主库进行脱机备份

脱机备份前要关闭数据库实例,否则备份会出错,为了保证数据同步前的一致性。

在主库 /home/dmdba/dmdbms/bin目录下执行

cd /home/dmdba/dmdbms/bin



 ./dmrman



BACKUP DATABASE '/home/dmdba/dmdata/dm/dm.ini' FULL BACKUPSET '/home/dmdba/dmbak/full_database';

然后把主库备份文件发送到从库

scp -r /home/dmdba/dmbak/full_database 192.168.81.129:/home/dmdba/dmbak/full_database

然后来到从库进行恢复操作

cd /home/dmdba/dmdbms/bin



 ./dmrman



RESTORE DATABASE '/home/dmdba/dmdata/dm/dm.ini' FROM BACKUPSET '/home/dmdba/dmbak/full_database';

RECOVER DATABASE '/home/dmdba/dmdata/dm/dm.ini' FROM BACKUPSET '/home/dmdba/dmbak/full_database';

RECOVER DATABASE '/home/dmdba/dmdata/dm/dm.ini' UPDATE DB_MAGIC;

数据库配置文件编辑

实例配置文件:dm.ini

归档配置文件:dmarch.ini

MAL系统配置文件:dmmal.ini

守护进程配置文件:dmwatcher.ini

监视器配置文件:dmmonitor.ini

复制配置文件时记得删除参数含义的解释

实例配置文件 dm.ini

vim /home/dmdba/dmdata/dm/dm.ini









主库修改





INSTANCE_NAME = dm1  #修改实例名



MAL_INI = 1            #打开 MAL 系统



ARCH_INI = 1           #打开归档配置



ALTER_MODE_STATUS = 0  #不允许手工方式修改实例模式/状态/OGUID



ENABLE_OFFLINE_TS = 2  #不允许备库 OFFLINE 表空间





从库修改





INSTANCE_NAME = dm2  #修改实例名



MAL_INI = 1            #打开 MAL 系统



ARCH_INI = 1           #打开归档配置



ALTER_MODE_STATUS = 0  #不允许手工方式修改实例模式/状态/OGUID



ENABLE_OFFLINE_TS = 2  #不允许备库 OFFLINE 表空间





归档配置文件dmarch.ini



vim /home/dmdba/dmdata/dm/dmarch.ini



主库配置



[ARCHIVE_REALTIME]

ARCH_TYPE     = REALTIME  #归档类型

ARCH_DEST     = dm2      #归档目标实例名(主库侧填写备库实例名)

[ARCHIVE_LOCAL1]

ARCH_TYPE     = LOCAL     #本地归档类型

ARCH_DEST     = /home/dmdba/arch/ #本地归档文件存放路径

ARCH_FILE_SIZE    = 128   #单位 MB,本地单个归档文件最大值

ARCH_SPACE_LIMIT  = 0     #单位 MB,0 表示无限制,范围 1024~4294967294 MB





从库配置



[ARCHIVE_REALTIME]

ARCH_TYPE     = REALTIME

ARCH_DEST     = dm1

[ARCHIVE_LOCAL1]

ARCH_TYPE     = LOCAL

ARCH_DEST     = /home/dmdba/arch/

ARCH_FILE_SIZE    = 128

ARCH_SPACE_LIMIT  = 0





MAL系统配置文件 dmmal.ini



vim /home/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     = 192.168.81.128  # MAL系统监听 TCP 内部网络 IP

  MAL_PORT     = 61141  # MAL系统监听 TCP连接的端口

  MAL_INST_HOST   = 192.168.81.128  #实例的对外服务 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      = 192.168.81.129  # MAL系统监听 TCP内部网络 IP

  MAL_PORT          = 61141  # MAL系统监听 TCP连接的端口

  MAL_INST_HOST         = 192.168.81.129  #实例的对外服务 IP地址

  MAL_INST_PORT         = 5236  #与 dm.ini中的 PORT_NUM一致

  MAL_DW_PORT  = 52141  #实例对应的守护进程监听 TCP端口

  MAL_INST_DW_PORT = 33141









守护进程配置文件 dmwatcher.ini



主从库配置一样



vim /home/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           = /home/dmdba/dmdata/dm/dm.ini  # dm.ini 配置文件路径

INST_AUTO_RESTART  = 1   #打开实例的自动启动功能

INST_STARTUP_CMD   = /home/dmdba/dmdbms/bin/dmserver  #命令行方式启动







监视器配置文件 dmmonitor.ini



主从库都可以,我这里选择放在主库



vim /home/dmdba/dmdata/dm/dmmonitor.ini



MON_DW_CONFIRM    = 1   #确认监视器模式

MON_LOG_PATH    = /home/dmdba/dmdata/dmmonitor_auto/log #监视器日志文件存放路径可以自定义,没有自行创建

MON_LOG_INTERVAL  = 60 #每隔 60 s 定时记录系统信息到日志文件

MON_LOG_FILE_SIZE   = 32 #每个日志文件最大 32 MB

MON_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_PORT

 MON_DW_IP     = 192.168.81.128:52141

 MON_DW_IP     = 192.168.81.129:52141

启动主从数据库

主库启动

cd  /home/dmdba/dmdbms/bin

./dmserver /home/dmdba/dmdata/dm/dm.ini mount

启动成功后新开一个窗口使用disql工具连接数据库注意使用dmdba用户

cd  /home/dmdba/dmdbms/bin

./disql SYSDBA/SYSDBA              #SYSDBA/SYSDBA 是默认用户和密码

主库执行操作

SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);



sp_set_oguid(453331); #修改 oguid



alter database primary; #修改为 primary 模式



SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);

从库启动

cd  /home/dmdba/dmdbms/bin

./dmserver /home/dmdba/dmdata/dm/dm.ini mount



启动成功后新开一个窗口使用disql工具连接数据库注意使用dmdba用户



cd  /home/dmdba/dmdbms/bin



./disql SYSDBA/SYSDBA 

从库执行操作

SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);



sp_set_oguid(453331); #修改 oguid



alter database standby; #修改为 standby 模式



SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);

执行完以上操作记得exit退出主从库启动状态

启动守护进程

主从库执行相同操作


cd  /home/dmdba/dmdbms/bin



./dmwatcher /home/dmdba/dmdata/dm/dmwatcher.ini

启动监视器

在主库机器执行新开一个窗口注意使用dmdba用户

cd  /home/dmdba/dmdbms/bin



./dmmonitor /home/dmdba/dmdata/dm/dmmonitor.ini

监视器显示WSTATUS(OPEN)、ISTATUS(OPEN)、RTYPE(REALTIME)、RSTAT(VALID)有数据表名主从搭建完成。

验证数据同步状态

主库登录创建表插入数据使用disql工具连接数据库注意使用dmdba用户

cd  /home/dmdba/dmdbms/bin



./disql SYSDBA/SYSDBA 





create table date(id int, name varchar2(20));   #创建表



insert into date values (1, 'one');      #插入数据



select * from date; #查看表数据



commit;





从库登录数据库查看同步数据使用disql工具连接数据库注意使用dmdba用户



cd  /home/dmdba/dmdbms/bin



./disql SYSDBA/SYSDBA 



select * from date;

数据同步状态正常。

注册服务

上面操作都是前台启动的方式,关闭窗口就会退出,下面我们将启动命令注册为系统服务。

主从库都操作使用root用户到数据库安装目录

cd /home/dmdba/dmdbms/script/root/

注册守护进程服务

./dm_service_installer.sh -t dmwatcher -p dmrw -dm_ini /home/dmdba/dmdata/dm/dm.ini -watcher_ini /home/dmdba/dmdata/dm/dmwatcher.ini

注册数据库实例服务

./dm_service_installer.sh -t dmserver -p dmrw -dm_ini /home/dmdba/dmdata/dm/dm.ini

注册监视器服务(只在主库执行)

./dm_service_installer.sh -t dmmonitor -p confirm -dm_ini /home/dmdba/dmdata/dm/dm.ini  -monitor_ini /home/dmdba/dmdata/dm/dmmonitor.ini

使用启动命令启动服务

启动数据库(主从都启动)

systemctl start DmServicedmrw

启动时报错了,进过排查发现是刚刚启动的实例忘记关闭导致端口被占用启动失败

Kill 掉未关闭的dm进程重新启动即可(如果还起不来有可能是在部署过程中使用了root用户启动某个步骤,导致dmdba用户没有权限读取配置或者文件,执行一下用户提权操作在手动启动看下是否正常。)

启动守护进程(主从都启动)

systemctl start DmWatcherServicedmrw

启动监视器(主库启动)

systemctl start DmMonitorServiceconfirm

注意启动和关闭顺序

启动 主库启动 → 从库启动 → 主库守护进程  → 从库守护进程  → 监视器

停止 监视器 → 主库守护进程 → 从库守护进程 → 从库停止 → 主库停止

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/624185.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

下载element-ui报错

此错误表示尝试从npm注册表下载“resize observer polyfill”包时超时。这可能是由于网络连接问题或npm注册表服务器的问题。 要解决此问题,您可以尝试以下步骤: 1.重试npm install命令:有时,网络问题会导致临时超时。再次运行npm…

BGP基本配置练习

要求:通过使用BGP来实现所有设备的环回都能ping通 实验的思路 完成所有路由器的IGP配置 使用直连接口建立EBGP对等体关系 使用环回接口建立IBGP对等体关系 使用connect-interface命令修改IBGP的源IP地址 使用next-hop-local命令修改路由传递的下一…

Funakoshi — LipiDye Ⅱ脂滴活细胞成像试剂

Funakoshi LipiDye II是一款适用于长时间活细胞成像以观察动态脂滴(LDS)合成、移动或降解的绿色荧光染料;是LipiDye(货号:FDV-0010)的升级版,同时具备超强的光稳定性和高灵敏度等特点。 ➧ 产品…

Cartoon Colections Flower Path 2

高质量的花为Unity游戏引擎优化! 移动优化场景 这款10款3D花卉系列,超过+55种颜色!点击 配有高品质的室内植物和花卉模型。 所有对像都可以在可视化中使用。 - 1024x1024,纹理贴图 - Poly计数:平均8500~125500 tris 下载:​​Unity资源商店链接资源下载链接 效果图:

长难句打卡5.14

This is now a question for Gloria Mackenzie, an 84-year-old widow who recently emerged from her small, tin-roofed house in Florida to collect the biggest undivided lottery jackpot in history. 翻译:这是84岁的孤寡老人歌莉娅 麦肯齐当前所面临的问题…

【正版系统】海外短剧系统功能介绍,前端uniapp+开源。

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一、海外短剧系统功能介绍 二、搭建要求 1.系统要求 总结 前言 短剧作为一种快速、紧凑的娱乐形式,正逐渐受到更多海外观众的喜爱。这种需求增长为…

移动端自动化测试工具 Appium 之持续集成

文章目录 一、背景二、前置条件三、代码部分1、pom.xml文件配置2、main入口代码 四、Jenkins 部分1、下载Jenkins2、安装插件3、job配置4、选择构建 五、工程目录六、报告示例七、总结 一、背景 持续集成是老生话谈的事情,用的好不好,看自己公司与使用场…

【链路层和局域网】

文章目录 链路层和局域网网络节点的连接方式数据链路层和局域网链路层导论链路层:上下文链路层服务链路层在哪里实现?适配器通信错误检测奇偶校验校验和:CRC(循环冗余校验)多点访问链路和协议多路访问协议MAC&#xff…

OpenNJet:引领下一代云原生应用引擎

文章目录 一、前言二、什么是OpenNJet 应用引擎三、OpenNJet的优势3.1 性能无损动态配置3.2 灵活的CoPilot框架3.3 支持HTTP/33.4 支持国密3.5 企业级应用3.6 高效安全 四、centos 安装4.1 生成njet.repo4.2 更新yum 缓存4.3 安装 njet 或 njet-otel 五、OpenNJet配置与部署5.1…

【Nginx <一>⭐️】Nginx 的初步了解以及安装使用

目录 👋前言 👀一、 Nginx 介绍 🌱二、 安装使用 💞️ 三、 总结 📫四、 章末 👋前言 小伙伴们大家好,前段时间主要在学习 Elasticsearch 相关的知识,花了两周的时间吧&#x…

【Linux系统编程】第十八弹---进程状态(上)

✨个人主页: 熬夜学编程的小林 💗系列专栏: 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】 目录 1、操作系统进程 1.1、进程背景 1.2、进程如何在CPU上运行的? 1.2、进程状态 2、Linux的进程状态 2.1、如何描…

【VUE】VUE3绘制箭头组件

效果预览&#xff1a; 长、宽、粗细等等根据情况合理调整即可。 组件&#xff1a; <template><div class"line" :style"props.arrowsColor"></div> </template><script setup> import { defineProps, ref, onMounted } fr…

答辩PPT制作成本高?推荐3个aippt工具

这些网站我愿称之为制作答辩PPT的神&#xff01; 很多快要毕业的同学在做答辩PPT的时候总是感觉毫无思路&#xff0c;一窍不通。但这并不是你们的错&#xff0c;对于平时没接触过相关方面&#xff0c;第一次搞答辩PPT的人来说&#xff0c;这是很正常的一件事。一个好的答辩PPT…

【案例】使用Vue实现拖拽课表

效果展示 效果说明 点击左侧的课程并进行拖拽&#xff0c;拖拽到要开设本课程的地方然后松手&#xff0c;即可将本节课设置为当前所拖拽的科目并且背景色为当前科目的背景色&#xff0c;当多次拖拽到同一节课的时候将会实现后者覆盖前者的效果。 效果实现代码 第一步&#x…

【全开源】多功能投票小程序支持微信公众号+微信小程序+H5(源码搭建/上线/运营/售后/维护更新)

介绍 多功能投票小程序是一款基于FastAdminThinkPHPuniapp开发的一款多功能投票小程序。 ​用户友好与便捷性&#xff1a; 投票小程序界面简洁直观&#xff0c;操作简便&#xff0c;用户无需下载和安装额外的应用&#xff0c;即可在微信或其他平台上直接使用&#xff0c;大大提…

AI应用案例:会议纪要自动生成

以腾讯会议转录生成的会议记录为研究对象&#xff0c;借助大模型强大的语义理解和文本生成等能力&#xff0c;利用指令和文本向量搜索实现摘要总结、要点提取、行动项目提取、会议纪要生成等过程&#xff0c;完成会议纪要的自动总结和生成&#xff0c;降低人工记录和整理时间成…

基于uniapp+vue3+ts小程序项目实战之项目初始化

&#x1f680; 作者 &#xff1a;“二当家-小D” &#x1f680; 博主简介&#xff1a;⭐前荔枝FM架构师、阿里资深工程师||曾任职于阿里巴巴担任多个项目负责人&#xff0c;8年开发架构经验&#xff0c;精通java,擅长分布式高并发架构,自动化压力测试&#xff0c;微服务容器化k…

InstantStyle —— 文本到图像生成中的风格保持新突破

在人工智能领域&#xff0c;文本到图像生成&#xff08;Text-to-Image Generation&#xff09;技术正迅速发展&#xff0c;其应用范围从娱乐到专业设计不断扩展。然而&#xff0c;风格一致性生成一直是该领域的一个技术难题。最近&#xff0c;InstantX团队提出了一种名为Instan…

flutter开发实战-本地SQLite数据存储

flutter开发实战-本地SQLite数据库存储 正在编写一个需要持久化且查询大量本地设备数据的 app&#xff0c;可考虑采用数据库。相比于其他本地持久化方案来说&#xff0c;数据库能够提供更为迅速的插入、更新、查询功能。这里需要用到sqflite package 来使用 SQLite 数据库 预…

网络工程师----第二十五天

计算机基础 第二章&#xff1a;物理层 物理层的功能&#xff1a;怎样在连接各种计算机的传输媒体上传输数据比特流&#xff0c;屏蔽不同传输媒体和通信手段的差异。 传输媒体接口的特性&#xff1a; 机械特性&#xff1a;接口所用接线器的形状和尺寸、引脚数目和排列、固定…