表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 |
注意:两台服务器都需要安装
[root@localhost /]# groupadd dinstall
[root@localhost /]# useradd -g dinstall dmdba
[root@localhost /]# passwd dmdba
之后通过系统提示进行密码设置
使用ulimit -a命令进行查询
参数使用限制:
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
创建目录/dm
[root@localhost /]# mkdir dm
赋予权限
[root@localhost /]# chown dmdba:dinstall -R dm
挂载光驱
使用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
根据图中选择进行安装
注意:安装完成后要使用root用户执行命令
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
[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
在主机ZB1上执行以下命令,确认主库dmap服务已启动:
ps -ef|grep dmap
若未启动,则先启动 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';
将备份的文件/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;
在ZB1和ZB2上分别修改dm.ini参数值:
vi /dm/data/DAMENG/dm.ini
MAL_INI = 1
ARCH_INI = 1
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2
在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
备机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
在实例目录下新建文件 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
在实例目录下新建文件 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 #命令行方式启动
主库mount方式后台启动
在PS1上修改/dm/bin/dmserverd中START_MODE为mount
[dmdba@localhost ~]$ cd /dm/bin
[dmdba@localhost bin]$ vi dmserverd
[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
[dmdba@localhost bin]$ ./dmserverd start #启动主库数据库后台服务
#使用disql工具连接备库
[dmdba@localhost bin]$ ./disql SYSDBA/SYSDBA
#修改oguid
SQL> sp_set_oguid(453331);
#修改数据库模式为standby
SQL> alter database standby;
守护进程后台启动脚本
在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
监视器进程后台脚本
在要部署的监视服务器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
启动守护进程
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即成功
问题 1: 使用mount命令挂载ISO,ISO文件是write-protected状态,只能以 read-only 模式挂载,挂载后无法赋予 DMInstall.bin 文件执行权限。
解决方法: Linux挂载ISO文件通常是以只读(read-only)状态挂载的,可以读取ISO文件中的内容,但不能向其写入或修改其内容。ISO文件通常是光盘映像文件的格式,如光盘镜像或光盘备份,它们被设计为只读,以确保数据的完整性和一致性。如果需要在Linux上修改ISO文件或将其用于写入操作,先将ISO文件复制到一个可写的位置,然后对其进行操作。所以将安装文件复制到可以执行的本地盘目录中,然后再赋予DMInstall.bin文件执行权限。
问题 2: 安装中提示 TMP 空间不足,无法安装。
解决方法: 通常是因为临时目录(/tmp)的可用空间不足以容纳安装所需的临时文件,指定临时目录,使用 mkdir 命令创建目录,然后使用 export DM_INSTALL_TMPDIR=指定的临时目录。
问题3: 用户如果使用 root 系统用户登录图形化环境,并且使用su命令切换到安装系统用户进行图形化安装,可能导致启动图形化安装程序失败。
解决方法: 切换root用户,使用命令xhost + 允许任何用户连接到X Server
问题4: 使用scp命令发送备份文件时失败
解决方法: permission denied错误,通常意味着没有足够的权限来执行所需的操作,所以查看接收端目录的权限,发现创建目录时使用的是root账户,dmdba没有权限进行写入操作。
使用chown dmdba:dinstall -R dbbak命令更改dbbak的拥有者为dmdba
问题5: 启动守护进程与监视器在监视器中使用tip命令查看系统运行状态,发现主备数据库没有处于 OPEN 状态
问题思考及解决方式: 使用check open命令查看原因
网上查找报错原因,没有找到,尝试直接从监视器 open主备数据库,备数据库变成分裂状态
查看 dmwatcher.ctl 文件,发现分裂原因是主备数据库魔数不一致。
想起部署的时候,备库还原的时候没有使用主库数据库备份文件,最后选择重新部署主备集群。
文章
阅读量
获赞