暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

dm7搭建读写分离

原创 shero 2020-11-05
796

部署环境

三台机器均安装达梦数据库软件,路径/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进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论