1.安装部署前先修改操作系统配置,修改/etc/systemd/system.conf文件,增加DefaultLimitCORE=infinity、DefaultLimitNOFILE=100000、DefaultLimitNPROC=100000并重启机器.

2.修改用户资源限制 vi /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

3.挂载安装包到mnt下

mount dm8_20211021_x86_rh6_64_ent_8.1.2.84.iso /mnt

1.使用命令行进行安装 

读写分离集群部署_重启

2..安装类型、安装位置选择 

读写分离集群部署_数据库_02

3.安装完成,用root用户执行注册服务命令

读写分离集群部署_数据库_03

4.初始化实例

读写分离集群部署_重启_04

5.初始化的实例必须先启动一次,才能脱机备份

读写分离集群部署_重启_05

6.备库按照以上部署一遍


7.执行 脱机backup备份 全库

./dmrman

backup database '/home/dmdba/dmdbms/dmrw/dm.ini' backupset '/home/dmdba/bakfull';

8.通过scp命令把备份的文件传输给备库

读写分离集群部署_数据库_06

9.备库进入

./dmrman

10.执行还原恢复

读写分离集群部署_数据库_07

11.执行 recover update db_magic。(dm7不需要执行这一步)

读写分离集群部署_守护进程_08

​12.修改配置文件dm.in​

主:

INSTANCE_NAME = dmrw1

MAL_INI = 1

ARCH_INI = 1

ALTER_MODE_STATUS = 0

ENABLE_OFFLINE_TS = 2

备:

INSTANCE_NAME = dmrw2

MAL_INI = 1

ARCH_INI = 1

ALTER_MODE_STATUS = 0

ENABLE_OFFLINE_TS = 2

13.配置归档配置文件 dmarch.ini根据实际情况修改

MAL_CHECK_INTERVAL= 5

#MAL 链路检测时间间隔

MAL_CONN_FAIL_INTERVAL= 5


[MAL_INST1]

MAL_INST_NAME = GRP1_RWW_01 #实例名,和 dm.ini 中的 INSTANCE_NAME 一致

MAL_HOST = 192.168.0.141 #MAL 系统监听 TCP 连接的 IP 地址

MAL_PORT = 61141

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

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

MAL_INST_PORT = 32141 #实例的对外服务端口,和 dm.ini 中的 PORT_NUM 一致

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

MAL_INST_DW_PORT = 33141 #实例监听守护进程 TCP 连接的端口

[MAL_INST2]

MAL_INST_NAME = GRP1_RWW_02

MAL_HOST = 192.168.0.142

MAL_PORT = 61142

MAL_INST_HOST = 192.168.1.132

MAL_INST_PORT = 32142

MAL_DW_PORT= 52142

MAL_INST_DW_PORT = 33142

14.配置 dmarch.ini 归档

[ARCHIVE_TIMELY1]

ARCH_TYPE= TIMELY

#即时归档类型

ARCH_DEST= dmrw1 #即时归档目标实例名

[ARCHIVE_LOCAL1]

ARCH_TYPE= LOCAL

#本地归档类型

ARCH_DEST= /dm/data/DAMENG/arch #本地归档文件存放路径

ARCH_FILE_SIZE= 128

#单位 Mb,本地单个归档文件最大值

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

15.配置守护进程 dmwatcher.ini

[GRP1]

DW_TYPE=GLOBAL

#全局守护类型

DW_MODE= AUTO

#自动切换模式

DW_ERROR_TIME = 10

#远程守护进程故障认定时间

INST_RECOVER_TIME = 60 #主库守护进程启动恢复的间隔时间

INST_ERROR_TIME = 10

#本地实例故障认定时间

INST_OGUID = 453332

#守护系统唯一 OGUID 值

INST_INI = /dm/data/DAMENG/dm.ini

#dm.ini 配置文件路径

INST_AUTO_RESTART = 1

#打开实例的自动启动功能

INST_STARTUP_CMD = /dm/bin/dmserver #命令行方式启动

RLOG_SEND_THRESHOLD = 0 #指定主库发送日志到备库的时间阈值,默认关闭

RLOG_APPLY_THRESHOLD = 0 #指定备库重演日志的时间阈值,默认关闭

16.以上配置文件,备库也需要配置一份

17.已前台mount方式启动数据库

读写分离集群部署_数据库_09

18.新开一个窗口执行,修改主库oguid和数据库模式

读写分离集群部署_守护进程_10

19.修改备库oguid与数据库模式

读写分离集群部署_重启_11

20.配置监视器dmmonitor.ini

MON_DW_Cnotallow= 1

#确认监视器模式

MON_LOG_PATH= /dm/data/log #监视器日志文件存放路径

MON_LOG_INTERVAL= 60

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

MON_LOG_FILE_SIZE= 32

#每个日志文件最大 32M

MON_LOG_SPACE_LIMIT= 0

#不限定日志文件总占用空间

[GRP1]

MON_INST_OGUID= 453332 #组 GRP1 的唯一 OGUID 值

#以下配置为监视器到组 GRP1 的守护进程的连接信息,以―IP:PORT‖的形式配置

#IP 对应 dmmal.ini 中的 MAL_HOST,PORT 对应 dmmal.ini 中的 MAL_DW_PORT

MON_DW_IP= 192.168.0.141:52141

MON_DW_IP= 192.168.0.142:52142

21.启动守护进行./dmwatcher /home/dmdba2/dmdata/DAMENG/dmwatcher.ini

22.启动监听./dmmonitor /home/dmdba2/dmdata/DAMENG/dmmonitor.ini

读写分离集群部署_守护进程_12

23.注册服务

以上启动为前台方式启动,仅用户搭建过程中验证配置。配置没问题后需要将实例,守护进程和确认监视器注册为系统服务。

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

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


./dm_service_installer.sh -t dmwatcher -p dmrw -watcher_ini /dmdata/dmrw/dmwatcher.ini

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

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

注册监视器服务(只需在监视器服务器上执行):

./dm_service_installer.sh -t dmmonitor -p confirm -monitor_ini /dmdata/dmmonitor_auto.ini


24.重启数据库步骤

重启集群

读写分离集群重启与主备相同:

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