部署环境
三台机器均安装达梦数据库软件,路径/opt/dmdbms/
- 主机
主库 192.168.20.11/192.168.10.11 主机名 dmwatch1 操作系统 centos6.5 备库 192.168.20.12/192.168.10.12 主机名 dmwatch2 操作系统 centos6.5 监视器 192.168.20.13/192.168.10.13 主机名 dmwatch 操作系统 centos6.5
- 端口
db_name 实例名称 PORT_NUM DW_PORT MAL_HOST MAL_PORT MAL_DW_PORT DMWATCH DMWATCH1 5236 5237 192.168.10.11 5238 5239 DMWATCH DMWATCH2 5236 5237 192.168.10.12 5238 5239
操作部署
- 主库操作
--创建实例
[dmdba@dmwatch1 dmdbms]$ dminit PATH=/opt/dmdbms/data DB_NAME=DMWATCH INSTANCE_NAME=DMWATCH1 PORT_NUM=5236
--注册服务
[dmdba@dmwatch1 dmdbms]# /opt/dmdbms/script/root/dm_service_installer.sh -t dmserver -i /opt/dmdbms/data/DMWATCH/dm.ini -p DMWATCH1
--启动服务
[dmdba@dmwatch1 dmdbms]#service DmServiceDMWATCH1 start
--启动归档
[dmdba@dmwatch1 dmdbms]$ disql SYSDBA/SYSDBA
SQL> alter database mount;
SQL> alter database add archivelog 'DEST=/opt/dmdbms/data/dmwatch1arch_log,TYPE=local,FILE_SIZE=128,space_limit=0';
SQL> alter database archivelog;
SQL> alter database open;
--查询下归档状态
SQL> select arch_mode from v$database;
--切换日志文件
SQL> alter system switch logfile;
SQL> exit
--rman备份需要脱机
[dmdba@dmwatch1 ~]$ service DmServiceDMWATCH1 stop
[dmdba@dmwatch1 ~]$ /opt/dmdbms/bin/dmrman
RMAN> backup database '/opt/dmdbms/data/DMWATCH/dm.ini' full backupset '/opt/soft/dmwatch1_full/dbbak01';
--备份文件拷贝到备库
[dmdba@dmwatch1 dbbak01]$ scp /opt/soft/dmwatch1_full/dbbak01 dmdba@192.168.10.12:/opt/soft/
- 备库操作
--初始化备库
[dmdba@dmwatch2 dmdbms]$ dminit PATH=/opt/dmdbms/data DB_NAME=DMWATCH INSTANCE_NAME=DMWATCH2 PORT_NUM=5236
--注册服务
[dmdba@dmwatch2 dmdbms]# /opt/dmdbms/script/root/dm_service_installer.sh -t dmserver -i /opt/dmdbms/data/DMWATCH/dm.ini -p DMWATCH2
--还原备库
[dmdba@dmwatch2 ~]$ /opt/dmdbms/bin/dmrman CTLSTMT="RESTORE DATABASE '/opt/dmdbms/data/DMWATCH/dm.ini' FROM BACKUPSET '/opt/soft/dbbak01'"
[dmdba@dmwatch2 ~]$ /opt/dmdbms/bin/dmrman CTLSTMT="RECOVER DATABASE '/opt/dmdbms/data/DMWATCH/dm.ini' FROM BACKUPSET '/opt/soft/dbbak01'"
[dmdba@dmwatch2 ~]$ /opt/dmdbms/bin/dmrman CTLSTMT="RECOVER DATABASE '/opt/dmdbms/data/DMWATCH/dm.ini' UPDATE DB_MAGIC"
- 检查主备库一致性(主库、备库操作)
主库、备库mount状态
[dmdba@dmwatch1 ~]$ /opt/dmdbms/bin/dmserver /opt/dmdbms/data/DMWATCH/dm.ini mount
[dmdba@dmwatch2 ~]$ /opt/dmdbms/bin/dmserver /opt/dmdbms/data/DMWATCH/dm.ini mount
启动命令行工具 DIsql,分别登录各个实例查询 LSN 值,如果主库和备库的 FILE_LSN和 CUR_LSN 值相同,可以确保数据完全一致。
SQL>select file_LSN, cur_LSN from v$rlog;
--结果如下;
行号 FILE_LSN CUR_LSN
-------- ------------------ --------------------
1 10250 10250
检查实例的永久魔数是否一致:
SQL>select permanent_magic;
--结果如下;
行号 PERMANENT_MAGIC
---------- ---------------
1385101984
确保 LSN 和永久魔数都一致的情况下,正常关闭各个实例,继续配置数据守护。
- 主库配置文件修改
--dm.ini 修改如下参数
INSTANCE_NAME = DMWATCH1
PORT_NUM = 5236
DW_PORT = 5237
DW_ERROR_TIME = 60
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2
MAL_INI = 1
ARCH_INI = 1
--创建dmmal.ini文件,内容如下
MAL_CHECK_INTERVAL = 5
MAL_CONN_FAIL_INTERVAL = 5
[MAL_INST1]
MAL_INST_NAME = DMWATCH1
MAL_HOST = 192.168.10.11
MAL_PORT = 5238
MAL_INST_HOST = 192.168.20.11
MAL_INST_PORT = 5236
MAL_DW_PORT = 5239
[MAL_INST2]
MAL_INST_NAME = DMWATCH2
MAL_HOST = 192.168.10.12
MAL_PORT = 5238
MAL_INST_HOST = 192.168.20.12
MAL_INST_PORT = 5236
MAL_DW_PORT = 5239
--dmarch.ini 修改成内容如下
[ARCHIVE_TIMELY]
ARCH_TYPE = TIMELY
ARCH_DEST = DMWATCH2
[ARCHIVE_LOCAL1]
ARCH_TYPE = LOCAL
ARCH_DEST = /opt/dmdbms/data/dmwatch1arch_log
ARCH_FILE_SIZE = 128
ARCH_SPACE_LIMIT = 0
--创建dmwatcher.ini文件内容如下
[GRP1]
DW_TYPE = GLOBAL
DW_MODE = AUTO
DW_ERROR_TIME = 10
INST_RECOVER_TIME = 60
INST_ERROR_TIME = 10
INST_OGUID = 453331
INST_INI = /opt/dmdbms/data/DMWATCH/dm.ini
INST_AUTO_RESTART = 1
INST_STARTUP_CMD = /opt/dmdbms/bin/dmserver
RLOG_SEND_THRESHOLD = 0
RLOG_APPLY_THRESHOLD = 0
--创建dmwatcher.ctl文件
在配置完成 dmwatcher.ini 后,使用 dmctlcvt 工具生成 dmwatcher.ctl
$ dmctlcvt TYPE=3 SRC=/opt/dmdbms/data/DMWATCH/dmwatcher.ini DEST=/opt/dmdbms/data/DMWATCH
#默认生成控制文件有个子目录,需要移动到父目录中:
#拷贝生成的 dmwatcher.ctl 文件到数据文件目录/opt/dmdbms/data/DMWATCH
- 备库配置文件修改
--dm.ini 修改如下参数
INSTANCE_NAME = DMWATCH2
PORT_NUM = 5236
DW_PORT = 5237
DW_ERROR_TIME = 60
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2
MAL_INI = 1
ARCH_INI = 1
--创建dmmal.ini文件内容如下
MAL_CHECK_INTERVAL = 5
MAL_CONN_FAIL_INTERVAL = 5
[MAL_INST1]
MAL_INST_NAME = DMWATCH1
MAL_HOST = 192.168.10.11
MAL_PORT = 5238
MAL_INST_HOST = 192.168.20.11
MAL_INST_PORT = 5236
MAL_DW_PORT = 5239
[MAL_INST2]
MAL_INST_NAME = DMWATCH2
MAL_HOST = 192.168.10.12
MAL_PORT = 5238
MAL_INST_HOST = 192.168.20.12
MAL_INST_PORT = 5236
MAL_DW_PORT = 5239
--修改dmarch.ini文件成如下内容
[ARCHIVE_TIMELY]
ARCH_TYPE = TIMELY
ARCH_DEST = DMWATCH1
[ARCHIVE_LOCAL1]
ARCH_TYPE = LOCAL
ARCH_DEST = /opt/dmdbms/data/dmwatch2arch_log
ARCH_FILE_SIZE = 128
ARCH_SPACE_LIMIT = 0
--创建dmwatcher.ini文件内容如下
[GRP1]
DW_TYPE = GLOBAL
DW_MODE = AUTO
DW_ERROR_TIME = 10
INST_RECOVER_TIME = 60
INST_ERROR_TIME = 10
INST_OGUID = 453331
INST_INI = /opt/dmdbms/data/DMWATCH/dm.ini
INST_AUTO_RESTART = 1
INST_STARTUP_CMD = /opt/dmdbms/bin/dmserver
RLOG_SEND_THRESHOLD = 0
RLOG_APPLY_THRESHOLD = 0
--dmwatcher.ctl 从主库拷贝过来存放对应目录中
- 主库设置OGUID
$ dmserver /opt/dmdbms/data/DMWATCH/dm.ini mount
SQL>sp_set_oguid(453331);
--修改数据库模式
SQL>alter database primary;
- 备库设置OGUID
$ dmserver /opt/dmdbms/data/DMWATCH/dm.ini mount
--设置 OGUID
SQL> sp_set_oguid(453331);
--修改数据库模式
--如果是 normal 模式,请忽略下面的第 1 步和第 3 步。
#STEP 1:
SQL> SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);
DMSQL executed successfully
used time: 9.822(ms). Execute id is 2.
#STEP 2:
SQL> alter database standby;
executed successfully
used time: 7.475(ms). Execute id is 0.
#STEP 3:
SQL> SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);
DMSQL executed successfully
used time: 9.070(ms). Execute id is 3.
SQL>
- 监视器操作
--在/opt/dmdbms/data目录下创建 dmmonitor.ini,内容如下
MON_DW_CONFIRM = 1 #确认监视器模式
MON_LOG_PATH = /opt/dmdbms/log #监视器日志文件存放路径
MON_LOG_INTERVAL = 60 #每隔 60s 定时记录系统信息到日志文件
MON_LOG_FILE_SIZE = 32 #每个日志文件最大 32M
MON_LOG_SPACE_LIMIT = 0 #不限定日志文件总占用空间
[GRP1]
MON_INST_OGUID = 453331 #组 GRP1 的唯一 OGUID 值
#以下配置为监视器到组 GRP1 的守护进程的连接信息,以“IP:PORT”的形式配置
#IP 对应 dmmal.ini 中的 MAL_HOST,PORT 对应 dmmal.ini 中的 MAL_DW_PORT
MON_DW_IP = 192.168.10.11:5239
MON_DW_IP = 192.168.10.12:5239
- 注册服务
--备库
[root@dm2 ~]# cd /opt/dmdbms/script/root
[root@dm2 root]# /opt/dmdbms/script/root/dm_service_installer.sh -t dmwatcher -i /opt/dmdbms/data/DMWATCH/dmwatcher.ini -p dm2
--主库
[root@dm1 ~]# cd /opt/dmdbms/script/root
[root@dm1 root]# /opt/dmdbms/script/root/dm_service_installer.sh -t dmwatcher -i /opt/dmdbms/data/DMWATCH/dmwatcher.ini -p dm1
--启动服务
--备库
$ service DmWatcherServicedm2 start
--主库
$ service DmWatcherServicedm1 start
--查看服务
ps -ef|grep watcher
--监视器服务注册
# /opt/dmdbms/script/root/dm_service_installer.sh -t dmmonitor -i /opt/dmdbms/data/dmmonitor.ini -p dmwatch
# service DmMonitorServicedmwatch start
# ps -ef|grep monitor
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




