一、环境介绍

实例名 路径 端口号 ip 系统类型 机器类型 数据库类型
primary master

/dmsoft/dmdbms

/dmdata

5236 192.168.202.142 centos7.9   虚拟机 DM8
standby slave

/dmsoft/dmdbms

/dmdata

5236 192.168.202.143 centos7.9   虚拟机

DM8

monitor mon

/dmsoft/dmdbms

5236 192.168.202.144 centos7.9 虚拟机 DM8

磁盘划分:

二、部署环境要求

1、服务器硬件

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

警告:守护进程配置自动切换时,必须在监视器服务器上配置确认监视器,并且保证网络高可用。

2、操作系统要求

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

3、目录与存储规划

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

4、用户与组

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

[root@localhost data]#  groupadd dinstall

[root@localhost data]#  useradd -g dinstall -m -d /home/dmdba -s /bin/bash dmdba

[root@localhost data]#  echo "dmdba"|passwd  dmdba --stdi

5、用户资源限制

        执行以下命令,修改 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

6、用户环境变量

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

vi /home/dmdba/.bash_profile

PATH=$PATH:$HOME/.local/bin:$HOME/bin:/dmsoft/dmdbms/bin

export PATH

export DM_HOME=/dmsoft/dmdbms

export PATH=$PATH:$DM_HOME/bin

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$DM_HOME/bin

7、防火墙集群之间需开放以上所有端口

三、安装数据库

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

[dmdba@localhost data]#  dminit path=/dmdata   db_name=master  page_size=32

注意:初始化的实例必须先启动一次,才能脱机备份。

启动实例

以系统服务方式启动实例,DM 提供脚本将数据库实例注册为操作系统服务。

root 用户下切换到 /dmsoft/dmdbms/script/root/

[dmdba@localhost data]#   dm_service_installer.sh -t dmserver -p dmserver -dm_ini /dmdata/master/dm.ini

参数优化

 [dmdba@localhost data]#   disql SYSDBA/SYSDBA@localhost:5236

注意:修改完参数后,需要重启数据库生效。

归档配置

alter database mount;
alter database add archivelog 'dest=/dmarch/,TYPE=local,FILE_SIZE=1024,SPACE_LIMIT=10240';
alter database archivelog;
alter database open;

四、主库脱机备份

确认主库 DMAP 服务已启动,执行以下命令:

 若未启动,则先启动 DMAP 服务,dmdba 到安装目录的 bin 下执行以下命令:

[dmdba@localhost data]#  ./DmAPService start

 关闭数据库后,使用 dmrman 工具脱机备份主库,dmdba 用户到安装目录的 bin 下执行以下命令:

关闭实例

[root@localhost data]#   systemctl stop DmServicedmserver

[dmdba@localhost data]#  dmrman

[dmdba@localhost data]#   backup database '/dmdata/master/dm.ini'  backupset '/dmback/full';

五、备库还原

拷贝主库备份到备库合适目录,执行以下命令:

[dmdba@localhost data]#   scp -r /dmbacp/full 192.168.202.142:/dmdata/back

关闭数据库后,使用 dmrman 工具还原备库执行 restore。

[dmdba@localhost data]#  dmrman

[dmdba@localhost data]#  restore database '/dmdata/master/dm.ini' from backupset '/dmback/full';

 [dmdba@localhost data]# recover database '/dmdata/master/dm.ini' from backupset '/dmback/full';

更新db_magic  

[dmdba@localhost data]# recover database '/dmdata/master/dm.ini'  update db_magic;

六、配置实例的配置文件 dm.ini

修改master/slave实例的达梦dm.ini文件参数,执行以下命令:

主库修改以下参数值:

 [dmdba@localhost data]#  vi /dmdata/master/dm.ini

INSTANCE_NAME = dmrw1
MAL_INI = 1
ARCH_INI = 1
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2

备库修改以下参数值:

 [dmdba@localhost data]#  vi /dmdata/slave/dm.ini

INSTANCE_NAME = dmrw2
MAL_INI = 1
ARCH_INI = 1
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2

主备实例重启生效。

七、配置归档配置文件 dmarch.ini

在实例目录下新建文件 dmarch.ini,执行以下命令:

 [dmdba@localhost data]# vi /dmdata/master/dmarch.ini

master主库添加以下内容:

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

slave备库添加以下内容:

 [dmdba@localhost data]# vi /dmdata/slave/dmarch.ini

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

八、配置MAL系统配置文件 dmmal.ini

在实例目录下新建文件 dmmal.ini,执行以下命令:

主备库文件内容要相同。

 [dmdba@localhost data]# vi  /dmdata/master/dmmal.ini

 [dmdba@localhost data]#  vi  /dmdata/master/dmmal.ini

MAL_CHECK_INTERVAL   = 5  #MAL 链路检测时间间隔
MAL_CONN_FAIL_INTERVAL  = 5  #判定 MAL 链路断开的时间
[MAL_INST1]
  MAL_INST_NAME = master #与 dm.ini 中的 INSTANCE_NAME 一致
  MAL_HOST     = 10.0.0.11  #MAL 系统监听 TCP 内部网络 IP
  MAL_PORT     = 61141 #MAL 系统监听 TCP 连接的端口
  MAL_INST_HOST   = 192.168.202.141  #实例的对外服务 IP 地址
  MAL_INST_PORT   = 5236 #与 dm.ini 中的 PORT_NUM 一致
  MAL_DW_PORT   = 52141 #实例对应的守护进程监听 TCP 端口
  MAL_INST_DW_PORT = 33141
[MAL_INST2]
  MAL_INST_NAME = slave #与 dm.ini 中的 INSTANCE_NAME 一致
  MAL_HOST      = 10.0.0.12  # MAL 系统监听 TCP 内部网络 IP
  MAL_PORT          = 61141 #MAL 系统监听 TCP 连接的端口
  MAL_INST_HOST         = 192.168.202.142  #实例的对外服务 IP 地址
  MAL_INST_PORT         = 5236 #与 dm.ini 中的 PORT_NUM 一致
  MAL_DW_PORT  = 52141 #实例对应的守护进程监听 TCP 端口
  MAL_INST_DW_PORT = 33141

九、配置守护进程配置文件 dmwatcher.ini

在实例目录下新建文件 dmwatcher.ini,执行以下命令:

主备库文件内容要相同。

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

十、以 Mount 方式启动数据库实例

使用 dmdba 用户,到数据库安装目录的 bin 下执行(主备库都执行)。

[dmdba@localhost data]# dmserver /dmdata/master/dm.ini mount

在新的终端使用 disql 工具连接数据库,执行以下命令:

[dmdba@localhost data]#  disql SYSDBA/SYSDBA

主备库都修改 oguid,执行以下命令:

SQL>sp_set_oguid(453331);

主库修改数据库模式为 primary,执行以下命令:

SQL>alter database primary;

备库修改数据库模式为 standby,执行以下命令:

SQL> alter database standby;

启动守护进程

dmdba 用户下,到数据库安装目录的 bin 下执行(主备库都执行)。

[dmdba@localhost data]#  dmwatcher  /dmdata/master/dmwatcher.ini

[dmdba@localhost data]#  dmwatcher  /dmdata/slave/dmwatcher.ini

守护进程启动后,会将 Mount 的实例 Open

启动确认监视器

守护进程配置为自动切换时,必须配置确认监视器。在主备服务器以外的服务器上(需安装有 DM 数据库软件,且与主备心跳网络端口开放)。

新建确认监视器配置文件 dmmonitor.ini,执行以下命令:

[dmdba@localhost data]#  vi /dmsoft/dmdbms/dmmonitor.ini

添加以下内容:

MON_DW_CONFIRM    = 1   #确认监视器模式
MON_LOG_PATH    = /dmdata/dmdbms/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     = 10.0.0.11:52141
 MON_DW_IP     = 10.0.0.12:52141

启动监视器,执行以下命令:

[dmdba@localhost data]#  dmmonitor /dmsoft/dmdbms/dmmonitor.ini

启动后输入 show 命令查看集群状态。

 

十一、注册服务

以上启动为前台方式启动,仅用户搭建过程中验证配置。配置没问题后需要将实例,守护进程和确认监视器注册为系统服务。使用 root 用户,到数据库安装目录的 script/root 下,执行。

注册守护进程服务(主备库都执行)。

[root@localhost data]#  ./dm_service_installer.sh -t dmwatcher -p master -watcher_ini /dmdata/master/dmwatcher.ini

[root@localhost data]#  ./dm_service_installer.sh -t dmwatcher -p master -watcher_ini /dmdata/slave/dmwatcher.ini

注册数据库实例服务(主备库都执行)。

[root@localhost data]# ./dm_service_installer.sh -t dmserver -p dmrw -dm_ini /dmdata/master/dm.ini

[root@localhost data]#./dm_service_installer.sh -t dmserver -p dmrw -dm_ini /dmdata/slave/dm.in

注册监视器服务(只需在监视器服务器上执行),执行以下命令:

[root@localhost data]#./dm_service_installer.sh -t dmmonitor -p confirm -monitor_ini /dmsoft/dmdbms/dmmonitor.ini

以服务方式启动

启动数据库实例,执行以下命令:

[root@localhost data]#   systemctl stop DmServicedmserver

启动守护进程,执行以下命令:

[root@localhost data]#   systemctl stop DmWatcherServicedmrw

启动监视器,执行以下命令:

[root@localhost data]#   systemctl stop DmMonitorServiceconfirm

十二、验证主备集群同步状态

监视器查看读写分离集群状态

集群任意节点,配置普通监视器配置文件 dmmonitor.ini,执行以下命令:

[dmdba@localhost data]# cat >> /dmsoft/dmdbms/dmmonitor.ini<<EOF

添加以下内容:

MON_DW_Confirm    = 0   #普通监视器模式
MON_LOG_PATH    = /dmdata/dmdbms/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     = 10.0.0.11:52141
 MON_DW_IP     = 10.0.0.12:52141

启动监视器,执行以下命令:[dmdba@localhost data]# ./dmmonitor /dmsoft/dmdbms/dmmonitor.ini

输入 show 命令查看集群状态,执行以下命令:

其中守护进程状态 WSTATUS 为 OPEN,实例状态 ISTATUS 为 OPEN,归档类型 RTYPE 为 REALTIME,归档状态 RSTAT 为VALID。

disql 客户端验证

使用 disql 客户端登录主库,创建测试表,插入数据,执行以下命令:

./disql SYSDBA/SYSDBA@192.168.202.142:5236

SQL 提示符下执行以下命令:

create table test(id int);
insert into test values (1);
commit;

使用 disql 客户端登录备库,查询测试表验证,执行以下命令:

./disql SYSDBA/SYSDBA@192.168.202.143:5236

SQL 提示符下执行以下命令:

select * from test;

十三、重启集群

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

  1. 关闭监视器:systemctl stop DmMonitorServiceconfirm
  2. 关闭主库守护进程:systemctl stop DmWatcherServicedmaster
  3. 关闭备库守护进程:systemctl stop DmWatcherServicedslave
  4. 关闭主库实例:systemctl stop DmServicedmaster
  5. 关闭备库实例:systemctl stop DmServicedslave
  6. 启动主库实例:systemctl start DmServicedmaster
  7. 启动备库实例:systemctl start DmServicedslave
  8. 启动主库守护进程:systemctl start DmWatcherServicedmaster
  9. 启动备库守护进程:systemctl start DmWatcherServicedslave
  10. 启动监视器:systemctl start DmMonitorServiceconfirm

十四、定制备份策略。略...

DM 武汉达梦数据库股份有限公司    24小时免费服务热线:400 991 6599
达梦技术社区:https://eco.dameng.com

Logo

电影级数字人,免显卡端渲染SDK,十行代码即可调用,工业级demo免费开源下载!

更多推荐