zoukankan      html  css  js  c++  java
  • 达梦数据库-Linux下命令行规范化安装 DM8 读写分离集群

    Linux下命令行规范化安装 DM8 读写分离集群

     

    主机

    安装用户

    软件安装目录

    实例目录

    端口

    归档目录

    192.168.157.129

    dmdba

    /home/dmdba/dmdbms

    /dm8/data

    5236

    /dmarch

    192.168.157.130

    dmdba

    /home/dmdba/dmdbms

    /dm8/data

    5236

    /dmarch

    1、

    # groupadd dinstall

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

    #passwd dmdba

    2、

    # vim /etc/security/limits.conf

    末尾添加

    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

    3、

    # vim /home/dmdba/.bash_profile

    末尾添加

    export DM_HOME=/home/dmdba/dmdbms

    export PATH=$PATH:$DM_HOME/bin:$DM_HOME/tool

    export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$DM_HOME/bin

    # su - dmdba

    $ source  .bash_profile

    4、

    上传安装包并挂载

    # mount -o loop dm8_20210513_x86_rh6_64_ent_8.1.2.2_pack5.iso /mnt

    5、

    # cd /mnt && su dmdba

    $ ./DMInstall.bin -i

    # 根据交互提示选择 并回车

    # 根据提示 root 执行脚本 ,创建dm软件系统服务并启动dm数据库服务

    # /home/dmdba/dmdbms/script/root/root_installer.sh

    6、

    安装数据库服务

    # su dmdba

    $ cd /home/dmdba/dmdbms/bin

    # 初始化实例可以根据情况指定参数

    $  dminit PATH=/dm8/data DB_NAME=DMRW INSTANCE_NAME=DMSERVER PORT_NUM=5236 PAGE_SIZE=32

    7、

    注册实例服务 

    # cd /home/dmdba/dmdbms/script/root  #root 用户

    #  ./dm_service_installer.sh -t dmserver -p dmserver -dm_ini /dm8/data/DMRW/dm.ini

    8、

    启停实例

    systemctl start DmServicedmserver

    systemctl stop DmServicedmserver

    9、主库配置脱机备份

    确认 dmap 已经运行

    ps -ef|grep dmap

    关闭数据库

    systemctl stop DmServicedmserver

    10、

    切换到主库dmdba用户下执行备份

    $ cd /home/dmdba/dmdbms/bin

    $ ./dmrman

    RMAN> backup database '/dm8/data/DMRW/dm.ini' backupset '/home/dmdba/bakfull';

        

    11、

    scp 备份文件到 备库 

    $ scp -r /home/dmdba/bakfull dmdba@192.168.157.130:/home/dmdba

    12、

    备库上 dmdba 用户执行恢复

    先关闭数据库实例服务

    # systemctl stop DmServicedmserver

    $ cd  /home/dmdba/dmdbms/bin

    执行 restore

    $ ./dmrman

    RMAN>  restore database '/dm8/data/DMRW/dm.ini' from backupset '/home/dmdba/bakfull';

    执行 recover

    RMAN>  recover database '/dm8/data/DMRW/dm.ini' from backupset '/home/dmdba/bakfull';

    执行 recover update db_magic

    recover database '/dm8/data/DMRW/dm.ini' update db_magic;

    13 、

    修改配置主备实例的配置文件 dm.ini

    $ vim /dm8/data/DMRW/dm.ini

    主库修改以下参数值:

    INSTANCE_NAME = dmrw1

    MAL_INI = 1

    ARCH_INI = 1

    ALTER_MODE_STATUS = 0

    ENABLE_OFFLINE_TS = 2

    备库修改以下参数值:

    INSTANCE_NAME = dmrw2

    MAL_INI = 1

    ARCH_INI = 1

    ALTER_MODE_STATUS = 0

    ENABLE_OFFLINE_TS = 2

    14、

    配置归档文件 dmarch.ini

    $ vim /dm8/data/DMRW/dmarch.ini

    主库添加以下内容:

    [ARCHIVE_REALTIME]

    ARCH_TYPE     = REALTIME  #实时归档类型

    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~4294967294 MB

    备库添加以下内容:

    [ARCHIVE_REALTIME]

    ARCH_TYPE     = REALTIME  #实时归档类型

    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~4294967294 MB

    15、

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

    $ vim /dm8/data/DMRW/dmmal.ini

    主备库文件内容要相同

    MAL_CHECK_INTERVAL   = 5  #MAL 链路检测时间间隔

    MAL_CONN_FAIL_INTERVAL  = 5  #判定 MAL 链路断开的时间

    [MAL_INST1]

      MAL_INST_NAME = dmrw1 #与 dm.ini 中的 INSTANCE_NAME 一致

      MAL_HOST     = 192.168.157.129  #MAL 系统监听 TCP 内部网络 IP

      MAL_PORT     = 61141 #MAL 系统监听 TCP 连接的端口

      MAL_INST_HOST   = 192.168.157.129  #实例的对外服务 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      = 192.168.157.130  # MAL 系统监听 TCP 内部网络 IP

      MAL_PORT          = 61141 #MAL 系统监听 TCP 连接的端口

      MAL_INST_HOST         = 192.168.157.130  #实例的对外服务 IP 地址

      MAL_INST_PORT         = 5236 #与 dm.ini 中的 PORT_NUM 一致

      MAL_DW_PORT  = 52141 #实例对应的守护进程监听 TCP 端口

      MAL_INST_DW_PORT = 33141

    16、

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

    $ vim /dm8/data/DMRW/dmwatcher.ini

    主备库文件内容要相同

    [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           = /dm8/data/DMRW/dm.ini #dm.ini 配置文件路径

    INST_AUTO_RESTART  = 1   #打开实例的自动启动功能

    INST_STARTUP_CMD   = /home/dmdba/dmdbms/bin/dmserver #命令行方式启动

    17、

    使用 dmdba 用户,到数据库安装目录的 bin 下执行(主备库都执行)

    $ cd /home/dmdba/dmdbms/bin

    $ ./dmserver /dm8/data/DMRW/dm.ini mount

    在新的终端使用 disql 工具连接数据库,执行以下命令:

    ./disql SYSDBA/SYSDBA

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

    sp_set_oguid(453331);

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

    alter database primary;

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

    alter database standby;

    主库:

    备库:

    18、

    启动守护进程

    dmdba 用户下,到数据库安装目录的 bin 下执行(主备库都执行)

    $ cd /home/dmdba/dmdbms/bin

    $ ./dmwatcher /dm8/data/DMRW/dmwatcher.ini

    19、

    启动确认监视器

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

    $ vim /dm8/data/DMRW/dmmonitor.ini

    MON_DW_CONFIRM    = 1   #确认监视器模式

    MON_LOG_PATH    = /home/dmdba/dmdbms/log #监视器日志文件存放路径

    MON_LOG_INTERVAL  = 60 #每隔 60 s 定时记录系统信息到日志文件

    MON_LOG_FILE_SIZE   = 32 #每个日志文件最大 32 MB

    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     = 192.168.157.129:52141

    MON_DW_IP     = 192.168.157.130:52141

    20、启动监听器

    $ cd /home/dmdba/dmdbms/bin

    $ ./dmmonitor /dm8/data/DMRW/dmmonitor.ini

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

    21、

    注册服务

    以上启动为前台方式启动,仅用户搭建过程中验证配置。配置没问题后需要将实例,守护进程和确认监视器注册为系统服务。使用 root 用户,到数据库安装目录的 script/root 下,执行

    # su root

    # cd /home/dmdba/dmdbms/script/root

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

    # ./dm_service_installer.sh -t dmwatcher -p dmrw -watcher_ini /dm8/data/DMRW/dmwatcher.ini

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

    # ./dm_service_installer.sh -t dmserver -p dmrw -dm_ini /dm8/data/DMRW/dm.ini

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

    # ./dm_service_installer.sh -t dmmonitor -p confirm -monitor_ini /dm8/data/DMRW/dmmonitor.ini

    22、

    以服务方式启动

    启动数据库实例,执行以下命令:

    systemctl start DmServicedmrw

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

    systemctl start DmWatcherServicedmrw

    启动监视器(监视器服务器上执行),执行以下命令:

    systemctl start DmMonitorServiceconfirm

    23 、

    验证主备集群同步状态

    参考第20 步即可。

    24、

    disql 客户端验证

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

    ./disql SYSDBA/SYSDBA@192.168.157.129:5236

    2、SQL 提示符下执行以下命令:

    create table test(id int);

    insert into test values (1);

    commit;

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

    ./disql SYSDBA/SYSDBA@192.168.157.130:5236

    4、SQL 提示符下执行以下命令:

    select * from test;

    25 、

    参数优化

    26、

    定制备份策略

    27、

    客户端连接

    linux

    配置 /etc/dm_svc.conf 文件

    # 以#开头的行表示是注释

    # 全局配置区

    DMRW=(192.168.30.129:5236,192.168.30.131:5236)

    # 以#开头的行表示是注释

    # 全局配置区

    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 内容后,需要重启客户端程序,修改的配置才能生效

    。。。

  • 相关阅读:
    十二、 Spring Boot 静态资源处理
    九、 Spring Boot 拦截器
    docker之搭建私有仓库
    docker之Dokcerfile 常用指令
    docker之网络管理
    docker之故障问题解决方案
    docker之搭建LNMP
    docker之容器数据持久化
    都说岁月不饶人,我们又何曾饶过岁月
    docker之容器管理
  • 原文地址:https://www.cnblogs.com/liangshaoye/p/14989435.html
Copyright © 2011-2022 走看看