我是靠谱客的博主 乐观衬衫,最近开发中收集的这篇文章主要介绍读写分离集群规范化部署以#开头的行表示是注释全局配置区服务配置区,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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

Copy
./dm_service_installer.sh -t dmwatcher -p dmrw -watcher_ini /home/dmdba/dmdbms/dmrw/dmwatcher.ini

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

Copy
./dm_service_installer.sh -t dmserver -p dmrw -dm_ini /home/dmdba/dmdbms/dmrw/dm.ini

注册监视器服务(只需在监视器服务器上执行),执行以下命令:

Copy
./dm_service_installer.sh -t dmmonitor -p confirm -monitor_ini /home/dmdba/dmdbms/dmmonitor.ini

以服务方式启动
启动数据库实例,执行以下命令:
systemctl start DmServicedmrw

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

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

show
3. status
打印守护进程状态信息,各字段含义说明如下:
GROUP_NAME:守护进程组名。
DW_STATUS:守护进程状态。
DW_SUB_STATUS:守护进程子状态。
显示所有守护进程组中的本地库信息,不显示远程库信息。

  1. show
    显示所有守护进程组中的本地库信息,不显示远程库信息。
    各字段含义说明如下
    各字段含义说明如下:
  1. 组全局字段信息
    GROUP_NAME:守护进程组名。
    TYPE:配置的守护类型。
    MODE:配置的切换模式,AUTO 表示故障自动切换模式,MANUAL 表示故障手动切换模
    式。
    OGUID:守护进程组配置的唯一 OGUID 值。
    MPP_FLAG:当前是否为 MPP 主备环境,值为 TRUE 或 FALSE。
    AUTO_RESTART:守护进程是否配置有自动拉起,值为 TRUE 或 FALSE。
    DW_STATUS:守护进程状态。
    DW_SUB_STATUS:守护进程子状态。
    DW_CTL_STATUS:守护进程控制文件状态。
  2. 各节点实例字段信息
    INST_OK:守护进程认定的节点实例状态,Ok 或 Error。
    NAME:节点实例名称。
    SVR_MODE:节点实例模式,包括 Normal/Primary/Standby 这三种模式。
    SYS_STATUS : 节 点 实 例 状 态 , 包 括 Startup/After
    Redo/Mount/Open/Suspend/ Shutdown 这几种状态。
    RTYPE:节点实例配置的归档类型,只统计 REALTIME/TIMELY 这两种归档类型,如
    果这两种归档都没有配置,则显示为 NONE。
    FSEQ:节点实例已经写入联机日志的 RLOG_PKG 包序号。
    FLSN:节点实例的文件 LSN,指已经写入联机日志文件的最大 LSN 值。
    CSEQ:节点实例的系统当前 PKG_SEQNO,指当前数据库最新产生的 RLOG_PKG 包的
    序号。
    CLSN:节点实例的系统当前 LSN,指当前数据库最新产生的 LSN 值。
    DW_STAT_FLAG:节点当前的执行标记。
    如果是备库模式,show 命令还会显示备库控制节点当前的重演信息,重演信息的行数
    和产生日志的主库节点个数一致,可以查看备库对主库不同节点日志的重演情况。
    DSC_SEQNO:主库节点序号,如果主库是单节点,则序号为 0。
    SSEQ:备库可重演到的最大日志包序号。
    SLSN:备库可重演到的最大 LSN,对应日志包序号为 STDBY_PKG_SEQNO。 KSEQ:非自动切换模式下,备库保持不重演的日志包序号。
    KLSN:非自动切换模式下,备库保持不重演最大 LSN,对应的日志包序号为 KSEQ。
    ASEQ:备库针对主库此节点已经重演到的日志包序号。
    ALSN:备库针对主库此节点已经重演到的 LSN 值,对应的日志包序号为 ASEQ。
    N_TSK:备库针对主库此节点的待重演任务个数。
    TSK_MEM_USE:备库当前针对主库此节点的日志重演已经占用的内存大小(单位:字
    节)。
  1. show group group_name
    显示所有守护进程组中的本地库信息,不显示远程库信息。各字段含义同 show 命令。
  2. show version
    显示守护进程自身版本号。
    守护进程版本信息格式为“DMWATCHER[数据守护版本号] 全局版本号”,例如:
    “DMWATCHER[4.0] V8”。
    同一套数据守护系统中,服务器、守护进程和监视器要求中括号内的数据守护版本号必
    须一致,否则不允许建立 TCP 连接,各自的控制台工具上和 log 日志中都会记录版本不匹
    配报错信息。
  3. show monitor config
    此命令为辅助用户配置 dmmonitor.ini 使用。
    守护进程根据自己的组名、oguid、ip/port 等配置信息,生成一份 dmmonitor.ini
    配置文件供用户参考使用。
    此命令只会显示包含在守护进程守护的本地实例归档配置文件中的实例对应的守护进
    程信息,比如本地实例配置的实时归档、即时归档、异步归档的目标实例所在守护进程信息,
    对于未配置的目标实例守护进程信息则不会显示,比如其他实例上配置的异步备库守护进程
    信息不能显示。因此对监视器来说,单个守护进程上的显示结果配置信息可能是不完整的。
    只做配置参考使用,可以借助多个守护进程的显示结果,综合起来进行配置。
  4. show link
    此命令为辅助用户查看本地守护进程和本地各节点实例、远程守护进程、dmcss、监视
    器的 TCP 连接状态使用。
    此命令只显示当前连接正常的链路信息,如果连接已经断开,则不会被显示出来。
    各字段含义说明如下:
    FROM_FLAG:和本地守护进程建立 tcp 连接的对方程序名称,dmserver、dmcss、
    dmwatcher 或者 dmmonitor。
    FROM_INAME:和本地守护进程建立 TCP 连接的对方实例名或者 css 名称。
    HANDLE:TCP 连接句柄。
    MID:只对监视器有效,监视器唯一标识 ID。
    N_FIX:TCP 连接句柄当前被使用个数。
    MON_ADDR:连接对方 IP 地址。
    MON_CONFIRM:只对监视器有效,标识是否为确认监视器。
    CONN_TIME:TCP 连接建立时间。
  1. 组全局字段信息
    GROUP:守护进程组名。
    OGUID:守护进程组配置的唯一 OGUID 值。
    MON_CONFIRM:监视器是否配置为确认模式,值为 TRUE 或 FALSE。
    MODE:当前配置的切换模式,AUTO 表示故障自动切换模式,MANUAL 表示故障手动切
    换模式。
    MPP_FLAG:当前是否为 MPP 主备环境,值为 TRUE 或 FALSE。
  2. 库全局字段信息
    守护进程和监视器是以库为单位进行管理的,对有多个节点的 DMDSC 集群,看作是一
    个完整的库,以下信息属于库的全局信息,部分守护进程相关的信息直接取自控制守护进程。
    IP:守护进程的 IP 地址,取自控制守护进程。
    MAL_DW_PORT:守护进程的监听端口,取自控制守护进程。
    WTIME:守护进程本地的当前时间,取自控制守护进程。
    WTYPE:守护进程配置的守护类型,包括 LOCAL/GLOBAL 两种类型,取自控制守护进
    程。
    WCTLSTAT:守护进程控制文件状态,包括 Valid/Split/Invalid 三种状态,对于
    配置为本地守护类型的实例,由于不需要有守护进程控制文件,该字段值为 NULL。
    WSTATUS:守护进程状态,取自控制守护进程。
    INAME:库名称,取自控制节点实例名。
    N_EP:库的节点个数。
    N_OK:此字段对 DMDSC 集群内的节点有效,表示 DMDSC 集群内 OK 节点个数。
    ISTATUS:数据库状态,包括 Startup/After Redo/Mount/Open/Suspend/
    Shutdown 这几种状态,由控制守护进程综合当前所有节点实例的状态得出。
    IMODE:数据库模式,包括 Unknown/Normal/Primary/Standby 这四种模式,由
    控制守护进程综合当前所有节点实例的模式得出。
    RTYPE:数据库配置的归档类型,只统计 REALTIME/TIMELY 这两种归档类型,如果
    这两种归档都没有配置,则显示为 NONE。
    RSTAT : 此 字 段 对 备 库 有 效 , 表 示 主 库 到 备 库 的 归 档 状 态 , 可 能 为
    Valid/Invalid/Unknown,对于本地守护类型的备库,此字段为 NULL,对于主库本身,
    此字段值为 Valid。该字段值要从备库对应的主库实例上取,如果当前没有活动主库或者
    备库无法确认对应的主库,则该字段显示为 Unknown。
  1. show database [group_name.]db_name
    此命令用于详细显示指定库的相关状态信息。
    各字段含义说明如下:
  1. 库全局字段信息
    和 show global info 命令中的库全局字段含义相同。
  2. 各节点实例字段信息
    INST_PORT:节点实例的监听端口。
    INST_OK:控制守护进程认定的节点实例状态,OK 或 ERROR。
    INAME:节点实例名称。
    ISTATUS:节点实例状态,包括 Startup/After Redo/Mount/Open/Suspend/
    Shutdown 这几种状态。
    IMODE:节点实例模式,包括 Normal/Primary/Standby 这三种模式。
    DSC_STATUS:此字段对单节点可忽略,只对 DMDSC 集群内的节点有意义,表示节点
    当前的 DMDSC 集群状态。
    DSC_SEQNO:此字段对单节点可忽略,只对 DMDSC 集群内的节点有意义,表示节点在
    DMDSC 集群内的序号。
    DSC_CONTROL_NODE:此字段对单节点可忽略,只对 DMDSC 集群内的节点有意义,
    表示 DMDSC 集群内控制节点的序号。
    RTYPE:节点实例配置的归档类型,只统计 REALTIME/TIMELY 这两种归档类型,如
    果这两种归档都没有配置,则显示为 NONE。
    RSTAT:此字段对备库控制节点有效,表示主库到备库控制节点的归档状态,可能为
    Valid/Invalid/Unknown,对于本地守护类型的备库,此字段为 NULL,对于主库本身,
    此字段值为 Valid。该字段值要从备库对应的主库实例上取,如果当前没有活动主库或者
    备库无法确认对应的主库,则该字段显示为 Unknown。
    FSEQ:节点实例已经写入联机日志的 RLOG_PKG 包序号。
    FLSN:节点实例的文件 LSN,指已经写入联机日志文件的最大 LSN 值。
    CSEQ:节点实例的系统当前 PKG_SEQNO,指当前数据库最新产生的 RLOG_PKG 包的
    序号。
    CLSN:节点实例的系统当前 LSN,指当前数据库最新产生的 LSN 值。
    DW_STAT_FLAG:节点当前的执行标记。
    如果是备库模式,show 命令还会显示备库控制节点当前的重演信息,重演信息的行数
    和产生日志的主库节点个数一致,可以查看备库对主库不同节点日志的重演情况。
    DSC_SEQNO:主库节点序号。
    SSEQ:备库可重演到的最大日志包序号。
    SLSN:备库可重演到的最大 LSN,对应日志包序号为 STDBY_PKG_SEQNO。 KSEQ:非自动切换模式下,备库保持不重演的日志包序号。
    KLSN:非自动切换模式下,备库保持不重演最大 LSN,对应的日志包序号为 KSEQ。 ASEQ:备库针对主库此节点已经重演到的日志包序号。
    ALSN:备库针对主库此节点已经重演到的 LSN 值,对应的日志包序号为 ASEQ。
    N_TSK:备库针对主库此节点的待重演任务个数。
    TSK_MEM_USE:备库当前针对主库此节点的日志重演已经占用的内存大小(单位:字 节)。
  1. show [group_name]
    如果指定 group_name,则显示指定组中所有库的详细状态信息,如果没有指定,则
    显示所有组中所有库的详细状态信息。
    show 命令由下面几种信息组成:
  1. 组全局字段信息
  2. 库全局字段信息
  3. 各节点实例字段信息
    也就是 show global info 和 show database 命令的整合,各字段含义可参考这
    两个命令中的含义说明。
  1. show i[nterval] n
    在 dmmonitor 工具界面上定时每隔 n 秒自动显示所有组中所有库的详细状态信息,相
    当于每隔 n 秒自动执行一次 show 命令,n 取值范围为 5~3600(s),相关字段含义可参考
    show [group_name] 命令说明。
    如果在工具界面上手动执行其他命令,则会自动取消定时显示功能。

本章节主要介绍在生产环境中(Linux 系统)规范化部署读写分离集群。

服务器硬件需求
按实际业务需求,选择合适的服务器,准备 3 台服务器,一台主库服务器,一台备库服务器,一台监视器服务器,服务器参数建议如下:

硬件 要求
物理内存 >=16 GB
交换区 Swap 空间>=物理内存
/tmp大小 > 1000 MB
网络 物理机器需要 4 个网卡,2 个 public 网卡做 band,2 个 private 网卡做 band
磁盘 根据实际应用系统需要挂载合适大小磁盘
时间服务器 按机房要求配置连接时间服务器
警告
守护进程配置自动切换时,必须在监视器服务器上配置确认监视器,并且保证网络高可用。

操作系统要求
操作系统版本安装
DM 数据库安装在 Linux 操作系统所需条件:glibc 2.3 以上,内核 2.6,预先安装 UnixODBC,系统性能监控等组件。

目录与存储规划
用途 目录路径 备注
数据库软件安装目录 /home/dmdba/dmdbms 可用空间>50 GB
实例安装目录 /dmdata 单独挂载性能最好的磁盘建议 SSD
归档日志存放目录 /dmarch 单独挂载磁盘
备份文件存放目录 /dmbak 单独挂载磁盘
用户与组
DM 数据库不应该使用 root 用户安装和维护。需要在安装之前为 DM 数据库创建一个专用的系统用户 (dmdba) 和用户组 (dinstall)。

执行以下命令,新建用户组 dinstall。

Copy
groupadd dinstall

执行以下命令,新建用户 dmdba。

Copy
useradd -g dinstall -m -d /home/dmdba -s /bin/bash dmdba

执行以下命令,修改 dmdba 用户密码。

Copy
passwd dmdba

输入密码并确认。

用户资源限制
执行以下命令,修改 dmdba 用户资源限制。

Copy
vim /etc/security/limits.conf

文件末尾添加如下内容:

Copy
dmdba soft core unlimited
dmdba hard core unlimited
dmdba soft nofile 65536
dmdba hard nofile 65536
dmdba soft nproc 65536
dmdba hard nproc 65536
dmdba soft stack 65536
dmdba hard stack 65536

用户环境变量
执行以下命令,修改 dmdba 用户环境变量。

Copy
vi /home/dmdba/.bash_profile

文件末尾添加如下内容:

Copy
export DM_HOME=/home/dmdba/dmdbms
export PATH= P A T H : PATH: PATH:DM_HOME/bin
export LD_LIBRARY_PATH= L D L I B R A R Y P A T H : LD_LIBRARY_PATH: LDLIBRARYPATH:DM_HOME/bin

防火墙设置
端口规划
搭建 2 节点主备集群,端口规划如下:(实际中可以按需要修改端口号)

主机名 public ip private ip 实例名 端口 用途
dmdsc1 192.168.56.11 10.0.0.11 dmrw1 5236 数据库实例 dmrw1 监听端口
dmdsc1 192.168.56.11 10.0.0.11 dmrw1 61141 MAL 系统监听 TCP 连接的端口
dmdsc1 192.168.56.11 10.0.0.11 dmrw1 52141 实例本地的守护进程监听 TCP 连接的端口
dmdsc1 192.168.56.11 10.0.0.11 dmrw1 33141 实例监听守护进程 TCP 连接的端口
dmdsc2 192.168.56.12 10.0.0.12 dmrw2 5236 数据库实例 dmrw2 监听端口
dmdsc2 192.168.56.12 10.0.0.12 dmrw2 61141 MAL 系统监听 TCP 连接的端口
dmdsc2 192.168.56.12 10.0.0.12 dmrw2 52141 实例本地的守护进程监听 TCP 连接的端口
dmdsc2 192.168.56.12 10.0.0.12 dmrw2 33141 实例监听守护进程 TCP 连接的端口
防火墙集群之间需开放以上所有端口,集群对客户端只需要开通数据库实例监听端口。

安装数据库
数据库软件安装参考单机规范化部署

软件安装目录为/home/dmdba/dmdbms,实例初始化目录/home/dmdba/dmdbms/dmrw,初始化脚本如下:

Copy
./dminit path=/home/dmdba/dmdbms db_name=dmrw page_size=32

注意
初始化的实例必须先启动一次,才能脱机备份。

主库脱机备份
执行以下命令,确认主库 dmap 服务已启动。

Copy
ps -ef|grep dmap

dmap服务

若未启动,则先启动 dmap 服务,dmdba 到安装目录的 bin 下执行以下命令。

Copy
./DmAPService start

关闭数据库后,使用 dmrman 工具脱机备份主库,dmdba 用户到安装目录的 bin 下执行以下命令。

Copy
./dmrman

执行 backup 全库。

Copy
backup database ‘/home/dmdba/dmdbms/dmrw/dm.ini’ backupset ‘/home/dmdba/bakfull’;

backup全库

备库还原
拷贝主库备份到备库合适目录。

Copy
scp -r /home/dmdba/bakfull 192.168.56.12:/home/dmdba

scp备份文件

关闭数据库后,使用 dmrman 工具还原备库,dmdba 用户到安装目录的 bin 下执行。

Copy
./dmrman

执行 restore。

Copy
restore database ‘/home/dmdba/dmdbms/dmrw/dm.ini’ from backupset ‘/home/dmdba/bakfull’;

scp备份文件

执行 recover。

Copy
recover database ‘/home/dmdba/dmdbms/dmrw/dm.ini’ from backupset ‘/home/dmdba/bakfull’;

scp备份文件

执行 recover update db_magic。

Copy
recover database ‘/home/dmdba/dmdbms/dmrw/dm.ini’ update db_magic;

scp备份文件

配置实例的配置文件 dm.ini
修改实例的 dm.ini 文件参数,执行以下命令。

Copy
vi /home/dmdba/dmdbms/dmrw/dm.ini

主库修改以下参数值:

Copy
INSTANCE_NAME = dmrw1
MAL_INI = 1
ARCH_INI = 1
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2

备库修改以下参数值:

Copy
INSTANCE_NAME = dmrw2
MAL_INI = 1
ARCH_INI = 1
ALTER_MODE_STATUS = 0
ENABLE_OFFLINE_TS = 2

配置归档配置文件 dmarch.ini
在实例目录下新建文件 dmarch.ini,执行以下命令。

Copy
vi /home/dmdba/dmdbms/dmrw/dmarch.ini

主库添加以下内容:

Copy
[ARCHIVE_TIMELYE]
ARCH_TYPE = TIMELY #即时归档类型
ARCH_DEST = dmrw2 #即时归档目标实例名(主库侧填写备库实例名)
[ARCHIVE_LOCAL1]
ARCH_TYPE = LOCAL #本地归档类型
ARCH_DEST = /home/dmdba/dmdbms/arch #本地归档文件存放路径
ARCH_FILE_SIZE = 128 #单位 Mb,本地单个归档文件最大值
ARCH_SPACE_LIMIT = 10240 #单位 Mb,0 表示无限制,范围 1024~4294967294M

备库添加以下内容:

Copy
[ARCHIVE_TIMELY]
ARCH_TYPE = TIMELY #即时归档类型
ARCH_DEST = dmrw1 #即时归档目标实例名(备库侧填写主库实例名)
[ARCHIVE_LOCAL1]
ARCH_TYPE = LOCAL #本地归档类型
ARCH_DEST = /home/dmdba/dmdbms/arch #本地归档文件存放路径
ARCH_FILE_SIZE = 128 #单位 Mb,本地单个归档文件最大值
ARCH_SPACE_LIMIT = 10240 #单位 Mb,0 表示无限制,范围 1024~4294967294M

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

Copy
vi /home/dmdba/dmdbms/dmrw/dmmal.ini

主备库文件内容要相同。

Copy
MAL_CHECK_INTERVAL = 5 #MAL 链路检测时间间隔
MAL_CONN_FAIL_INTERVAL = 5 #判定 MAL 链路断开的时间
[MAL_INST1]
MAL_INST_NAME = dmrw1 #与dm.ini 中的 INSTANCE_NAME 一致
MAL_HOST = 10.0.0.11 #MAL 系统监听 TCP 内部网络 IP
MAL_PORT = 61141 #MAL 系统监听 TCP 连接的端口
MAL_INST_HOST = 192.168.56.11 #实例的对外服务 IP 地址
MAL_INST_PORT = 5236 #与 dm.ini 中的 PORT_NUM 一致
MAL_DW_PORT = 52141 #实例对应的守护进程监听 TCP端口
MAL_INST_DW_PORT = 33141
[MAL_INST2]
MAL_INST_NAME = dmrw2 #与dm.ini 中的 INSTANCE_NAME 一致
MAL_HOST = 10.0.0.12 # MAL 系统监听 TCP 内部网络 IP
MAL_PORT = 61141 #MAL 系统监听 TCP 连接的端口
MAL_INST_HOST = 192.168.56.12 #实例的对外服务 IP 地址
MAL_INST_PORT = 5236 #与dm.ini 中的 PORT_NUM 一致
MAL_DW_PORT = 52141 #实例对应的守护进程监听 TCP端口
MAL_INST_DW_PORT = 33141

配置守护进程配置文件 dmwatcher.ini
在实例目录下新建文件 dmwatcher.ini,执行以下命令。

Copy
vi /home/dmdba/dmdbms/dmrw/dmwatcher.ini

主备库文件内容要相同。

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

以 Mount 方式启动数据库实例
使用 dmdba 用户,到数据库安装目录的 bin 下执行以下命令。(主备库都执行)

Copy
./dmserver /home/dmdba/dmdbms/dmrw/dm.ini mount

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

Copy
./disql SYSDBA/SYSDBA

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

Copy
sp_set_oguid(453331);

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

Copy
alter database primary;

备库修改数据库模式为 standby,执行以下命令。

Copy
alter database standby;

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

Copy
./dmwatcher /home/dmdba/dmdbms/dmrw/dmwatcher.ini

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

启动确认监视器
守护进程配置为自动切换时,必须配置确认监视器。在主备服务器以外的服务器上(需安装有 DM 数据库软件,且与主备心跳网络端口开放)。

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

Copy
vi /home/dmdba/dmdbms/dmmonitor.ini

添加以下内容:

Copy
MON_DW_CONFIRM = 1 #确认监视器模式
MON_LOG_PATH = /home/dmdba/dmdbms/log #监视器日志文件存放路径
MON_LOG_INTERVAL = 60 #每隔 60s 定时记录系统信息到日志文件
MON_LOG_FILE_SIZE = 32 #每个日志文件最大 32MB
MON_LOG_SPACE_LIMIT = 0 #不限定日志文件总占用空间
[GRP_RW]
MON_INST_OGUID = 453331 #组 GRP_RW 的唯一 OGUID 值
#以下配置为监视器到组 GRP_RW 的守护进程的连接信息,以“IP:PORT”的形式配置
#IP 对应 dmmal.ini 中的 MAL_HOST,PORT 对应 dmmal.ini 中的 MAL_DW_PORT
MON_DW_IP = 10.0.0.11:52141
MON_DW_IP = 10.0.0.12:52141

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

Copy
./dmmonitor /home/dmdba/dmdbms/dmmonitor.ini

启动后输入 show 命令查看集群状态。

show查看

注册服务
以上启动为前台方式启动,仅用户搭建过程中验证配置。配置没问题后需要将实例,守护进程和确认监视器注册为系统服务。

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

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

Copy
./dm_service_installer.sh -t dmwatcher -p dmrw -watcher_ini /home/dmdba/dmdbms/dmrw/dmwatcher.ini

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

Copy
./dm_service_installer.sh -t dmserver -p dmrw -dm_ini /home/dmdba/dmdbms/dmrw/dm.ini

注册监视器服务(只需在监视器服务器上执行)。

Copy
./dm_service_installer.sh -t dmmonitor -p confirm -monitor_ini /home/dmdba/dmdbms/dmmonitor.ini

以服务方式启动
执行以下命令,启动数据库实例。

Copy
systemctl start DmServicedmrw

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

Copy
systemctl start DmWatcherServicedmrw

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

Copy
systemctl start DmMonitorServiceconfirm

验证主备集群同步状态
监视器查看读写分离集群状态
集群任意节点,配置普通监视器配置文件 dmmonitor.ini,执行以下命令,

Copy
vi /home/dmdba/dmmonitor.ini

添加以下内容:

Copy
MON_DW_Confirm = 0 #普通监视器模式
MON_LOG_PATH = /home/dmdba/dmdbms/log #监视器日志文件存放路径
MON_LOG_INTERVAL = 60 #每隔 60s 定时记录系统信息到日志文件
MON_LOG_FILE_SIZE = 32 #每个日志文件最大 32MB
MON_LOG_SPACE_LIMIT = 0 #不限定日志文件总占用空间
[GRP_RW]
MON_INST_OGUID = 453331 #组 GRP_RW 的唯一 OGUID 值
#以下配置为监视器到组 GRP_RW 的守护进程的连接信息,以“IP:PORT”的形式配置
#IP 对应 dmmal.ini 中的 MAL_HOST,PORT 对应 dmmal.ini 中的 MAL_DW_PORT
MON_DW_IP = 10.0.0.11:52141
MON_DW_IP = 10.0.0.12:52141

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

Copy
./dmmonitor /home/dmdba/dmmonitor.ini

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

show查看

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

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

Copy
./disql SYSDBA/SYSDBA@192.168.56.11:5236

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

Copy
create table test(id int);
insert into test values (1);
commit;

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

Copy
./disql SYSDBA/SYSDBA@192.168.56.12:5236

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

Copy
select * from test;

查询结果正确

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

重启集群
读写分离集群重启与主备相同:

关闭监视器:systemctl stop DmMonitorServiceconfirm
关闭主库守护进程:systemctl stop DmWatcherServicedmrw
关闭备库守护进程:systemctl stop DmWatcherServicedmrw
关闭主库实例:systemctl stop DmServicedmrw
关闭备库实例:systemctl stop DmServicedmrw
启动主库实例:systemctl start DmServicedmrw
启动备库实例:systemctl start DmServicedmrw
启动主库守护进程:systemctl start DmWatcherServicedmrw
启动备库守护进程:systemctl start DmWatcherServicedmrw
启动监视器:systemctl start DmMonitorServiceconfirm
定制备份策略
备份与单机相同,详见定制备份策略部分。

客户端连接集群
客户端主机上需要配置 dm_svc.conf 文件(未安装 DM 数据库的机器新建即可),文件路径:

32 位的 DM 安装在 Win32 操作平台下,此文件位于 %SystemRoot%system32 目录;
64 位的 DM 安装在 Win64 操作平台下,此文件位于 %SystemRoot%system32 目录;
32 位的 DM 安装在 Win64 操作平台下,此文件位于 %SystemRoot%SysWOW64 目录;
在 Linux 平台下,此文件位于/etc 目录。
文件内容:

Copy

以#开头的行表示是注释

全局配置区

DMRW=(192.168.56.11:5236,192.168.56.12:5236)
TIME_ZONE=(+480) #表示+8:00 时区
LOGIN_ENCRYPT=(0)
DIRECT=(Y)

服务配置区

[DMRW]
TIME_ZONE=(+540) #表示+9:00 时区
LOGIN_MODE=(2)
SWITCH_TIME=(3) #在服务器之间切换的次数
SWITCH_INTERVAL=(10) #在服务器之间切换的时间间隔,单位为毫秒
RW_SEPARATE=(0) #是否启用读写分离
RW_PERCENT=(25) #读写分离分发比例

客户端程序连接数据库时,需要指定 ip 端口处替换为服务名即可,例如:

disql SYSDBA/SYSDBA@DMRW

注意
当修改了 dm_svc.conf 内容后,需要重启客户端程序,修改的配置才能生效。

最后

以上就是乐观衬衫为你收集整理的读写分离集群规范化部署以#开头的行表示是注释全局配置区服务配置区的全部内容,希望文章能够帮你解决读写分离集群规范化部署以#开头的行表示是注释全局配置区服务配置区所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(75)

评论列表共有 0 条评论

立即
投稿
返回
顶部