达梦数据库基于数据守护的两地三中心灾备环境部署方案


一、概述

本文档介绍基于数据守护的机房实时主备+同城实时备库+异地异步备库的两地三中心灾备方案详细的部署过程。

二、主备集群部署过程(自动切换)

2.1 部署规划

IP规划:

主机名

服务ip

心跳ip

数据库名

实例名

备注

SH01

192.168.3.51

192.168.4.51

dmdb

dw1

节点一

SH02

192.168.3.52

192.168.4.52

dmdb

dw2

节点二

SH03

192.168.3.53

192.168.4.53

dmdb

dw3

节点三

SH04

192.168.3.54

192.168.4.54

dmdb

dw4

节点四

SH05

192.168.3.55

192.168.4.55

确认监视器

端口规划:

实例名

实例端口

MAL 系统监听 TCP 连接的端口

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

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

SH01

5236

7336

7436

7536

SH02

5236

7336

7436

7536

SH03

5236

7336

7436

7536

SH04

5236

7336

7436

7536

目录规划:(在对应服务器上创建目录owner为dmdba组为dinstall)

数据库软件安装目录

/home/dmdba/dmdbms

实例安装目录

/dmdata/

归档日志存放目录

/dmdata/arch

备份文件存放目录

/dmdata/dmbak/

2.2 数据库软件安装

2.2.1 操作系统配置

2.2.1.1 修改内核参数

vi /etc/sysctl.conf

添加以下内容:

fs.file-max = 6815744

fs.aio-max-nr = 1048576

kernel.shmmni = 4096

kernel.sem = 250 32000 100 128

net.ipv4.ip_local_port_range = 9000 65500

net.core.rmem_default = 4194304

net.core.rmem_max = 4194304

net.core.wmem_default = 262144

net.core.wmem_max = 1048576

vm.dirty_ratio = 80

vm.dirty_expire_centisecs = 500

vm.dirty_writeback_centisecs = 100

kernel.core_pattern = /dmdata/core.%p

vm.swappiness=10

vm.dirty_background_ratio = 0

vm.min_free_kbytes = 2097152

使参数生效,执行以下命令:

sysctl -p

2.2.1.2 新建数据库管理用户和组

groupadd dinstall -g 2001

useradd  -G dinstall -m -d /home/dmdba -s /bin/bash -u 2001 dmdba

passwd dmdba

2.2.1.3 修改用户资源限制

vi /etc/security/limits.conf

添加以下内容:

dmdba  soft      nice       0

dmdba  hard      nice       0

dmdba  soft      as         unlimited

dmdba  hard      as         unlimited

dmdba  soft      fsize      unlimited

dmdba  hard      fsize      unlimited

dmdba  soft      nproc      65536

dmdba  hard      nproc      65536

dmdba  soft      nofile     65536

dmdba  hard      nofile     65536

dmdba  soft      core       unlimited

dmdba  hard      core       unlimited

dmdba  soft      data       unlimited

dmdba  hard      data       unlimited

2.2.1.4 修改用户环境变量

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

2.2.2 数据库软件安装

1.使用root用户挂载数据库软件的iso文件

mkdir -p /dmiso

mount -o loop dm8_20200930_x86_rh6_64_ent_8.1.1.134.iso /mnt

2.使用dmdba用户安装软件

su - dmdba

执行以下命令,切换到 /mnt 目录下

cd /mnt

执行DMInstall.bin文件开始安装,选择【-i】参数以命令行方式安装。

./DMInstall.bin -i

选择安装程序的语言 c/C 为中文,e/E 为英文。

提示是否安装 key 文件,输入 N 跳过。

选择时区,21 即东 8 区。

选择安装类型,默认典型安装(包含所有内容)。

选择软件安装目录,默认/home/dmdba/dmdbms

确认安装

安装完成提示使用root执行脚本:

/home/dmdba/dmdbms/script/root/root_installer.sh

2.3 主备集群配置

2.3.1 初始化数据库实例

所有服务器完成数据库初始化。

执行以下命令:

dminit path=/dmdata page_size=32 extent_size=32 charset=1 log_size=256 db_name=dmdb instance_name=dmdb 

以主机SH01为主库,启动实例:

dmserver /dmdata/dmdb/dm.ini

出现system is ready后输入exit停止数据库。

2.3.2 脱机备份数据库

在主机SH01上以dmdba用户启动dmrman工具:

dmrman use_ap=2

执行backup全库:

backup database '/dmdata/dmdb/dm.ini' backupset '/home/dmdba/bakfull';

2.3.3 备份还原数据库

将备份的文件/home/dmdba/bakfull拷贝到备库服务器上。

在所有备节点上使用dmrman工具还原备库,dmdba用户执行:

dmrman

进入dmrman工具交互界面

执行restore:

restore database '/dmdata/dmdb/dm.ini' from backupset '/home/dmdba/bakfull';

完成后执行recover:

recover database '/dmdata/dmdb/dm.ini' from backupset '/home/dmdba/bakfull';

最后执行recover update db_magic:

recover database '/dmdata/dmdb/dm.ini'  update db_magic;

2.3.4 修改dm.ini参数

4个节点都要修改dm.ini文件,使用dmdba用户执行以下命令:

vi /dmdata/dmdb/dm.ini

主库SH01上修改以下参数值:

INSTANCE_NAME = dw1

MAL_INI = 1

ARCH_INI = 1

ALTER_MODE_STATUS = 0

ENABLE_OFFLINE_TS = 2

TIMER_INI = 1

备库SH02上修改以下参数值:

INSTANCE_NAME = dw2

MAL_INI = 1

ARCH_INI = 1

ALTER_MODE_STATUS = 0

ENABLE_OFFLINE_TS = 2

TIMER_INI = 1

主库SH03上修改以下参数值:

INSTANCE_NAME = dw3

MAL_INI = 1

ARCH_INI = 1

ALTER_MODE_STATUS = 0

ENABLE_OFFLINE_TS = 2

TIMER_INI = 1

备库SH04上修改以下参数值:

INSTANCE_NAME = dw4

MAL_INI = 1

ARCH_INI = 1

ALTER_MODE_STATUS = 0

ENABLE_OFFLINE_TS = 2

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

4个节点都要在实例目录下新建文件dmarch.ini文件,使用dmdba用户执行以下命令:

vi /dmdata/dmdb/dmarch.ini

主库SH01上添加以下内容:

[ARCHIVE_REALTIME1]  

ARCH_TYPE     = REALTIME  

ARCH_DEST     = dw2

[ARCHIVE_REALTIME2]  

ARCH_TYPE     = REALTIME  

ARCH_DEST     = dw3

[ARCHIVE_ASYNC]

ARCH_TYPE  = ASYNC

ARCH_DEST  = dw4

ARCH_TIMER_NAME = RT_TIMER    

[ARCHIVE_LOCAL1]

ARCH_TYPE     = LOCAL

ARCH_DEST     = /dmdata/arch    

ARCH_FILE_SIZE    = 256

ARCH_SPACE_LIMIT  = 102400

备库SH02上添加以下内容:

[ARCHIVE_REALTIME1]  

ARCH_TYPE     = REALTIME  

ARCH_DEST     = dw1

[ARCHIVE_REALTIME2]  

ARCH_TYPE     = REALTIME  

ARCH_DEST     = dw3

[ARCHIVE_ASYNC]

ARCH_TYPE  = ASYNC

ARCH_DEST  = dw4

ARCH_TIMER_NAME = RT_TIMER  

[ARCHIVE_LOCAL1]

ARCH_TYPE     = LOCAL

ARCH_DEST     = /dmdata/arch  

ARCH_FILE_SIZE    = 256

ARCH_SPACE_LIMIT  = 102400    

备库SH03上添加以下内容:

[ARCHIVE_REALTIME1]  

ARCH_TYPE     = REALTIME  

ARCH_DEST     = dw1

[ARCHIVE_REALTIME2]  

ARCH_TYPE     = REALTIME  

ARCH_DEST     = dw2

[ARCHIVE_ASYNC]

ARCH_TYPE  = ASYNC

ARCH_DEST  = dw4

ARCH_TIMER_NAME = RT_TIMER  

[ARCHIVE_LOCAL1]

ARCH_TYPE     = LOCAL

ARCH_DEST     = /dmdata/arch  

ARCH_FILE_SIZE    = 256

ARCH_SPACE_LIMIT  = 102400

备库SH04上添加以下内容:

[ARCHIVE_LOCAL1]

ARCH_TYPE     = LOCAL

ARCH_DEST     = /dmdata/arch  

ARCH_FILE_SIZE    = 256

ARCH_SPACE_LIMIT  = 10240

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

4个节点都要在实例目录下新建文件dmmal.ini,执行以下命令。

vi /dmdata/dmdb/dmmal.ini

主备库4个节点文件内容要相同。

MAL_CHECK_INTERVAL   = 5  

MAL_CONN_FAIL_INTERVAL  = 15  

[MAL_INST1]

  MAL_INST_NAME = dw1

  MAL_HOST     = 192.168.4.51  

  MAL_PORT     = 7336

  MAL_INST_HOST   = 192.168.3.51  

  MAL_INST_PORT   = 5236

  MAL_DW_PORT   = 7436

  MAL_INST_DW_PORT = 7536

[MAL_INST2]

  MAL_INST_NAME = dw2

  MAL_HOST      = 192.168.4.52  

  MAL_PORT          = 7336

  MAL_INST_HOST         = 192.168.3.52   

  MAL_INST_PORT         = 5236

  MAL_DW_PORT  = 7436

  MAL_INST_DW_PORT = 7536

[MAL_INST3]

  MAL_INST_NAME = dw3

  MAL_HOST      = 192.168.4.53  

  MAL_PORT          = 7336

  MAL_INST_HOST         = 192.168.3.53   

  MAL_INST_PORT         = 5236

  MAL_DW_PORT  = 7436

  MAL_INST_DW_PORT = 7536

[MAL_INST4]

  MAL_INST_NAME = dw4

  MAL_HOST      = 192.168.4.54  

  MAL_PORT          = 7336

  MAL_INST_HOST         = 192.168.3.54   

  MAL_INST_PORT         = 5236

  MAL_DW_PORT  = 7436

  MAL_INST_DW_PORT = 7536

2.3.7 配置定时器配置文件dmtimer.ini

除异步备库不需要创建dmtimer.ini文件,其他主备库节点都需要在实例目录下新建文件dmtimer.ini,执行以下命令:

vi /dmdata/dmdb/dmtimer.ini

主备库3个节点文件内容要相同。

添加以下内容:

[RT_TIMER]

TYPE = 2

FREQ_MONTH_WEEK_INTERVAL = 1

FREQ_SUB_INTERVAL = 0

FREQ_MINUTE_INTERVAL = 10

START_TIME = 00:00:00

END_TIME = 23:59:59

DURING_START_DATE = 2021-11-01 00:00:00

DURING_END_DATE = 9999-12-31 23:59:59

NO_END_DATE_FLAG = 1

DESCRIBE = RT TIMER

IS_VALID = 1

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

4个节点都要在实例目录下新建文件dmwatcher.ini,执行以下命令:

vi /dmdata/dmdb/dmwatcher.ini

主库SH01上添加以下内容:

[GRP_DW]

DW_TYPE    = GLOBAL  

DW_MODE    = AUTO

DW_ERROR_TIME     = 30  

INST_RECOVER_TIME  = 60         

INST_ERROR_TIME   = 20  

INST_OGUID         = 453331

INST_INI           = /dmdata/dmdb/dm.ini

INST_AUTO_RESTART  = 1   

INST_STARTUP_CMD   = /home/dmdba/dmdbms/bin/dmserver

备库SH02上添加以下内容:

[GRP_DW]

DW_TYPE    = GLOBAL  

DW_MODE    = AUTO

DW_ERROR_TIME     = 30  

INST_RECOVER_TIME  = 60         

INST_ERROR_TIME   = 20  

INST_OGUID         = 453331

INST_INI           = /dmdata/dmdb/dm.ini

INST_AUTO_RESTART  = 1   

INST_STARTUP_CMD   = /home/dmdba/dmdbms/bin/dmserver

备库SH03上添加以下内容:

[GRP_DW]

DW_TYPE    = GLOBAL  

DW_MODE    = AUTO

DW_ERROR_TIME     = 30  

INST_RECOVER_TIME  = 60         

INST_ERROR_TIME   = 20  

INST_OGUID         = 453331

INST_INI           = /dmdata/dmdb/dm.ini

INST_AUTO_RESTART  = 1   

INST_STARTUP_CMD   = /home/dmdba/dmdbms/bin/dmserver

异步备库SH04上添加如下内容:

[GRP_DW]

DW_TYPE = LOCAL

DW_MODE = MANUAL

DW_ERROR_TIME = 30

INST_RECOVER_TIME  = 60

INST_ERROR_TIME = 20

INST_OGUID = 453331

INST_INI           = /dmdata/dmdb/dm.ini

INST_AUTO_RESTART  = 1   

INST_STARTUP_CMD   = /home/dmdba/dmdbms/bin/dmserver

mount 方式启动数据库实例

使用dmdba用户,执行以下命令(主备库都执行):

dmserver /dmdata/dmdb/dm.ini mount

在新的终端使用disql工具连接数据库:

disql SYSDBA/'"Hn@dameng123"'

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

sp_set_oguid(453331);

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

alter database primary;

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

alter database standby;

启动守护进程

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

dmwatcher /dmdata/dmdb/dmwatcher.ini

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

2.3.9 配置sql日志

所有节点修改sqllog.ini

vi /dmdata/dmdb/sqllog.ini

主备库4个节点文件内容要相同。

BUF_TOTAL_SIZE = 10240

BUF_SIZE = 1024

BUF_KEEP_CNT = 6

[SLOG_ALL]

FILE_PATH = ../log

PART_STOR = 1

SWITCH_MODE = 2

SWITCH_LIMIT = 512

ASYNC_FLUSH = 1

FILE_NUM = 5

ITEMS = 0

SQL_TRACE_MASK = 2:3:25

MIN_EXEC_TIME = 1500

USER_MODE = 0

USERS =

2.3.10 注册服务

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

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

./dm_service_installer.sh -t dmwatcher -p dw -watcher_ini /dmdata/dmdb/dmwatcher.ini

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

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

以服务方式启动

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

systemctl start DmServicedw

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

systemctl start DmWatcherServicedw

2.3.11 验证主备集群同步状态

监视器查看主备集群状态。

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

vi /dmdata/dmdb/dmmonitor.ini

添加以下内容:

MON_DW_CONFIRM    = 0

MON_LOG_PATH    = /home/dmdba/dmdbms/log

MON_LOG_INTERVAL  = 60

MON_LOG_FILE_SIZE   = 200

MON_LOG_SPACE_LIMIT  = 1024

[GRP_DW]

 MON_INST_OGUID    = 453331

 MON_DW_IP     = 192.168.4.51:7436

 MON_DW_IP     = 192.168.4.52:7436

 MON_DW_IP     = 192.168.4.53:7436

 MON_DW_IP     = 192.168.4.54:7436

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

dmmonitor /dmdata/dmdb/dmmonitor.ini

输入 show 命令查看集群状态:

其中守护进程状态 WSTATUS 为 OPEN,实例状态 ISTATUS 为 OPEN,实时归档类型 RTYPE 为 TIMELY,异步归档类型为ASYNC,归档状态 RSTAT 为VALID。

disql 客户端验证

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

disql SYSDBA/'"Hn@dameng123"'

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

create table test(id int);

insert into test values (1);

commit;

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

disql SYSDBA/'"Hn@dameng123"'

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

select * from test;

查看数据是否正常同步。

2.3.12 参数优化

集群部署完成后,需要优化 dm.ini 参数,主备库都需要修改。

重启集群(参数修改后需要重启集群):

读写分离集群重启:

关闭主库守护进程:systemctl stop DmWatcherServicedw

关闭备库守护进程:systemctl stop DmWatcherServicedw

关闭主库实例:systemctl stop DmServicedw

关闭备库实例:systemctl stop DmServicedw

启动主库实例:systemctl start DmServicedw

启动备库实例:systemctl start DmServicedw

启动主库守护进程:systemctl start DmWatcherServicedw

启动备库守护进程:systemctl start DmWatcherServicedw

2.3.13 配置确认监视器

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

vi /dmdata/dmdb/dmmonitor.ini

添加以下内容:

MON_DW_CONFIRM    = 1

MON_LOG_PATH    = /home/dmdba/dmdbms/log

MON_LOG_INTERVAL  = 60

MON_LOG_FILE_SIZE   = 200

MON_LOG_SPACE_LIMIT  = 1024

[GRP_DW]

 MON_INST_OGUID    = 453331

 MON_DW_IP     = 192.168.4.51:7436

 MON_DW_IP     = 192.168.4.52:7436

 MON_DW_IP     = 192.168.4.53:7436

 MON_DW_IP     = 192.168.4.54:7436

注册监视器服务:

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

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

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

以服务方式启动监视器服务

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

systemctl start DmMonitorServiceconfirm

 

 想要获取达梦数据库更多的学习资料,可登陆达梦数据云适配中心(https://eco.dameng.com/)获取。