达梦数据库主备集群

1:服务器硬件需求

按实际业务需求,选择合适的服务器,准备 3 台服务器,一台主库服务器,一台备库服务器,一台监视器服务器,服务器参数建议如下:

硬件要求
物理内存>=16 GB
交换区Swap 空间>=物理内存
/tmp大小> 1000 MB
网络物理机器需要 4 个网卡,2 个 public 网卡做 band,2 个 private 网卡做 band
磁盘根据实际应用系统需要挂载合适大小磁盘
时间服务器按机房要求配置连接时间服务器

操作系统版本安装

DM 数据库安装在 Linux 操作系统所需条件:glibc 2.3 以上,内核 2.6,预先安装 UnixODBC,系统性能监控等组件。这里使用Centos 7.6。

目录与存储规划

用途目录路径备注
数据库软件安装目录/home/dmdba/dmdbms可用空间>50 GB
实例安装目录/data/dmdata单独挂载性能最好的磁盘建议 SSD
归档日志存放目录/data/dmarch单独挂载磁盘
备份文件存放目录/data/dmbak单独挂载磁盘

用户与组

DM 数据库不应该使用 root 用户安装和维护。需要在安装之前为 DM 数据库创建一个专用的系统用户 (dmdba) 和用户组 (dinstall)。

执行以下命令,新建用户组 dinstall、新用户dmdba

groupadd dinstall
useradd  -g dinstall -m -d /home/dmdba -s /bin/bash  dmdba执行以下命令,修改 dmdba 用户密码:
passwd dmdba

用户资源限制

执行以下命令,修改 dmdba 用户资源限制:

vim /etc/security/limits.conf
文件末尾添加如下内容:dmdba soft core unlimited
dmdba hard core unlimited
dmdba soft nofile 65536
dmdba hard nofile 65536
dmdba soft nproc  65536
dmdba hard nproc  65536
dmdba soft stack  65536
dmdba hard stack  65536

用户环境变量

执行以下命令,修改 dmdba 用户环境变量:

vi /home/dmdba/.bash_profile
文件末尾添加如下内容:export DM_HOME=/home/dmdba/dmdbms
export PATH=$PATH:$DM_HOME/bin
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$DM_HOME/bin
端口规划

搭建 2 节点主备集群,端口规划如下:(实际中可以按需要修改端口号)

主机名public ipprivate ip实例名端口用途
dmdsc1192.168.1.3110.10.10.31dmrw15236数据库实例 dmrw1 监听端口
dmdsc1192.168.1.3110.10.10.31dmrw161141MAL 系统监听 TCP 连接的端口
dmdsc1192.168.1.3110.10.10.31dmrw152141实例本地的守护进程监听 TCP 连接的端口
dmdsc1192.168.1.3110.10.10.31dmrw133141实例监听守护进程 TCP 连接的端口
dmdsc2192.168.1.3210.10.10.32dmrw25236数据库实例 dmrw2 监听端口
dmdsc2192.168.1.3210.10.10.32dmrw261141MAL 系统监听 TCP 连接的端口
dmdsc2192.168.1.3210.10.10.32dmrw252141实例本地的守护进程监听 TCP 连接的端口
dmdsc2192.168.1.3210.10.10.32dmrw233141实例监听守护进程 TCP 连接的端口

防火墙集群之间需开放以上所有端口, 集群对客户端只需要开通数据库实例监听端口。

2:安装数据库

数据库软件安装详见单机规范化部署。

软件安装目录:/home/dmdba/dmdbms,实例初始化目录:/data/dmdata,初始化脚本如下:

主库和备库都需要配置实例,监视器可以不用配置
使用dmdba用户配置实例,进入达梦安装bin目录

[dmdba@dmdsc1 bin]$ pwd
/home/dmdba/dmdbms/bin主库进入/home/dmdba/dmdbms/bin目录下执行,初始化实例:
dminit path=/data/dmdata db_name=dmrw INSTANCE_NAME=dmrw1 EXTENT_SIZE=32 PAGE_SIZE=32 LOG_SIZE=2048备库进入/home/dmdba/dmdbms/bin目录下执行
dminit path=/data/dmdata db_name=dmrw INSTANCE_NAME=dmrw2 EXTENT_SIZE=32 PAGE_SIZE=32 LOG_SIZE=2048

主库前台启动实例,生成实例对应文件,启动后关闭即可。

 ./dmserver /data/dmdata/dmrw/dm.ini

3:主库进行脱机备份

脱机备份前要关闭数据库实例,否则备份会出错
备份的目的是为了确保主备数据库在自动同步前数据是一致的

[dmdba@dmdsc1 bin]$ ./dmrman 
dmrman V8RMAN> BACKUP DATABASE '/data/dmdata/dmrw/dm.ini' FULL BACKUPSET '/data/dmbak/full_database';
BACKUP DATABASE '/data/dmdata/dmrw/dm.ini' FULL BACKUPSET '/data/dmbak/full_database';
file dm.key not found, use default license!
Database mode = 0, oguid = 0
Normal of FAST
Normal of DEFAULT
Normal of RECYCLE
Normal of KEEP
Normal of ROLL
EP[0]'s cur_lsn[39830], file_lsn[39830]
Processing backupset /data/dmbak/full_database
[Percent:100.00%][Speed:0.00M/s][Cost:00:00:02][Remaining:00:00:00]                                 
backup successfully!
time used: 00:00:03.346

主库复制备份文件到备库

[dmdba@dmdsc1 dmbak]$ scp -r full_database 192.168.1.32:/data/dmbak/

备库进入/home/dmdba/dmdbms/bin进行恢复

[dmdba@dmdsc2 bin]$ ./dmrman 
dmrman V8
RMAN> RESTORE DATABASE '/data/dmdata/dmrw/dm.ini' FROM BACKUPSET '/data/dmbak/full_database';
RESTORE DATABASE '/data/dmdata/dmrw/dm.ini' FROM BACKUPSET '/data/dmbak/full_database';
file dm.key not found, use default license!
Normal of FAST
Normal of DEFAULT
Normal of RECYCLE
Normal of KEEP
Normal of ROLL
[Percent:100.00%][Speed:0.00M/s][Cost:00:00:02][Remaining:00:00:00]                                 
restore successfully.
time used: 00:00:02.475RMAN> RECOVER DATABASE '/data/dmdata/dmrw/dm.ini' FROM BACKUPSET '/data/dmbak/full_database';
RECOVER DATABASE '/data/dmdata/dmrw/dm.ini' FROM BACKUPSET '/data/dmbak/full_database';
Database mode = 2, oguid = 0
Normal of FAST
Normal of DEFAULT
Normal of RECYCLE
Normal of KEEP
Normal of ROLL
EP[0]'s cur_lsn[39830], file_lsn[39830]
recover successfully!
time used: 671.697(ms)RMAN> RECOVER DATABASE '/data/dmdata/dmrw/dm.ini' UPDATE DB_MAGIC;
RECOVER DATABASE '/data/dmdata/dmrw/dm.ini' UPDATE DB_MAGIC;
Database mode = 2, oguid = 0
Normal of FAST
Normal of DEFAULT
Normal of RECYCLE
Normal of KEEP
Normal of ROLL
EP[0]'s cur_lsn[39830], file_lsn[39830]
recover successfully!
time used: 00:00:01.066
RMAN> 

4:配置文件设置

实例配置文件:dm.ini
归档配置文件:dmarch.ini
MAL系统配置文件:dmmal.ini
守护进程配置文件:dmwatcher.ini
监视器配置文件:dmmonitor.ini
为了便于管理,将所有配置文件都与dm.ini配置文件放在同一个目录下。 

1)实例配置文件 dm.ini

主备库进入/data/dmdata/dmrw目录下修改dm.ini文件

vi /data/dmdata/dmrw/dm.ini主库:
INSTANCE_NAME = DMRW1  #修改实例名
MAL_INI = 1            #打开 MAL 系统
ARCH_INI = 1           #打开归档配置
ALTER_MODE_STATUS = 0  #不允许手工方式修改实例模式/状态/OGUID
ENABLE_OFFLINE_TS = 2  #不允许备库 OFFLINE 表空间备库:
INSTANCE_NAME = DMRW2  #修改实例名
MAL_INI = 1            #打开 MAL 系统
ARCH_INI = 1           #打开归档配置
ALTER_MODE_STATUS = 0  #不允许手工方式修改实例模式/状态/OGUID
ENABLE_OFFLINE_TS = 2  #不允许备库 OFFLINE 表空间

 2)归档配置文件dmarch.ini

vi /data/dmdata/dmrw/dmarch.ini主库:
[ARCHIVE_REALTIME]
ARCH_TYPE     = REALTIME  #归档类型
ARCH_DEST     = DMRW2      #归档目标实例名(主库侧填写备库实例名)
[ARCHIVE_LOCAL1]
ARCH_TYPE     = LOCAL     #本地归档类型
ARCH_DEST     = /data/dmarch #本地归档文件存放路径
ARCH_FILE_SIZE    = 128   #单位 MB,本地单个归档文件最大值
ARCH_SPACE_LIMIT  = 0     #单位 MB,0 表示无限制,范围 1024~4294967294 MB备库:
[ARCHIVE_REALTIME]
ARCH_TYPE     = REALTIME  #归档类型
ARCH_DEST     = DMRW1   	  #归档目标实例名(备库侧填写主库实例名)
[ARCHIVE_LOCAL1]
ARCH_TYPE     = LOCAL     #本地归档类型
ARCH_DEST     = /data/dmarch #本地归档文件存放路径
ARCH_FILE_SIZE    = 128   #单位 MB,本地单个归档文件最大值
ARCH_SPACE_LIMIT  = 0     #单位 MB,0 表示无限制,范围 1024~4294967294 MB

 3)MAL系统配置文件 dmmal.ini,主库与备库内容一致

vi /data/dmdata/dmrw/dmmal.iniMAL_CHECK_INTERVAL   = 5  # MAL链路检测时间间隔
MAL_CONN_FAIL_INTERVAL  = 5  # 判定 MAL链路断开的时间
[MAL_INST1]MAL_INST_NAME = DMRW1  #与 dm.ini中的 INSTANCE_NAME一致MAL_HOST      = 192.168.1.31  # MAL系统监听 TCP 内部网络 IPMAL_PORT      = 61141  # MAL系统监听 TCP连接的端口MAL_INST_HOST = 192.168.1.31  #实例的对外服务 IP地址MAL_INST_PORT = 5236  #与 dm.ini中的 PORT_NUM一致MAL_DW_PORT   = 52141  #实例对应的守护进程监听 TCP 端口MAL_INST_DW_PORT = 33141
[MAL_INST2]MAL_INST_NAME = DMRW2  #与 dm.ini中的 INSTANCE_NAME 一致MAL_HOST      = 192.168.1.32  # MAL系统监听 TCP内部网络 IPMAL_PORT      = 61141  # MAL系统监听 TCP连接的端口MAL_INST_HOST = 192.168.1.32  #实例的对外服务 IP地址MAL_INST_PORT = 5236  #与 dm.ini中的 PORT_NUM一致MAL_DW_PORT   = 52141  #实例对应的守护进程监听 TCP端口MAL_INST_DW_PORT = 33141

 4)守护进程配置文件 dmwatcher.ini

主库与备库内容一致

vi /data/dmdata/dmrw/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/dmdata/dmrw/dm.ini  # dm.ini 配置文件路径
INST_AUTO_RESTART  = 1   #打开实例的自动启动功能
INST_STARTUP_CMD   = /home/dmdba/dmdbms/bin/dmserver  #命令行方式启动

5)监视器配置文件 dmmonitor.ini

集群任意节点(一般在备库),配置监视器配置文件 dmmonitor.ini,本文配置在备库服务器上。 

vi /data/dmdata/dmrw/dmmonitor.iniMON_DW_CONFIRM    = 1   #确认监视器模式
MON_LOG_PATH    = /data/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_PORTMON_DW_IP     = 192.168.1.31:52141MON_DW_IP     = 192.168.1.32:52141

5:启动主备服务

1)启动数据库实例
主备库在/home/dmdba/dmdbms/bin目录下执行

./dmserver /data/dmdata/dmrw/dm.ini mount

[dmdba@dmdsc1 bin]$ ./dmserver /data/dmdata/dmrw/dm.ini mount
file dm.key not found, use default license!
version info: develop
DM Database Server 64 V8 03134284094-20231109-208042-20067 startup...
Normal of FAST
Normal of DEFAULT
Normal of RECYCLE
Normal of KEEP
Normal of ROLL
Database mode = 0, oguid = 0
License will expire on 2024-11-09
file lsn: 39830
ndct db load finished, code:0
ndct second level fill fast pool finished
ndct third level fill fast pool finished
ndct second level fill fast pool finished
ndct third level fill fast pool finished
ndct fill fast pool finished
nsvr_startup end.
uthr_pipe_create, create pipe[read:18, write:19]
uthr_pipe_create, create pipe[read:20, write:21]
uthr_pipe_create, create pipe[read:22, write:23]
uthr_pipe_create, create pipe[read:24, write:25]
uthr_pipe_create, create pipe[read:26, write:27]
uthr_pipe_create, create pipe[read:28, write:29]
uthr_pipe_create, create pipe[read:30, write:31]
uthr_pipe_create, create pipe[read:32, write:33]
uthr_pipe_create, create pipe[read:34, write:35]
uthr_pipe_create, create pipe[read:36, write:37]
uthr_pipe_create, create pipe[read:38, write:39]
uthr_pipe_create, create pipe[read:40, write:41]
uthr_pipe_create, create pipe[read:42, write:43]
uthr_pipe_create, create pipe[read:44, write:45]
uthr_pipe_create, create pipe[read:46, write:47]
uthr_pipe_create, create pipe[read:48, write:49]
aud sys init success.
aud rt sys init success.
systables desc init success.
ndct_db_load_info finished, code:0.
SYSTEM IS READY.

 另外开一个新的终端,使用 disql 工具连接数据库。

主库执行:
cd /home/dmdba/dmdbms/bin
./disql SYSDBA/SYSDBASQL> SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);
SQL> sp_set_oguid(453331);      #修改 oguid
SQL> alter database primary;    #修改为 primary 模式
SQL> SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);备库执行:
cd /home/dmdba/dmdbms/bin
./disql SYSDBA/SYSDBASQL> SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);
SQL> sp_set_oguid(453331);      #修改 oguid
SQL> alter database standby;    #修改为 standby 模式
SQL> SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);

2)启动守护进程

守护进程启动后,会将 Mount 的实例 Open。主备执行相同的操作。如有报错,请参考:

 达梦数据库主从备份搭建_达梦数据库主从配置-CSDN博客

cd /home/dmdba/dmdbms/bin
[dmdba@dmdsc1 bin]$ ./dmwatcher /data/dmdata/dmrw/dmwatcher.ini
DMWATCHER[4.0] V8
DMWATCHER[4.0] IS READY

3)启动监视器

在192.168.1.32备库机器上启动监视器
重新打开一个连接,执行:./dmmonitor /data/dmdata/dmrw/dmmonitor.ini

[dmdba@dmdsc2 bin]$ ./dmmonitor /data/dmdata/dmrw/dmmonitor.ini
[monitor]         2024-01-12 17:11:56: DMMONITOR[4.0] V8
[monitor]         2024-01-12 17:11:57: DMMONITOR[4.0] IS READY.[monitor]         2024-01-12 17:11:57: 
#--------------------------------------------------------------------------------#
GET MONITOR CONNECT INFO FROM DMWATCHER(DMRW2), THE FIRST LINE IS SELF INFO.DW_CONN_TIME         MON_CONFIRM    MID            MON_IP                   MON_VERSION                                                     
2024-01-12 17:11:57  TRUE           129505858      ::ffff:192.168.1.106     DMMONITOR[4.0] V8#--------------------------------------------------------------------------------#[monitor]         2024-01-12 17:11:57: 收到守护进程(DMRW2)消息WTIME                WSTATUS        INST_OK   INAME            ISTATUS     IMODE     RSTAT    N_OPEN   FLSN            CLSN            2024-01-12 17:11:57  OPEN           OK        DMRW2            OPEN        STANDBY   NULL     2        39998           39998           [monitor]         2024-01-12 17:11:57: 收到守护进程(DMRW1)消息WTIME                WSTATUS        INST_OK   INAME            ISTATUS     IMODE     RSTAT    N_OPEN   FLSN            CLSN            2024-01-12 17:11:57  OPEN           OK        DMRW1            OPEN        PRIMARY   VALID    2        39998           39998           show
2024-01-12 18:35:22 
#================================================================================#
GROUP            OGUID       MON_CONFIRM     MODE            MPP_FLAG  
GRP_RW           453331      TRUE            AUTO            FALSE     <<DATABASE GLOBAL INFO:>>
DW_IP         MAL_DW_PORT  WTIME                WTYPE     WCTLSTAT  WSTATUS        INAME            INST_OK   N_EP  N_OK  ISTATUS     IMODE     DSC_STATUS     RTYPE     RSTAT    
192.168.1.31  52141        2024-01-12 18:35:21  GLOBAL    VALID     OPEN           DMRW1            OK        1     1     OPEN        PRIMARY   DSC_OPEN       REALTIME  VALID    EP INFO:
INST_IP       INST_PORT  INST_OK   INAME            ISTATUS     IMODE     DSC_SEQNO  DSC_CTL_NODE RTYPE     RSTAT       FSEQ            FLSN            CSEQ            CLSN            DW_STAT_FLAG          
192.168.1.31  5236       OK        DMRW1            OPEN        PRIMARY   0          0            REALTIME  VALID       4843            40075           4843            40075           NONE                  <<DATABASE GLOBAL INFO:>>
DW_IP         MAL_DW_PORT  WTIME                WTYPE     WCTLSTAT  WSTATUS        INAME            INST_OK   N_EP  N_OK  ISTATUS     IMODE     DSC_STATUS     RTYPE     RSTAT    
192.168.1.32  52141        2024-01-12 18:35:21  GLOBAL    VALID     OPEN           DMRW2            OK        1     1     OPEN        STANDBY   DSC_OPEN       REALTIME  VALID    EP INFO:
INST_IP       INST_PORT  INST_OK   INAME            ISTATUS     IMODE     DSC_SEQNO  DSC_CTL_NODE RTYPE     RSTAT       FSEQ            FLSN            CSEQ            CLSN            DW_STAT_FLAG          
192.168.1.32  5236       OK        DMRW2            OPEN        STANDBY   0          0            REALTIME  VALID       4843            40075           4843            40075           NONE                  DATABASE(DMRW2) APPLY INFO FROM (DMRW1), REDOS_PARALLEL_NUM (1), WAIT_APPLY[FALSE]:
DSC_SEQNO[0], (RSEQ, SSEQ, KSEQ)[4843, 4843, 4843], (RLSN, SLSN, KLSN)[40075, 40075, 40075], N_TSK[0], TSK_MEM_USE[0] 
REDO_LSN_ARR: (40075)#================================================================================#

 监视器显示以上数据,说明主备搭建成功。需要注意的数据有WSTATUS(OPEN)、ISTATUS(OPEN)、RTYPE(REALTIME)、RSTAT(VALID)。

6:验证数据同步

主库:使用 disql 客户端登录,创建测试表,插入数据。

cd /home/dmdba/dmdbms/bin
./disql SYSDBA/SYSDBA[dmdba@dmdsc1 bin]$ ./disql SYSDBA/SYSDBA服务器[LOCALHOST:5236]:处于主库打开状态
登录使用时间 : 3.624(ms)
disql V8
SQL> create table test(id int, name varchar2(20));
操作已执行
已用时间: 9.349(毫秒). 执行号:601.
SQL> insert into test values (1, 'one');
影响行数 1已用时间: 0.938(毫秒). 执行号:602.
SQL> select * from test;行号     ID          NAME
---------- ----------- ----
1          1           one已用时间: 0.753(毫秒). 执行号:603.
SQL> commit;
操作已执行
已用时间: 1.702(毫秒). 执行号:604.
SQL> 

 备库:使用 disql 客户端登录,查询测试表验证。

[dmdba@dmdsc2 bin]$ ./disql SYSDBA/SYSDBA服务器[LOCALHOST:5236]:处于备库打开状态
登录使用时间 : 4.497(ms)
disql V8
SQL> select * from test;行号     ID          NAME
---------- ----------- ----
1          1           one已用时间: 1.656(毫秒). 执行号:101.
SQL> 

数据正常同步。

7:服务注册

上述服务启动都是前台启动,关闭窗口服务就会退出,可以将启动命令注册为系统服务,便于操作。

使用 root 用户,到数据库安装目录的 script/root 下,执行。

[root@dmdsc1 root]# pwd
/home/dmdba/dmdbms/script/root#注册守护进程服务(主备库都执行)
[root@dmdsc1 root]# ./dm_service_installer.sh -t dmwatcher -p dmrw -watcher_ini /data/dmdata/dmrw/dmwatcher.ini
Created symlink from /etc/systemd/system/multi-user.target.wants/DmWatcherServicedmrw.service to /usr/lib/systemd/system/DmWatcherServicedmrw.service.
创建服务(DmWatcherServicedmrw)完成#注册数据库实例服务(主备库都执行)。
[root@dmdsc1 root]# ./dm_service_installer.sh -t dmserver -p dmrw -dm_ini /data/dmdata/dmrw/dm.ini
Created symlink from /etc/systemd/system/multi-user.target.wants/DmServicedmrw.service to /usr/lib/systemd/system/DmServicedmrw.service.
创建服务(DmServicedmrw)完成#注册监视器服务(只需在监视器服务器上执行),执行以下命令:
[root@dmdsc2 root]# ./dm_service_installer.sh -t dmmonitor -p confirm -monitor_ini /data/dmdata/dmrw/dmmonitor.ini
Created symlink from /etc/systemd/system/multi-user.target.wants/DmMonitorServiceconfirm.service to /usr/lib/systemd/system/DmMonitorServiceconfirm.service.
创建服务(DmMonitorServiceconfirm)完成

服务方式启动

启动数据库实例,执行以下命令(主备执行):
systemctl start DmServicedmrw启动守护进程,执行以下命令(主备执行):
systemctl start DmWatcherServicedmrw启动监视器,执行以下命令(在监视器节点执行):
systemctl start DmMonitorServiceconfirm

 8:参数优化

集群部署完成后,需要优化 dm.ini 参数主备库都需要修改。参数值优化详见参数优化部分。

9:重启集群

主备集群重启有顺序要求:

关闭监视器:systemctl stop DmMonitorServiceconfirm
关闭主库守护进程:systemctl stop DmWatcherServicedmrw
关闭备库守护进程:systemctl stop DmWatcherServicedmrw
关闭主库实例:systemctl stop DmServicedmrw
关闭备库实例:systemctl stop DmServicedmrw
启动主库实例:systemctl start DmServicedmrw
启动备库实例:systemctl start DmServicedmrw
启动主库守护进程:systemctl start DmWatcherServicedmrw
启动备库守护进程:systemctl start DmWatcherServicedmrw
启动监视器:systemctl start DmMonitorServiceconfirm

注意启动和关闭顺序!!

启动:主备库实例 → 主备库守护进程 → 监视器

关闭:监视器 → 主备库守护进程 → 主备库实例

10:客户端连接集群

客户端主机上需要配置 dm_svc.conf 文件(未安装 DM 数据库的机器新建即可),文件路径:

32 位的 DM 安装在 Win32 操作平台下,此文件位于 %SystemRoot%\system32 目录;
64 位的 DM 安装在 Win64 操作平台下,此文件位于 %SystemRoot%\system32 目录;
32 位的 DM 安装在 Win64 操作平台下,此文件位于 %SystemRoot%\SysWOW64 目录;
在 Linux 平台下,此文件位于/etc 目录。

文件内容:

# 以#开头的行表示是注释
# 全局配置区
DMRW=(192.168.1.31:5236,192.168.1.32:5236)
TIME_ZONE=(+480) #表示+8:00 时区
LOGIN_ENCRYPT=(0)
DIRECT=(Y)
# 服务配置区
[DMRW]
TIME_ZONE=(+540) #表示+9:00 时区
LOGIN_MODE=(1)
SWITCH_TIME=(3)
SWITCH_INTERVAL=(10)

 客户端程序连接数据库时,需要指定 IP 端口处替换为服务名即可,例如:

disql SYSDBA/SYSDBA@DMRW

注意:当修改了 dm_svc.conf 内容后,需要重启客户端程序,修改的配置才能生效。

11:故障切换

通过上述配置,达梦数据库在主库故障后,会自动切换到备库。故障恢复后会自动加入到集群中,不过不再是主库,而是备库。

参考文档:

主备集群规范化部署 | 达梦技术文档

达梦数据库主从备份搭建_达梦数据库主从配置-CSDN博客

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL同步ES的几种方案

MySQL数据同步ES的几种方案 1. 同步双写 与业务耦合深&#xff0c;且业务响应时间长 2. 异步双写 这时可以使用类似MQ这样的中间件&#xff0c;业务主写时向MQ发送一条信息&#xff0c;再由一个聚合服务区消费&#xff0c;最终同步到ES 3. 定时任务 不好配置时间&#xff0c;…

Spring Boot - Application Events 的发布顺序_ContextRefreshedListener

文章目录 Pre概述Code源码分析 Pre Spring Boot - Application Events 的发布顺序_ApplicationEnvironmentPreparedEvent 概述 Spring Boot 的广播机制是基于观察者模式实现的&#xff0c;它允许在 Spring 应用程序中发布和监听事件。这种机制的主要目的是为了实现解耦&#…

2024年最新软件测试面试题

Part1 1、你的测试职业发展是什么&#xff1f;【文末有面试文档免费领取】 测试经验越多&#xff0c;测试能力越高。所以我的职业发展是需要时间积累的&#xff0c;一步步向着高级测试工程师奔去。而且我也有初步的职业规划&#xff0c;前3年积累测试经验&#xff0c;按如何做…

Python——猜猜心里的数字(2)

1、数字随机产生&#xff0c;范围1-10 2、有三次机会猜数字通过三层嵌套 3、每次猜不中&#xff0c;提示大小 import random numrandom.randint(1,10) guess_num int(input("请输入您猜测的值&#xff1a;")) if guess_numnum:print("恭喜你&#xff0c;第一次…

【漏洞复现】Office365-Indexs-任意文件读取

漏洞描述 Office 365 Indexs接口存在一个任意文件读取漏洞,攻击者可以通过构造精心设计的请求,成功利用漏洞读取服务器上的任意文件,包括敏感系统文件和应用程序配置文件等。通过利用此漏洞,攻击者可能获得系统内的敏感信息,导致潜在的信息泄露风险 免责声明 技术文章…

LLM之长度外推(二)| Self-Extend:无需微调的自扩展大模型上下文窗口

论文链接&#xff1a;https://simg.baai.ac.cn/paperfile/a34ae7f4-f0ce-4f8f-b8f2-e8e4d84bbee5.pdf 目前大模型基本都采用transformer结构&#xff0c;而transformer中attention机制的计算复杂度与序列长度呈平方关系&#xff0c;因此大模型在训练时候通常会设置固定的上下文…

案例117:基于微信小程序的新闻资讯系统设计与实现

文末获取源码 开发语言&#xff1a;Java 框架&#xff1a;springboot JDK版本&#xff1a;JDK1.8 数据库&#xff1a;mysql 5.7 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.5.4 小程序框架&#xff1a;uniapp 小程序开发软件&#xff1a;HBuilder …

NES 模拟器中音画同步问题

背景 模拟器是与游戏和播放器都有相似之处的系统。模拟器与游戏的相似之处&#xff0c;在于都需要一个采集输入–执行逻辑–然后按一定帧率&#xff08;通常是 60 FPS&#xff09;把画面显示出来的循环。但是模拟器又需要模拟音频设备&#xff0c;播放音频设备产生的声音样本&…

Ubuntu搭建OpenCV环境(C++)

Ubuntu搭建OpenCV环境(C) 文章目录 Ubuntu搭建OpenCV环境(C)一、环境介绍二、依赖安装三、安装包下载四、opencv安装五、测试 一、环境介绍 虚拟机 &#xff1a;VMware 15.5 OS &#xff1a; Ubuntu 20.04 opencv 版本 &#xff1a; 4.9.0 操作系统安装本文不再赘述&#x…

学习Vue封装的过渡与动画总结

今天学习了Vue封装的过渡与动画&#xff0c;接下来说一下Vue是如何实现的&#xff0c;首先原生的方法是在style元素中给指定元素添加过渡的过渡或动画&#xff0c;但Vue就不需要直接获取到需要过渡或动画的元素&#xff0c;而是使用一个<transition>的标签来包裹住想要过…

py的函数讲解

前言:本章节我们来讲函数&#xff0c;主播略微感觉到有点小难&#xff0c;友友们需要认真看 目录 一.初始函数 1.1关于函数 1.2举例 1.3小结 二.函数的基础语法 2.1关于函数的语法 2.2举例 2.3小结 三.函数的参数 3.1关于函数的参数 3.2举例 3.3小结 四.函数的返回…

Arduino实现简易颜色识别机械臂

机械臂 一 功能原理1 硬件设备2 arduino库3 工作原理 二 代码设计全局参数1 颜色识别2 机械臂转动3 机械臂复位 三 展示效果 一 功能原理 识别出不同颜色的物体&#xff0c;让机械臂进行夹取并放入不同位置。 1 硬件设备 2 arduino库 3 工作原理 二 代码设计 项目重点划分…

如何在 SwiftUI 中实现音频图表

文章目录 前言DataPoint 结构体BarChartView 结构体ContentView 结构体实现协议实现线图总结 前言 在可访问性方面&#xff0c;图表是复杂的事物之一。iOS 15 引入了一项名为“音频图表”的新功能。 下面我们将学习如何通过使用 accessibilityChartDescriptor 视图修饰符为任…

用友NC Cloud IUpdateService接口存在XXE漏洞

免责声明:请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失,均由使用者本人负责,所产生的一切不良后果与文章作者无关。该文章仅供学习用途使用。 1. 用友NC 简介 微信公众号搜索:南风漏洞复现文库 该…

Shutter Encoder多媒体转换v17.8

软件介绍 多媒体包含种类繁多的各种文件格式&#xff0c;每种格式都有其不同的特征和所谓的“怪癖”。 因此&#xff0c;如果使用多种图像、视频或音频格式&#xff0c;找到一个集中的软件来从一个地方处理所有这些格式可能会非常棘手。 这就是 Shutter Encoder 基本上允许做的…

Go语言使用gosseract 库来进行图像文字识别,识别出来的中文是乱码的?如何解决?

如果您在使用 gosseract 库进行图像文字识别时&#xff0c;得到的中文文字是乱码&#xff0c;可能是因为默认情况下 gosseract 以及 Tesseract 引擎并不支持中文字符的识别。要解决这个问题&#xff0c;您需要进行一些配置和设置。 以下是解决方案的步骤&#xff1a; 1 安装 …

【算法】信使(最短路问题)

题目 战争时期&#xff0c;前线有 n 个哨所&#xff0c;每个哨所可能会与其他若干个哨所之间有通信联系。 信使负责在哨所之间传递信息&#xff0c;当然&#xff0c;这是要花费一定时间的&#xff08;以天为单位&#xff09;。 指挥部设在第一个哨所。 当指挥部下达一个命令…

硬盘重新分区怎么恢复分区之前的文件?

分区是常见的故障&#xff0c;通常由多种原因引起。一方面&#xff0c;硬盘老化或者受到损坏可能会导致分区表出现问题&#xff1b;另一方面&#xff0c;用户误操作&#xff0c;如格式化或分区不当&#xff0c;也可能导致分区丢失。针对此问题&#xff0c;解决方法包括使用专业…

代码仓库gitlab的数据迁移步骤

GitLab数据迁移的具体方法和详细操作如下&#xff1a; 备份源GitLab服务器的数据&#xff1a;你可以使用GitLab自带的备份工具进行备份&#xff0c;执行以下命令进行备份&#xff1a; sudo gitlab-rake gitlab:backup:create安装新的GitLab服务器&#xff1a;在目标服务器上安装…

# C++系列-第3章循环结构-28-累加

在线练习&#xff1a; http://noi.openjudge.cn/ https://www.luogu.com.cn/ 累加 奥运奖牌计数 题目描述 2008 2008 2008 年北京奥运会&#xff0c;A 国的运动员参与了 n n n 天的决赛项目 ( 1 ≤ n ≤ 100 ) (1 \le n \le 100) (1≤n≤100)。现在要统计一下 A 国所获得的…