2020-11-10

达梦数据库-读写分离集群搭建

一、环境说明

机器名 IP地址 初始状态 操作系统
略 192.168.18.150 主库 Centos7
略 192.168.18.151 备库 Centos7

实例名 PORT_NUM MAL_INST_DW_PORT MAL_HOST MAL_DW_PORT
GRP1_RWW_01 5236 33141 192.168.18.150 52141
GRP1_RWW_02 5236 33142 192.168.18.151 52142

二、数据准备

1、初始化数据库
./dminit path=/data
在这里插入图片描述

2、备份
注:此处为脱机备份,路径仅供参考。

①正常关闭数据库
②进行脱机备份
./dmrman CTLSTMT=“BACKUP DATABASE ‘/data/dmdbms/DAMENG/dm.ini’ FULL TO BACKUP_FILE1 BACKUPSET ‘/data/BACKUP_FILE_01’”
在这里插入图片描述

③拷贝备份文件到备库所在机器(主–>备)
scp -r /data/BACKUP_FILE_01 192.168.18.151:/data/dmdbms
在这里插入图片描述

④执行脱机数据库还原与恢复(备)
还原:
./dmrman ctlstmt=“RESTORE DATABASE ‘/data/dmdbms/DAMENG/dm.ini’ FROM BACKUPSET ‘/data/BACKUP_FILE_01’”
在这里插入图片描述

恢复:
./dmrman ctlstmt=“RECOVER DATABASE ‘/data/dmdbms/DAMENG/dm.ini’ FROM BACKUPSET ‘/data/BACKUP_FILE_01’”
在这里插入图片描述

./dmrman ctlstmt=“RECOVER DATABASE ‘/data/dmdbms/DAMENG/dm.ini’ UPDATE DB_MAGIC”
在这里插入图片描述

三、配置读写分离集群

1、配置主库 GRP1_RWW_01
1)配置dm.ini(注:port_num配置的5236,备库也是5236)
vim dm.ini
#实例名,建议使用―组名_守护环境_序号‖的命名方式,总长度不能超过 16
INSTANCE_NAME = GRP1_RWW_01
PORT_NUM = 32141 #数据库实例监听端口
DW_INACTIVE_INTERVAL = 60 #接收守护进程消息超时时间
ALTER_MODE_STATUS = 0 #不允许手工方式修改实例模式/状态/OGUID
ENABLE_OFFLINE_TS = 2 #不允许备库 OFFLINE 表空间
MAL_INI = 1 #打开 MAL 系统
ARCH_INI = 1 #打开归档配置
RLOG_SEND_APPLY_MON = 64 #统计最近 64 次的日志发送信息

注:配置以上信息,查看是否对应。
2)配置 dmmal.ini
说明:配置 MAL 系统,各主备库的 dmmal.ini 配置必须完全一致,MAL_HOST 使用内部网
络 IP,MAL_PORT 与 dm.ini 中 PORT_NUM 使用不同的端口值,MAL_DW_PORT 是各实例
对应的守护进程之间,以及守护进程和监视器之间的通信端口。
vim dmmal.ini

MAL_CHECK_INTERVAL = 5 #MAL 链路检测时间间隔
MAL_CONN_FAIL_INTERVAL = 5 #判定 MAL 链路断开的时间
[MAL_INST1]
MAL_INST_NAME = GRP1_RWW_01 #实例名,和 dm.ini 中的 INSTANCE_NAME 一致
MAL_HOST = 192.168.18.150 #MAL 系统监听 TCP 连接的 IP 地址
MAL_PORT = 61141 #MAL 系统监听 TCP 连接的端口
MAL_INST_HOST = 192.168.18.150 #实例的对外服务 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.18.151
MAL_PORT = 61142
MAL_INST_HOST = 192.168.18.151
MAL_INST_PORT = 32142
MAL_DW_PORT = 52142
MAL_INST_DW_PORT = 33142
#[MAL_INST3]
#MAL_INST_NAME = GRP1_RWW_03
#MAL_HOST = 192.168.0.143
#MAL_PORT = 61143
#MAL_INST_HOST = 192.168.1.133
#MAL_INST_PORT = 32143
#MAL_DW_PORT = 52143
#MAL_INST_DW_PORT = 33143
3)配置 dmarch.ini
说明:修改 dmarch.ini,配置本地归档和即时归档。
vim dmarch.ini
[ARCHIVE_TIMELY1]
ARCH_TYPE = TIMELY #即时归档类型
ARCH_DEST = GRP1_RWW_02 #即时归档目标实例名
#[ARCHIVE_TIMELY2]
#ARCH_TYPE = TIMELY #即时归档类型
#ARCH_DEST = GRP1_RWW_03 #即时归档目标实例名
[ARCHIVE_LOCAL1]
ARCH_TYPE = LOCAL #本地归档类型
ARCH_DEST = /data/dmdbms/DAMENG/arch #本地归档文件存放路径
ARCH_FILE_SIZE = 128 #单位 Mb,本地单个归档文件最大值
ARCH_SPACE_LIMIT = 0 #单位 Mb,0 表示无限制,范围 1024~4294967294M

4)配置 dmwatcher.ini
说明:配置为全局守护类型,使用自动切换模式。
vim 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 = /data/dmdbms/DAMENG/dm.ini #dm.ini 配置文件路径
INST_AUTO_RESTART = 1 #打开实例的自动启动功能
INST_STARTUP_CMD = /data/dmdbms/bin/dmserver #命令行方式启动
RLOG_SEND_THRESHOLD = 0 #指定主库发送日志到备库的时间阀值,默认关闭
RLOG_APPLY_THRESHOLD = 0 #指定备库重演日志的时间阀值,默认关闭

5)启动主库(以mount方式启动)
./dmserver /data/dmdbms/DAMENG/dm.ini mount
在这里插入图片描述

6)设置OGUID
登录disql进行设置。
SQL>SP_SET_PARA_VALUE(1, ‘ALTER_MODE_STATUS’, 1);
SQL>sp_set_oguid(453332);
SQL>SP_SET_PARA_VALUE(1, ‘ALTER_MODE_STATUS’, 0);
7)修改数据库模式
SQL>alter database primary;
2、配置备库 GRP1_RWW_02
1)配置dm.ini
vim dm.ini

#实例名,建议使用―组名_守护环境_序号‖的命名方式,总长度不能超过 16
INSTANCE_NAME = GRP1_RWW_02
PORT_NUM = 32141 #数据库实例监听端口
DW_INACTIVE_INTERVAL = 60 #接收守护进程消息超时时间
ALTER_MODE_STATUS = 0 #不允许手工方式修改实例模式/状态/OGUID
ENABLE_OFFLINE_TS = 2 #不允许备库 OFFLINE 表空间
MAL_INI = 1 #打开 MAL 系统
ARCH_INI = 1 #打开归档配置
RLOG_SEND_APPLY_MON = 64 #统计最近 64 次的日志发送信息
注:配置以上信息,查看是否对应。
2)配置dmmal.ini
vim dmmal.ini
MAL_CHECK_INTERVAL = 5 #MAL 链路检测时间间隔
MAL_CONN_FAIL_INTERVAL = 5 #判定 MAL 链路断开的时间
[MAL_INST1]
MAL_INST_NAME = GRP1_RWW_01 #实例名,和 dm.ini 中的 INSTANCE_NAME 一致
MAL_HOST = 192.168.18.150 #MAL 系统监听 TCP 连接的 IP 地址
MAL_PORT = 61141 #MAL 系统监听 TCP 连接的端口
MAL_INST_HOST = 192.168.18.150 #实例的对外服务 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.18.151
MAL_PORT = 61142
MAL_INST_HOST = 192.168.18.151
MAL_INST_PORT = 32142
MAL_DW_PORT = 52142
MAL_INST_DW_PORT = 33142
#[MAL_INST3]
#MAL_INST_NAME = GRP1_RWW_03
#MAL_HOST = 192.168.0.143
#MAL_PORT = 61143
#MAL_INST_HOST = 192.168.1.133
#MAL_INST_PORT = 32143
#MAL_DW_PORT = 52143
#MAL_INST_DW_PORT = 33143

3)配置dmarch.ini
说明:修改 dmarch.ini,配置本地归档和即时归档。
vim dmarch.ini
[ARCHIVE_TIMELY1]
ARCH_TYPE = TIMELY #即时归档类型
ARCH_DEST = GRP1_RWW_01 #即时归档目标实例名
#[ARCHIVE_TIMELY2]
#ARCH_TYPE = TIMELY #即时归档类型
#ARCH_DEST = GRP1_RWW_03 #即时归档目标实例名
[ARCHIVE_LOCAL1]
ARCH_TYPE = LOCAL #本地归档类型
ARCH_DEST = /data/dmdbms/DAMENG/arch #本地归档文件存放路径
ARCH_FILE_SIZE = 128 #单位 Mb,本地单个归档文件最大值
ARCH_SPACE_LIMIT = 0 #单位 Mb,0 表示无限制,范围 1024~4294967294M

4)配置dmwatcher.ini
说明:配置为全局守护类型,使用自动切换模式。
vim 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 = /data/dmdbms/DAMENG/dm.ini #dm.ini 配置文件路径
INST_AUTO_RESTART = 1 #打开实例的自动启动功能
INST_STARTUP_CMD = /data/dmdbms/bin/dmserver #命令行方式启动
RLOG_SEND_THRESHOLD = 0 #指定主库发送日志到备库的时间阀值,默认关闭
RLOG_APPLY_THRESHOLD = 0 #指定备库重演日志的时间阀值,默认关闭

5)启动备库(以mount方式启动)
./dmserver /data/dmdbms/DAMENG/dm.ini mount
在这里插入图片描述

6)设置ODUID
SQL>SP_SET_PARA_VALUE(1, ‘ALTER_MODE_STATUS’, 1);
SQL>sp_set_oguid(453332);
SQL>SP_SET_PARA_VALUE(1, ‘ALTER_MODE_STATUS’, 0);
7)修改数据库模式
SQL>SP_SET_PARA_VALUE(1, ‘ALTER_MODE_STATUS’, 1);
SQL>alter database standby;
SQL>SP_SET_PARA_VALUE(1, ‘ALTER_MODE_STATUS’, 0);

3、配置监视器
说明:由于主库和即时备库的守护进程配置为自动切换模式,因此这里选择配置确认监视器。和普通监视器相比,确认监视器除了相同的命令支持外,在主库发生故障时,能够自动通知。即时备库接管为新的主库,具有自动故障处理的功能。
修改 dmmonitor.ini 配置确认监视器,其中 MON_DW_IP 中的 IP 和 PORT 和dmmal.ini 中的 MAL_HOST 和 MAL_DW_PORT 配置项保持一致。
vim dmmonitor.ini
MON_DW_Confirm = 1 #确认监视器模式
MON_LOG_PATH = /data/dmdbms/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.18.150:52141
MON_DW_IP = 192.168.18.151:52142
#MON_DW_IP = 192.168.0.143:52143

4、启动守护进程(主库和备库)
./dmwatcher /data/dmdbms/DAMENG/dmwatcher.ini

5、启动监视器
./dmmonitor /data/dmdbms/DAMENG/dmmonitor.ini
在这里插入图片描述

四、注册服务

说明:
如果想让dmserver、dmwatcher和dmmonitor服务开机自启动,需要手动注册服务,注册步骤必须用root用户进行,注册完成后重启机器时,就会自动启动dmserver、 dmwatcher和dmmonitor服务。其中,因为确认监视器一直处于工作状态,所以确认监视器需要注册dmmonitor服务,自动启动;非确认监视器是在查看信息时才使用,届时手 动启动控制台dmmonitor服务即可,可以不用注册dmmonitor服务。

–该目录根据创建数据库所对应目录。
注册服务目录:cd /home/dmdba/dmdbms/script/root/
此处目录为:/data/dmdbms/script/root

1)主库注册服务进程:
./dm_service_installer.sh -t dmserver -dm_ini /data/dmdbms/DAMENG/dm.ini -p mount
在这里插入图片描述

主库注册守护进程:
./dm_service_installer.sh -t dmwatcher -watcher_ini /data/dmdbms/DAMENG/dmwatcher.ini -p dmwatcher
在这里插入图片描述

2)备库注册服务进程:
./dm_service_installer.sh -t dmserver -dm_ini /data/dmdbms/DAMENG/dm.ini -p mount
在这里插入图片描述

备库注册守护进程:
./dm_service_installer.sh -t dmwatcher -watcher_ini /data/dmdbms/DAMENG/dmwatcher.ini -p dmwatcher
在这里插入图片描述

备库注册监控进程:
./dm_service_installer.sh -t dmmonitor -monitor_ini /data/dmdbms/DAMENG/dmmonitor.ini -p dmmonitor
在这里插入图片描述

启动顺序:
1)主库服务
2)备库服务
3)主库守护进程
4)备库守护进程
5)监控进程

停止顺序:
1)监控进程
2)备库守护进程
3)备库服务
4)主库守护进程
5)主库服务

五、可能遇到的问题
1、主备库处于mount,不能open。原因FLSN值相差较大,需要备份还原。
主库:
在这里插入图片描述

备库:
在这里插入图片描述

解决:
1)将主库备份(脱机备或联机备);
2)将备份scp到备库进行备份还原(即数据同步);
3)检查相应的配置文件是否正确(主要检查实例名和端口);
4)重新启动。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值