达梦数据库主备集群安装部署步骤

  • 节点规划

public ip

private ip

实例名

端口

用途

192.168.161.204

10.0.0.11

dmrw1

5236

数据库实例 dmrw1 监听端口

192.168.161.204

10.0.0.11

dmrw1

61141

MAL 系统监听 TCP 连接的端口

192.168.161.204

10.0.0.11

dmrw1

52141

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

192.168.161.204

10.0.0.11

dmrw1

33141

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

192.168.161.205

10.0.0.12

dmrw2

5236

数据库实例 dmrw2 监听端口

192.168.161.205

10.0.0.12

dmrw2

61141

MAL 系统监听 TCP 连接的端口

192.168.161.205

10.0.0.12

dmrw2

52141

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

192.168.161.205

10.0.0.12

dmrw2

33141

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

192.168.161.206

10.0.0.100

配置确认监视器以便守护进程自动切换

一.三台机上都需要做的准备工作

1.创建用户与组

groupadd dinstall

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

passwd dmdba

2.配置用户资源限制

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

3.配置用户环境变量

vim /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

4.VM虚拟机添加一块网卡并且设置好private ip

vm虚机添加网卡后, 默认ifconfig看到会多一块网卡,但在/etc/sysconfig/network-scripts下只会看到ifcfg-ens33网卡配置,新添加的网卡没有配置,这种情况下可以用以下命令添加,之后再编辑网卡配置,编辑完重启下网络服务

nmcli con add con-name ens37 type ethernet ifname ens37

 

5.安装DM数据库软件,详细步骤和过程可参考上一篇单机安装步骤,这里不详细说明   

二.在主、备机器上分别初始化一个实例

  

三.主库脱机备份

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

1.注册服务并且启动数据库实例

此处启动数据库实例的方法也可以进入DM安装软件的bin目录下,利用命令./dmserver /homd/dmdba/dmdbms/dmrw/dm.ini前台启动。

2.检查DMAP服务是否已启动,若没启动需要启动。进入DM软件安装路径下的bin目录,./DmAPService start方式进行启动

3.确认DMAP服务已启动,关闭数据库服务,并且启动dmrman备份工具

4.备份

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

四. 还原

1.拷贝刚刚在主库上做的备份,然后传输到备库上

注意:刚刚初始化的实例需要先启动一次,才能还原备份

2.关闭数据库服务,打开dmrman备份工具进行导入

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

3.恢复

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

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

五.配置实例配置文件dm.ini

vim /home/dmdba/dmdbms/dmrw/dm.ini

1.主库上把配置文件中的值修改成以下,其他不需要改动

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

2.备库上把配置文件中的值修改成以下,其他不需要改动

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

六.配置归档配置文件dmarch.ini

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

vim /home/dmdba/dmdbms/dmrw/dmarch.ini

1.主库添加以下内容:

[ARCHIVE_REALTIME]

ARCH_TYPE     = REALTIME  #实时归档类型

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

[ARCHIVE_LOCAL1]

ARCH_TYPE     = LOCAL #本地归档类型

ARCH_DEST     = /home/dmdba/dmdbms/arch #本地归档文件存放路径

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

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

2.备库添加以下内容:

[ARCHIVE_REALTIME]

ARCH_TYPE     = REALTIME  #实时归档类型

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

[ARCHIVE_LOCAL1]

ARCH_TYPE     = LOCAL #本地归档类型

ARCH_DEST     = /home/dmdba/dmdbms/arch  #本地归档文件存放路径

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

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

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

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

vi /home/dmdba/dmdbms/dmrw/dmmal.ini

主备库文件内容相同

MAL_CHECK_INTERVAL   = 5  #MAL 链路检测时间间隔

MAL_CONN_FAIL_INTERVAL  = 5  #判定 MAL 链路断开的时间

[MAL_INST1]

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

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

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

  MAL_INST_HOST   = 192.168.161.204  #实例的对外服务 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      = 10.0.0.12  # MAL 系统监听 TCP 内部网络 IP

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

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

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

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

  MAL_INST_DW_PORT = 33141

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

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

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

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

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

九.以mount方式启动数据库实例

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

./dmserver /home/dmdba/dmdbms/dmrw/dm.ini mount

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

./disql SYSDBA/SYSDBA

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

sp_set_oguid(453331);

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

alter database primary;

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

alter database standby;

十.启动守护进程

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

./dmwatcher /home/dmdba/dmdbms/dmrw/dmwatcher.ini

守护进程启动后,会自动将 处于Mount 状态的实例修改成Open状态。

十一.配置确认监视器

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

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

vim /home/dmdba/dmdbms/dmmonitor.ini

添加以下内容:

MON_DW_CONFIRM    = 1   #确认监视器模式

MON_LOG_PATH    = /home/dmdba/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

2.启动确认监视器,执行以下命令:

./dmmonitor /home/dmdba/dmdbms/dmmonitor.ini

3.启动后输入show查看集群状态,确认是否正常 

十二.注册服务

以上启动为前台方式启动,便于搭建过程中验证。确认配置没问题后一般实际试用的时候需要将实例、守护进程和确认监视器注册为系统服务来使用。

使用 root 用户,到DM软件安装路径的 script/root目录 下执行命令进行服务的注册

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

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

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

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

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

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

十三.以服务的方式启动

1.启动守护进程,一般守护进程会配置自动拉起实例服务,所以不需要额外再启动实例服务,执行以下命令启动守护进程:

systemctl start DmWatcherServicedmrw

若确认守护进程未拉起实例服务,则可以用命令单独启动实例服务,并且查看守护进程配置文件是否没有配置自动拉起实例服务,或者查看日志确认是否有什么报错信息,之后根据报错信息去具体定位原因,启动实例服务的命令如下

systemctl start DmServicedmrw

2.启动确认监视器,执行以下命令:

systemctl start DmMonitorServiceconfirm

十四.配置普通监视器(可选)

一个集群中只能有一个唯一的确认监视器,所以实际使用中一般还会配置其它普通监视器,普通监视器可以有多个

1.配置普通监视器

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

vim /home/dmdba/dmmonitor.ini

添加以下内容:

MON_DW_Confirm    = 0   #普通监视器模式

MON_LOG_PATH    = /home/dmdba/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

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

./dmmonitor /home/dmdba/dmmonitor.ini

3.输入 show 命令查看集群状态

十五.设置客户端连接集群

当搭建了集群后,可以配置以服务名的方式来连接集群。这个需要在客户端主机上配置dm_svc.conf文件,若客户端上未安装DM数据库,则新建此配置文件,此文件默认位于/etc目录下

文件内容如下:

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

# 全局配置区

DMRW=(192.168.161.204:5236,192.168.161.205:5236) #此处的ip为主和备的ip

TIME_ZONE=(+480) #表示+8:00 时区

LOGIN_ENCRYPT=(0)

DIRECT=(Y)

# 服务配置区

[DMRW]

TIME_ZONE=(+540) #表示+9:00 时区

LOGIN_MODE=(1) #设置连接的时候连哪个库,一般为1

SWITCH_TIME=(3)

SWITCH_INTERVAL=(10)

客户端连接集群的时候,不再用具体的ip来连接,而是用服务名来连接

./disql SYSDBA/SYSDBA@dmrw

更多资讯请上达梦技术社区了解:https://eco.dameng.com

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值