达梦8读写分离集群搭建部署

主机名

public ip

private ip

实例名

端口

用途

dmdsc1

192.168.52.129

10.10.1.11

dmrw1

5236

数据库实例 dmrw1 监听端口

61141

MAL 系统监听 TCP 连接的端口

52141

实例本地的守护进程监听 TCP 连接的端口

33141

实例监听守护进程 TCP 连接的端口

dmdsc2

192.168.52.131

10.10.1.13

dmrw2

5236

数据库实例 dmrw2 监听端口

61141

MAL 系统监听 TCP 连接的端口

52141

实例本地的守护进程监听 TCP 连接的端口

33141

实例监听守护进程 TCP 连接的端口

一、创建安装用户

1.1创建安装用户组 dinstall

# groupadd dinstall

1.2创建安装用户 dmdba

# useradd -g dinstall -m -d /home/dmdba -s /bin/bash dmdba

1.3初始化用户密码

# passwd dmdba

1.4创建达梦数据库安装目录并授权

[root@localhost ~]# mkdir -p /dm8/dmdbms

[root@localhost ~]# mkdir -p /dm8/dmarch

[root@localhost ~]# mkdir -p /dm8/dmbak

[root@localhost ~]# chown -R dmdba:dinstall /dm8/

[root@localhost ~]# chmod -R 775 /dm8/

1.5挂载iso文件

mount -o loop dm8_20220304_x86_rh6_64_ent_8.1.2.114.iso /mnt/

1.6 修改hosts和hostname

# hostnamectl set-hostname dmdsc1

# vim /etc/hosts

1.7 设置操作系统防火墙、Selinux并重载生效

vim /etc/selinux/config

SELINUX= disabled

# 关闭防火墙

systemctl stop firewalld.service

# 设置开机禁用防火墙

systemctl disable firewalld.service

# 查看防火墙状态

firewall-cmd  --state

not running

1.8 用户资源限制

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

1.9 配置环境变量

在dmdba用户自动添加添加如下内容:

[dmdba@dmdsc1 ~]$ vim .bash_profile

export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/dm8/dmdbms/bin"

export DM_HOME="/dm8/dmdbms"

export PATH="$PATH:$DM_HOME/bin"

二、安装数据库

2.1 安装数据库软件 注:主备库都需要安装

主备库安装数据库软件方式相同

切换用户到dmdba

# su - dmdba

$ cd /mnt

$ ./DMInstall.bin -i

依次输入 c                       选择中文

               n                        选择输入dm.key文件路径

               y                       选择设置时区

               21                     默认为21中国标准时间

               1                       默认为1标准安装

             /dm8/dmdbms     输入安装目录

               y                         输入y确认安装

安装结束,根据提示,请以root系统用户执行命令:

$ sudo su

# cd /opt/dmdbms/script/root/

# ./root_installer.sh

数据库安装完成

2.2初始化数据库 注: 主备库都执行

# su – dmdba

$ cd /dm8/dmdbms/bin

./dminit path=/dm8/dmdbms db_name=dmrw page_size=32 extent_size=32

注意:

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

$ cd /dm8/dmdbms/bin

$ ./dmserver /dm8/dmdbms/dmrw/dm.ini

启动后关闭进程即可

2.3主库脱机备份

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

ps -ef|grep dmap

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

cd /dm8/dmdba/bin

./DmAPService start

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

su - dmdba

cd /dm8/dmdba/bin

./dmrman

执行 backup 全库

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

2.4 备库还原

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

$ scp bakfull.* dmdba@192.168.52.131:/dm8/dmbak/

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

su - dmdba

cd /dm8/dmdba/bin

./dmrman

执行 restore

restore database '/dm8/dmdbms/dmrw/dm.ini' from backupset '/dm8/dmbak';

执行 recover

recover database '/dm8/dmdbms/dmrw/dm.ini' from backupset '/dm8/dmbak';

执行 recover update db_magic

recover database '/dm8/dmdbms/dmrw/dm.ini' update db_magic;

三、配置主库配置文件

3.1配置dm.ini文件参数

$ cd /dm8/dmdbms/dmrw

$ vim dm.ini

INSTANCE_NAME = GRP1_RWW_01 

MAL_INI = 1

ARCH_INI = 1

ALTER_MODE_STATUS = 0

ENABLE_OFFLINE_TS = 2

3.2 配置归档文件dmarch.ini

$ cd /dm8/dmdbms/dmrw

$ vim dmarch.ini

[ARCHIVE_REALTIME]

ARCH_TYPE     = TIMELY  #即时归档类型

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

[ARCHIVE_LOCAL1]

ARCH_TYPE     = LOCAL #本地归档类型

ARCH_DEST     = /dm8/dmarch #本地归档文件存放路径

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

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

3.3 配置MAL系统配置文件 dmmal.ini

$ cd /dm8/dmdbms/dmrw

$ 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     = 10.10.1.11  #MAL 系统监听 TCP 内部网络 IP

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

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

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

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

  MAL_INST_DW_PORT = 33141

[MAL_INST2]

  MAL_INST_NAME = GRP1_RWW_02 #与 dm.ini 中的 INSTANCE_NAME 一致

  MAL_HOST      = 10.10.1.13  # MAL 系统监听 TCP 内部网络 IP

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

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

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

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

  MAL_INST_DW_PORT = 33142

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

$ cd /dm8/dmdbms/dmrw

$ 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           = /dm8/dmdbms/dmrw/dm.ini #dm.ini 配置文件路径

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

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

3.5 以MOUNT方式启动数据库实例

$ cd /dm8/dmdbms/bin/

./dmserver /dm8/dmdbms/dmrw/dm.ini mount

$ cd /dm8/dmdbms/bin/

./disql SYSDBA/SYSDBA

SQL>SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);

SQL> sp_set_oguid(453332); 注:设置OUGID值

SQL>SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);

SQL> alter database primary; 主库修改数据库为 primary 模式

Mount 执行进程不要关闭

3.6 启动守护进程

$ cd /dm8/dmdbms/bin/

./dmwatcher /dm8/dmdbms/dmrw/dmwatcher.ini

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

四、配置备库配置文件

4.1配置dm.ini文件参数

$ cd /dm8/dmdbms/dmrw

$ vim dm.ini

INSTANCE_NAME = GRP1_RWW_02

MAL_INI = 1

ARCH_INI = 1

ALTER_MODE_STATUS = 0

ENABLE_OFFLINE_TS = 2

4.2 配置归档文件dmarch.ini

$ cd /dm8/dmdbms/dmrw

$ vim dmarch.ini

[ARCHIVE_REALTIME]

ARCH_TYPE     = TIMELY #即时归档类型

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

[ARCHIVE_LOCAL1]

ARCH_TYPE     = LOCAL #本地归档类型

ARCH_DEST     = /dm8/dmarch  #本地归档文件存放路径

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

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

4.3 配置MAL系统配置文件 dmmal.ini

$ cd /dm8/dmdbms/dmrw

$ 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     = 10.10.1.11  #MAL 系统监听 TCP 内部网络 IP

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

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

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

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

  MAL_INST_DW_PORT = 33141

[MAL_INST2]

  MAL_INST_NAME = GRP1_RWW_02 #与 dm.ini 中的 INSTANCE_NAME 一致

  MAL_HOST      = 10.10.1.13  # MAL 系统监听 TCP 内部网络 IP

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

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

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

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

  MAL_INST_DW_PORT = 33142

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

$ cd /dm8/dmdbms/dmrw

$ 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           = /dm8/dmdbms/dmrw/dm.ini #dm.ini 配置文件路径

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

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

4.5 以MOUNT方式启动数据库实例

$ cd /dm8/dmdbms/bin/

./dmserver /dm8/dmdbms/dmrw/dm.ini mount

$ cd /dm8/dmdbms/bin/

./disql SYSDBA/SYSDBA

SQL>SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);

SQL> sp_set_oguid(453332); 注:设置OUGID值

SQL>SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);

SQL>SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);

SQL> alter database standby; 主库修改数据库为 standby模式

SQL>SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);

Mount 执行进程不要关闭

4.6 启动守护进程

$ cd /dm8/dmdbms/bin/

./dmwatcher /dm8/dmdbms/dmrw/dmwatcher.ini

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

五 配置监视器

前期配置一样,安装数据库软件即可

5.1 配置确认监视器

$ cd /dm8/dmdbms/

$ vim dmmonitor.ini

MON_DW_CONFIRM    = 1   #确认监视器模式

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

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

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

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

[GRP1]

 MON_INST_OGUID    = 453332 #组 GRP_RW 的唯一 OGUID 值

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

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

 MON_DW_IP     = 10.10.1.11:52141

 MON_DW_IP     = 10.10.1.13:52142

5.2 启动监视器

$ cd /dm8/dmdbms/bin

./dmmonitor /dm8/dmdbms/dmmonitor.ini

六、注册服务

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

cd /dm8/dmdbms/script/root/

./dm_service_installer.sh -t dmwatcher -p dmrw -watcher_ini /dm8/dmdbms/dmrw/dmwatcher.ini

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

cd /dm8/dmdbms/script/root/

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

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

cd /dm8/dmdbms/script/root/

./dm_service_installer.sh -t dmmonitor -p confirm -monitor_ini /dm8/dmdbms/dmmonitor.ini

6.4 启动服务

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

systemctl start DmServicedmrw

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

systemctl start DmWatcherServicedmrw

启动监视器,执行以下命

systemctl start DmMonitorServiceconfirm

6.5 配置普通监视器

$ cd /dm8/dmdbms/

$ vim dmmonitor0.ini

MON_DW_Confirm    = 0   #普通监视器模式

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

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

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

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

[GRP1]

 MON_INST_OGUID    = 453332 #组 GRP_RW 的唯一 OGUID 值

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

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

 MON_DW_IP     = 10.10.1.11:52141

 MON_DW_IP     = 10.10.1.13:52142

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

./dmmonitor /dm8/dmdbms/dmmonitor0.ini

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

七、dm_svc.conf 配置

7.1 简介

dm_svc.conf 是使用 DM 数据库时非常重要的配置文件,它包含了 DM 各接口和客户端工具所需要配置的一些参数。通过他可以实现 DM 各种集群的读写分离和均衡负载,且必须和接口/客户端工具位于同一台机器上才能生效。

初始 dm_svc.conf 文件由 DM 安装时自动生成。不同的平台生成目录有所不同,注意相应访问用户需要对该文件有读取权限。

32 位的 DM 安装在 Win32 操作平台下,此文件位于%SystemRoot%\system32目录;

64 位的 DM 安装在 Win64 操作平台下,此文件位于%SystemRoot%\system32目录;

32 位的 DM 安装在 Win64 操作平台下,此文件位于%SystemRoot%\SysWOW64目录;

在 Linux 平台下,此文件位于/etc 目录。

但在某些情况下,所使用的用户没有读取和修改/etc 目录下文件的权限,这时就需要将 dm_svc.conf 文件放到有权限的目录下,并修改 url 连接串的内容。以 Linux 平台,文件放在 /etc 目录下

编辑 dm_svc.conf 文件:

#以#开头的行表示是注释

#全局配置区

TIME_ZONE=(480)

LANGUAGE=(cn)

DMRW=(192.168.52.129:5236, 192.168.52.131:5236)

#服务配置

[DMRW]

LOGIN_MODE=(1)

RW_SEPARATE=(1)

RW_PERCENT=(30)

SWITCH_TIMES=(60)

SWITCH_INTERVAL=(1000)

jdbc 连接串

jdbc:dm://DMRW

7.2  常用配置项介绍

服务名

用于连接数据库的服务名,类似Oracle配置在tnsname.ora文件中的服务名,参数值格式为:

服务名=(IP[:PORT],IP[:PORT],……)。

TIME_ZONE

指明客户端的默认时区设置范围为:-779~840M,如 60 对应+1:00 时区,+480 对于东八区,如果不做配置默认是操作系统的时区。

KEYWORDS

该参数可以用于屏蔽数据库关键字,如果数据库关键字在 SQL 语句中以单词的形式存在,无法识别需要加上双引号或者可以通过该参数来屏蔽关键字,建议大小写都写入参数中。

例如:KEYWORDS=(versions,VERSIONS,type,TYPE)

LOGIN_MODE

指定优先登录的服务器模式。0:优先连接PRIMARY 模式的库,NORMAL 模式次之,最后选择STANTBY 模式;1:只连接主库;2:只连接备库;3:优先连接STANDBY 模式的库,PRIMARY 模式次之,最后选择NORMAL 模式;4:优先连接NORMAL 模式的库,PRIMARY 模式次之,最后选择STANDBY 模式。

注意:在2021年版本之后,此参数的默认值由0变更为4,因此在高可用切换场景下,使用不同时间版本驱动会有不同的表现。如果想要保持一致可以将此参数固定在 dm_svc.conf 文件中。

SWITCH_TIMES

以服务名连接数据库时,若未找到符合条件的库成功建立连接,将尝试遍历服务名中库列表的次数。有效值范围1~9223372036854775807,默认值为1,可以设置至少 3 次用来避免由于网卡的波动,造成数据库连接测频繁切换

SWITCH_INTERVAL

在服务器之间切换的时间间隔,单位为毫秒,有效值范围 1~9223372036854775807。与参数 SWITCH_TIMES、EP_SELECTOR 配合使用,EP_SELECTOR 设置为 0,等待 SWITCH_INTERVAL 后会切换尝试连接下一个服务器,EP_SELECTOR 设置为1,等待 SWITCH_INTERVAL 后会继续尝试连接该服务器,直到 SWITCH_TIMES 次再切换下一个服务器。

RW_SEPARATE

是否启用读写分离。0:不启用;1:启用;2:启用,备库由客户端进行选择,且只会选择服务名中配置的节点。

RW_PERCENT

读写分离分发比例,有效值范围0~100,及主库占所有事物数的比例。可以根据主备库的实际压力来设定。

EP_SELECTOR

连接数据库时采用何种模型建立连接,0:依次选取列表中的不同节点建立连接,使得所有连接均匀地分布在各个节点上,1:选择列表中最前面的节点建立连接,只有当前节点无法建立连接时才会选择下一个节点进行连接。

AUTO_RECONNECT

连接发生异常或一些特殊场景下连接处理策略。0:关闭连接,1:当连接发生异常时自动切换到其他库,无论切换成功还是失败都会抛一个 SQLEXCEPTION,用于通知上层应用进行事务执行失败时的相关处理;2 配合 EP_SELECTOR=1 使用,如果服务名列表前面的节点恢复了,将当前连接切换到前面的节点上,可以根据应用的实际要求设定。

达梦数据库 - 新一代大型通用关系型数据库 | 达梦在线服务平台

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值