注册
DM8主备集群部署(2节点)
专栏/培训园地/ 文章详情 /

DM8主备集群部署(2节点)

zheng778 2023/10/10 1237 0 0
摘要

DM主备集群部署(2节点)

1 主备集群规划

表1.1 服务器IP规划

类别 实例名 服务器地址 心跳IP
主库 PS1 192.168.50.134 192.168.0.15
备库 PS2 192.168.50.137 192.168.0.25

表1.2 端口规划

名称 端口
PORT_NUM 5236
MAL_PORT 7336
MAL_DW_PORT 7536
MAL_INST_DW_PORT 7436
MAL_INST_PORT 5236

表1.3 目录规划

目录 路径
安装目录 /dm
数据文件目录 /dm/data
备份目录 /dm/dbbak/dmbak
归档目录 /dm/data/DAMENG/dmarch

2 集群部署

2.1 Linux下数据库软件安装

注意:两台服务器都需要安装

2.1.1创建安装用户

[root@localhost /]# groupadd dinstall [root@localhost /]# useradd -g dinstall dmdba [root@localhost /]# passwd dmdba

之后通过系统提示进行密码设置

2.1.2 检查操作系统限制

使用ulimit -a命令进行查询
2.1.png
参数使用限制:

data seg size (kbytes, -d)

建议用户设置为 1048576(即 1GB)以上或 unlimited(无限制),此参数过小将导致数据库启动失败。

file size(blocks, -f)

建议用户设置为 unlimited(无限制),此参数过小将导致数据库安装或初始化失败。

open files(-n)

建议用户设置为 65536 以或 unlimited(无限制)。

virtual memory (kbytes, -v)

建议用户设置为 1048576(即 1GB)以上或 unlimited(无限制),此参数过小将导致数据库启动失败。
如果用户需要为当前安装用户更改 ulimit的资源限制,请修改文件/etc/security/limits.conf。

[root@localhost /]# vi /etc/security/limits.conf

文件最后添加

dmdba hard nofile 65536
dmdba soft nofile 65536
dmdba hard stack 32768
dmdba soft stack 16384

2.2.png

2.1.3安装DM8

创建目录/dm

[root@localhost /]# mkdir dm

赋予权限

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

挂载光驱
2.3.png
使用df命令查看挂载设备,使用mount命令挂载至/mnt/cdrom下

[root@localhost /]# mount /dev/sr0 /mnt/cdrom

复制安装文件到/opt下

[root@localhost /]# cd /mnt/cdrom
[root@localhost cdrom]# cp DMInstall.bin /opt/DMInstall.bin

赋予文件执行权限

[root@localhost cdrom]# cd /opt
[root@localhost opt]# chmod 755 DMInstall.bin

切换安装用户

[root@localhost opt]# su dmdba

执行命令进行安装

[dmdba@localhost opt]$ ./DMInstall.bin -i

2.4.png
根据图中选择进行安装
注意:安装完成后要使用root用户执行命令
2.5.png
2.6.png

2.2 初始化实例

2个节点都有实例初始化,执行以下命令:
主机PS1:

[dmdba@localhost ~]$ cd /dm/bin
[dmdba@localhost bin]$./dminit path=/dm/data page_size=32 log_size=1024 instance_name=PS1

开启服务

[dmdba@localhost bin]$ cp service_template/DmService dmserverd
[dmdba@localhost bin]$ vim dmserverd
INI_PATH=/dm/data/DAMENG/dm.ini

3.1.png

[dmdba@localhost bin]$ ./dmserverd start

开机自启配置

[root@localhost bin] cp dmserverd /etc/init.d/
[root@localhost bin] chkconfig --add dmserverd
[root@localhost bin] chkconfig –-list

备机PS2:

[dmdba@localhost ~]$ cd /dm/bin
[dmdba@localhost bin]$ ./dminit path=/dm/data page_size=32 log_size=1024 instance_name=PS2

开启服务

[dmdba@localhost bin]$ cp service_template/DmService dmserverd
[dmdba@localhost bin]$ vim dmserverd
INI_PATH=/dm/data/DAMENG/dm.ini
[dmdba@localhost bin]$ dmserverd start

开机自启配置

[root@localhost bin] cp dmserverd /etc/init.d/
[root@localhost bin] chkconfig --add dmserverd
[root@localhostbin] chkconfig --list

2.3 脱机备份主机数据库

在主机ZB1上执行以下命令,确认主库dmap服务已启动:

ps -ef|grep dmap

3.2.png
若未启动,则先启动 DMAP 服务,使用dmdba用户切换到安装目录的 bin 下执行以下命令:

./DmAPService start

若已启动,则执行以下命令进行脱机备份

[dmdba@localhost bin]$ ./dmserverd stop
[dmdba@localhost bin]$ ./dmrman use_ap=2
[dmdba@localhost bin]$
dmrman V8
RMAN> backup database '/dm/data/DAMENG/dm.ini' backupset '/dm/dbbak/dmbak/bakfull';

2.4 脱机还原备机数据库

将备份的文件/dm/dbbak/dmbak/bakfull拷贝到备库服务器上。

[dmdba@localhost dmbak] scp -r bakfull/ dmdba@192.168.0.17:/dm/dbbak/dmbak

在备机ZB2上,使用 dmrman 工具还原备库,dmdba 用户执行:

[dmdba@localhost bin]$ ./dmserverd stop
[dmdba@localhost bin]$ ./dmrman

#执行restore
RMAN> restore database '/dm/data/DAMENG/dm.ini' from backupset '/dm/dbbak/dmbak/bakfull';
#执行recover
RMAN> recover database '/dm/data/DAMENG/dm.ini' from backupset '/dm/dbbak/dmbak/bakfull';
#执行recover update db_magic
RMAN> recover database '/dm/data/DAMENG/dm.ini' update db_magic;

2.5 配置文件修改

2.5.1 修改dm.ini参数

在ZB1和ZB2上分别修改dm.ini参数值:

vi /dm/data/DAMENG/dm.ini

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

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

在ZB1和ZB2上分别修改dmarch.ini参数值:

ZB1:

[dmdba@localhost bin]$ vi /dm/data/DAMENG/dmarch.ini

ZB2:

[dmdba@localhost bin]$ vi /dm/data/DAMENG/dmarch.ini

主机ZB1上添加以下内容:

[ARCHIVE_REALTIME]
ARCH_TYPE     = REALTIME  #实时归档类型
aRCH_DEST     = PS2   #实时归档目标实例名(主库侧填写备库实例名)
[ARCHIVE_LOCAL1]
ARCH_TYPE     = LOCAL #本地归档类型
ARCH_DEST     = /dm/data/DAMENG/dmarch #本地归档文件存放路径
ARCH_FILE_SIZE    = 128 #单位 MB,本地单个归档文件最大值
ARCH_SPACE_LIMIT  = 10240 #单位 MB,0 表示无限制,范围 1024~4294967294 MB

3.3.png
备机ZB2上添加以下内容:

[ARCHIVE_REALTIME]
ARCH_TYPE     = REALTIME  #实时归档类型
aRCH_DEST     = PS1   #实时归档目标实例名(主库侧填写备库实例名)
[ARCHIVE_LOCAL1]
ARCH_TYPE     = LOCAL #本地归档类型
ARCH_DEST     = /dm/data/DAMENG/dmarch #本地归档文件存放路径
ARCH_FILE_SIZE    = 128 #单位 MB,本地单个归档文件最大值
ARCH_SPACE_LIMIT  = 10240 #单位 MB,0 表示无限制,范围 1024~4294967294 MB

3.4.png

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

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

[dmdba@localhost DAMENG]$ vi /dm/data/DAMENG/dmmal.ini

注意:主备库2个节点文件内容要相同,内容如下:

MAL_CHECK_INTERVAL   = 5
MAL_CONN_FAIL_INTERVAL  = 15
[MAL_INST1]
  MAL_INST_NAME = ZB1
  MAL_HOST     = 192.168.50.134
  MAL_PORT     = 7336
  MAL_INST_HOST   = 192.168.0.15
  MAL_INST_PORT   = 5236
  MAL_DW_PORT   = 7536
  MAL_INST_DW_PORT = 7436
[MAL_INST2]
  MAL_INST_NAME = ZB2
  MAL_HOST      = 192.168.50.137
  MAL_PORT          = 7336
  MAL_INST_HOST         = 192.168.0.25
  MAL_INST_PORT         = 5236
  MAL_DW_PORT  = 7536
  MAL_INST_DW_PORT = 7436

3.5.png

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

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

vi /dm/data/DAMENG/dmwatcher.ini

注意:主备库2个节点文件内容相同(由于实例路径的原因),内容如下:

[GRP_DW]
DW_TYPE    = GLOBAL  #全局守护类型
DW_MODE    = AUTO  #自动切换模式
DW_ERROR_TIME     = 10  #远程守护进程故障认定时间
INST_RECOVER_TIME  = 60  #主库守护进程启动恢复的间隔时间
INST_ERROR_TIME   = 10  #本地实例故障认定时间
INST_OGUID         = 453331  #守护系统唯一 OGUID 值
INST_INI           = /dm/data/DAMENG/dm.ini   #dm.ini 配置文件>路径
INST_AUTO_RESTART  = 1   #打开实例的自动启动功能
INST_STARTUP_CMD   = /dm/bin/dmserverd  #命令行方式启动

3.6.png

2.5.5 修改主备库状态和oguid

主库mount方式后台启动
在PS1上修改/dm/bin/dmserverd中START_MODE为mount

[dmdba@localhost ~]$ cd /dm/bin
[dmdba@localhost bin]$ vi dmserverd

3.7.png

[dmdba@localhost bin]$ ./dmserverd start  #启动主库数据库后台服务
#使用disql工具连接主库
[dmdba@localhost bin]$ ./disql SYSDBA/SYSDBA

#修改oguid
SQL> sp_set_oguid(453331);

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

备库mount方式后台启动
在PS2上修改/dm/bin/dmserverd中START_MODE为mount

[dmdba@localhost ~]$ cd /dm/bin
[dmdba@localhost bin]$ vim dmserverd

3.8.png

[dmdba@localhost bin]$ ./dmserverd start  #启动主库数据库后台服务

#使用disql工具连接备库
[dmdba@localhost bin]$ ./disql SYSDBA/SYSDBA

#修改oguid
SQL> sp_set_oguid(453331);

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

2.5.6 修改后台启动脚本

守护进程后台启动脚本
在PS1和PS2上的目录/dm/bin/service_template拷贝DmWatcherService文件到/ dmdbms/bin目录下,然后修改DmWatcherService中 INI_PATH为PS1和PS2指定守护进程配置文件dmwatcher.ini的路径(比如/dm/data/DAMENG/dmwatcher.ini)。

[dmdba@localhost bin]$ cp /service_template/DmWatcherService DmWatcherService
[dmdba@localhost bin]$ vi DmWatcherService
INI_PATH=/dm/data/DAMENG/dmwatcher.ini

3.9.png
监视器进程后台脚本
在要部署的监视服务器PS2上的/dm/bin/service_template拷贝DmMonitorService到/dm/bin目录下,然后修改DmMonitorService中INI_PATH为监视器配置文件dmmonitor.ini路径(比如/dm/data/DAMENG/dmmonitor.ini).

[dmdba@localhost bin]$ vi /dm/data/DAMENG/dmmonitor.ini
MON_DW_CONFIRM    = 1 #确认监视器模式
MON_LOG_PATH    = /dm/data/DAMENG/log  #监视器日志文件存放路径
MON_LOG_INTERVAL  = 60 #每隔 60 s 定时记录系统信息到日志文件
MON_LOG_FILE_SIZE   = 200 #每个日志文件最大 32 MB
MON_LOG_SPACE_LIMIT  = 1024  #不限定日志文件总占用空间
[GRP_DW]
MON_INST_OGUID    = 453331 #组 GRP_DW 的唯一 OGUID 值
#以下配置为监视器到组 GRP_DW 的守护进程的连接信息,以“IP:PORT”的形式配置
#IP 对应 dmmal.ini 中的 MAL_HOST,PORT 对应 dmmal.ini 中的 MAL_DW_PORT
MON_DW_IP     = 192.168.0.15:7536
MON_DW_IP     = 192.168.0.25:7536

3.10.png

2.6 启动集群

启动守护进程
dmdba 用户切换到数据库安装目录的 bin 下执行以下命令(主备库都执行):

#PS1:
[dmdba@localhost bin]$ ./DmWatcherService start
#PS2:
[dmdba@localhost bin]$ ./DmWatcherService start

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

启动监视器进程
建议配置在第三台独立的服务器上(需安装和主备相同版本的DM数据库软件(不必初始化实例),且与主备心跳网络端口开放),守护进程配置为自动切换时,必须配置确认监视器,本次在PS2上部署监视器。

使用执行以下命令,启动监视器。

#PS2:
[dmdba@localhost bin]$ ./dmmonitor /dm/data/DAMENG/dmmonitor.ini

输入 show 命令查看集群状态:
其中守护进程状态 WSTATUS 为 OPEN,实例状态 ISTATUS 为 OPEN,归档类型 RTYPE 为 TIMELY,归档状态 RSTAT 为VALID。

输入 tip 命令查看系统当前运行状态:
看到实例状态均为OPEN即成功
3.11.png

3 部署过程遇到的问题及解决方法

问题 1: 使用mount命令挂载ISO,ISO文件是write-protected状态,只能以 read-only 模式挂载,挂载后无法赋予 DMInstall.bin 文件执行权限。
3.12.png

解决方法: Linux挂载ISO文件通常是以只读(read-only)状态挂载的,可以读取ISO文件中的内容,但不能向其写入或修改其内容。ISO文件通常是光盘映像文件的格式,如光盘镜像或光盘备份,它们被设计为只读,以确保数据的完整性和一致性。如果需要在Linux上修改ISO文件或将其用于写入操作,先将ISO文件复制到一个可写的位置,然后对其进行操作。所以将安装文件复制到可以执行的本地盘目录中,然后再赋予DMInstall.bin文件执行权限。

问题 2: 安装中提示 TMP 空间不足,无法安装。
3.13.png

解决方法: 通常是因为临时目录(/tmp)的可用空间不足以容纳安装所需的临时文件,指定临时目录,使用 mkdir 命令创建目录,然后使用 export DM_INSTALL_TMPDIR=指定的临时目录。
3.14.png

问题3: 用户如果使用 root 系统用户登录图形化环境,并且使用su命令切换到安装系统用户进行图形化安装,可能导致启动图形化安装程序失败。
3.15.png解决方法: 切换root用户,使用命令xhost + 允许任何用户连接到X Server

问题4: 使用scp命令发送备份文件时失败
3.16.png
解决方法: permission denied错误,通常意味着没有足够的权限来执行所需的操作,所以查看接收端目录的权限,发现创建目录时使用的是root账户,dmdba没有权限进行写入操作。
3.17.png使用chown dmdba:dinstall -R dbbak命令更改dbbak的拥有者为dmdba

问题5: 启动守护进程与监视器在监视器中使用tip命令查看系统运行状态,发现主备数据库没有处于 OPEN 状态
问题思考及解决方式: 使用check open命令查看原因
3.18.png
网上查找报错原因,没有找到,尝试直接从监视器 open主备数据库,备数据库变成分裂状态
3.19.png
查看 dmwatcher.ctl 文件,发现分裂原因是主备数据库魔数不一致。
3.20.png
想起部署的时候,备库还原的时候没有使用主库数据库备份文件,最后选择重新部署主备集群。

评论
后发表回复

作者

文章

阅读量

获赞

扫一扫
联系客服