DSC自动部署

配置共享磁盘

1.在第一台服务器上添加一个磁盘

选择虚拟机(DSC1) > 右键“设置” > 添加“硬盘” > SCSI > 创建新虚拟磁盘 > 指定磁盘容量 > 指定磁盘文件路径及命名 > 确定。

选择新添加得硬盘 2 (SCSI) > 高级 > 设置设备号为 SCSI 1:1 ,模式为独立、永久。

2.在第二台服务器同样添加这个磁盘。

选择虚拟机(DSC2) > 右键“设置” > 添加“硬盘” > SCSI > 使用现有虚拟磁盘 > 选择现有磁盘(浏览找到刚创建的磁盘) > 完成。

选择新添加得硬盘 2 (SCSI) > 高级 > 设置设备号为 SCSI 1:1 ,模式为独立、永久。

3.修改两台虚拟机的vmx配置。

找到虚拟机创建路径下的vmx文件,通过记事本形式打开。
新增以下信息,其中前两行是每个共享磁盘需要新增的,后面的统一只需要添加一次。

scsi1.sharedBus = "virtual" 
scsi1:1.deviceType = "disk"

disk.locking = "false"
diskLib.dataCacheMaxSize = "0"
diskLib.dataCacheMaxReadAheadSize = "0"
diskLib.DataCacheMinReadAheadSize = "0"
diskLib.dataCachePageSize = "4096"
diskLib.maxUnsyncedWrites = "0"
disk.EnableUUID = "TRUE"

4.虚拟机启动途中会出现sdb即为新增的共享磁盘

5.查看磁盘

fdisk -l
lsblk

磁盘分区(DSC1)

分区(DSC1)

fdisk /dev/sdb

需要分区后才能进行绑定。依次输入下列信息:

n → p → 1 → “回车” → +1G           # dcr
n → p → 2 → “回车” → +1G           # vote
n → p → 3 → “回车” → +10G          # log0
n → p → 4 → “回车” → 回车          # data0
w                                 # 保存

查看分区(DSC1)

在这里插入图片描述

查看分区(DSC2)

在这里插入图片描述

如果DSC2中没有显示分区,则可能共享磁盘挂载失败,需要重新挂载。

配置裸设备(DSC1 & DSC2)
共享存储需要在 2 个节点上都操作。
sdb1-sdb4 是需要配置的共享磁盘。

新建 udev 规则文件(DSC1 & DSC2)

vi /etc/udev/rules.d/90-raw.rules

添加以下内容:

ACTION=="add",KERNEL=="sdb1",RUN+="/bin/raw /dev/raw/raw1 %N"
ACTION=="add",KERNEL=="sdb2",RUN+="/bin/raw /dev/raw/raw2 %N"
ACTION=="add",KERNEL=="sdb3",RUN+="/bin/raw /dev/raw/raw3 %N"
ACTION=="add",KERNEL=="sdb4",RUN+="/bin/raw /dev/raw/raw4 %N"
KERNEL=="raw[1-4]", OWNER="dmdba", GROUP="dinstall", MODE="660"

执行以下命令,使 udev 生效:

udevadm trigger --type=devices --action=change

执行以下命令,检查是否配置成功:

ll /dev/raw/raw* 

如果查看不到配置的裸设备,请重启服务器再验证。

在这里插入图片描述

备份还原

 ./dmrman use_ap=2 dcr_ini=/home/dmdba/dmdbms/dsc_config/AUTO_DSC1/dmdcr0.ini 

RESTORE DATABASE '/home/dmdba/dmdbms/dsc_config/AUTO_DSC1/dm.ini' FROM BACKUPSET '/home/dmdba/fullback';

RMAN>RECOVER DATABASE '/home/dmdba/dmdbms/dsc_config/AUTO_DSC1/dm.ini' FROM BACKUPSET '/home/dmdba/fullback';
RMAN>RECOVER DATABASE'/home/dmdba/dmdbms/dsc_config/AUTO_DSC1/dm.ini'  UPDATE DB_MAGIC;

上传部署工具

上传配置脚本到第一节点,并解压缩,修改所属用户为dmdba;

unzip  dm8_dsc_dw.zip  -d  /home/dmdba

2.2 配置文件dm8_dsc.conf

 cd /home/dmdba/dm8_dsc_dw
 vi dm8_dsc.conf

修改文件内容:(提前把文件内容涉及到的目录创建好)

#配置文件

[GLOBAL]

DM_HOME          = /home/dmdba/dmdbms/bin                 #根据实际修改

DB_PATH          = /home/dmdba/dmdbms/dsc_config          #DSC 节点的目录,里面存放控制文件、配置文件等

TEMP_PATH        = /home/dmdba/dmdbms/temp                #DSC 临时表空间目录,里面存放节点的临时表空间。

ARCH_PATH        = /dmarch/CNDT                           #DSC 节点的本地归档、远程归档路径,只有ARCH_INI_OPEN=1时生效。

BAK_PATH         = /dmbak/CNDT                            #DSC 节点数据库备份的默认路径

DCR_ASM_PATH     = /dev/dm_dcr                            #操作系统绑定的dcr路径

VOTE_ASM_PATH    = /dev/dm_vote                           #操作系统绑定的vote路径

LOG_ASM_PATH     = /dev/dm_redo                           #操作系统绑定的redo日志路径,对应磁盘组DMLOG

DATA_ASM_PATH    = /dev/dm_data0,/dev/dm_data1            #操作系统绑定的数据库数据文件路径,对应磁盘组DMDATA

ARCH_ASM_PATH    = /dev/dm_archive                        #操作系统绑定的本地归档存储路径,只有ARCH_INI_OPEN=2/3时生效,其对应的磁盘组DMARCH,如值与DATA_ASM_PATH完全一致,归档将存储在磁盘组DMDATA上。

[ARCH]

ARCH_INI_OPEN    = 2                                      #是否开启DSC节点的本地归档,0不开启,1开启本地归档且放在本地,2开启本地归档且放在ASM,3:DSC+备机,并且dsc归档放在asm上。

ARCH_SPACE_LIMIT = 10240                                 #单个节点的本地归档或远程归档的大小空间限制,如是4节点DSC,则需要预留4*ARCH_SPACE_LIMIT的空间。

SSH_PORT         = 22                                     #远程Linux服务器的ssh端口号,一般为22,某些客户出于安全考虑,会更改ssh的默认连接端口

[DSC_DMINIT]                                              #初始化DSC实例的一些参数

DB_NAME             = CNDT                                #实例名称

SYS_PATH            = data                                #在ASM存储中的数据文件路径,注意大小写

SYSTEM_SIZE         = 1024                                #SYSTEM.dbf的大小

ROLL_SIZE           = 10000                               #Roll表空间的大小

MAIN_SIZE           = 1024                                #MAIN表空间的大小

CTL_SIZE            = 8                                   #dm.ctl文件的大小

LOG_SIZE            = 2048                                #redo文件的大小,搭建集群完成后,通过17步骤扩大集群的redo文件到log_size大小。

AUTO_OVERWRITE      = 1                                   #ASM中的同名文件是否覆盖

PAGE_SIZE           = 16                                  #初始化实例时的页大小

EXTENT_SIZE         = 16                                  #初始化实例时的簇大小

DB_SYSDBA_PWD       = SYSDBA_PWD                          #初始化数据库时的SYSDBA密码,包括后续修改SYSDBA密码后的一些运维操作

DB_INIT_PARA        = CASE_SENSITIVE=1,UNICODE_FLAG=0     #其它初始化参数,需要什么参数按格式增加即可,多个参数以逗号隔开

[DSC_CONF]

DCR_OGUID           = 220914                              #DCR的oguid,取6位数字即可,常用规律为当前日期

[DSC_PORT]                               #搭建集群时所用到的各个端口号

DB_INST_PORT                = 31236      #DSC实例端口号

DB_MAL_PORT                 = 31246      #DSC实例的MAL通信端口号

DCR_CHECK_PORT              = 31256      #DCR 检查端口号。检查实例是否活动的时候用,各实例不能冲突,故该端口会随着实例自动+1

ASM_MAL_PORT                = 31266      #ASM 通信的端口号

ASM_DCR_EP_PORT             = 31276      #ASM 节点 TCP 监听端口。各实例不能冲突,故该端口会随着实例自动+1

CSS_DCR_EP_PORT             = 31286      #CSS 节点 TCP 监听端口

[DSC_TIME]                                 #DSC集群一些心跳故障认证时间

DB_DCR_GRP_DSKCHK_CNT       = 57           #心跳,DSC DB 故障认定时间

ASM_DCR_GRP_DSKCHK_CNT      = 61           #心跳,DSC ASM 故障认定时间

CSS_DCR_GRP_DSKCHK_CNT      = 65           #心跳,DSC CSS 故障认定时间

DMDCR_ASM_RESTART_INTERVAL  = 71           #DMCSS 认定 DMASM 节点故障重启的时间间隔(取值 0~86400s),0则不会执行拉起

DMDCR_DB_RESTART_INTERVAL   = 0            #DMCSS 认定 DMDSC 节点故障重启的时间间隔(取值 0~86400s),0则不会执行拉起

DMDCR_AUTO_OPEN_CHECK       = 111          #指定时间内如果节点实例未启动,DMCSS 会自动将节点踢出集群环境,单位为秒

MAL_CHECK_INTERVAL          = 87           #MAL 链路检测时间间隔,取值范围(0s-1800s)为了防止误判,DMDSC 集群中,建议将配置值>= DB_DCR_GRP_DSKCHK_CNT。

MAL_CONN_FAIL_INTERVAL      = 33           #判定 MAL 链路断开的时间,取值范围(2s-1800s)

[ASM]

DCR_EP_SHM_KEY              = 42424       #共享内存标识,不同实例的该值不一样,故该端口会随着实例自动+1

DCR_EP_SHM_SIZE             = 200         #共享内存大小

[DataWatcher]                                            #该组参数只有在ARCH_INI_OPEN=3时生效,表示搭建DSC+单机备机

DATA_PATH                   = /mppdata/dsc_dw                   #备机数据库数据文件路径,根据实际修改,但要确保该目录只为该集群所用。

MAL_DW_PORT                 = 52141                             #dmmal.ini中的MAL_DW_PORT端口,用于集群中所有守护进程、监视器的通信。

MAL_INST_DW_PORT            = 5276                              #DM8的参数,数据守护4.0

DB_OGUID                    = 191212                            #建议修改#OGUID,代表集群的唯一标识,表示数据库的OGUID

DW_TYPE                     = REALTIME                          #搭建的集群类型:即时归档:TIMELY;实时归档:REALTIME,如无特殊需求,建议用REALTIME

DW_MODE                     = MANUAL                            #集群的故障切换模式:自动切换(AUTO),非自动切换(MANUAL)          

ASYNC_NODE                  = 1                                 #异步备机的数量,取值0-8。始终从最后的NODE为异步备机,如只有2NODE,则表示1主1异步备机。

AUTO_RESTART                = 1                                 #实例自动重启,1表示自动重启,0表示不自动重启,仅针对备机有效,对DSC无效

INST_RECOVER_TIME           = 60                                #主库守护进程启动恢复的间隔时间

INST_ERROR_TIME             = 120                               #本地数据库故障认定时间

DW_ERROR_TIME               = 120                               #远程主(备)机守护进程故障认定时间

ARCH_WAIT_APPLY             = 0                                 #高性能模式为0,事务强一致模式为1

ARCH_FLUSH_BUF_SIZE         = 0                                 #写本地归档时,合并rlog为多少M再写。202009月度版才支持,之前版本该值需要设置为0.

[MAIL]#一般不用改参数,以128GB内存为例

MAL_SYS_BUF_SIZE=6000

MAL_BUF_SIZE=3000

MAL_VPOOL_SIZE=5000

MAL_COMPRESS_LEVEL=0

#各节点配置

[DSC1]

DSC_MAL_HOST = 192.168.50.13     #内网IP

DSC_INST_HOST = 192.168.186.13   #外网IP

DSC_INST_UID  = dmdba    #输入登录用户名

DSC_INST_PWD  = ******* #输入登录密码

[DSC2]

DSC_MAL_HOST = 192.168.50.14

DSC_INST_HOST = 192.168.186.14

DSC_INST_UID  = dmdba

DSC_INST_PWD  = ******* 

部署执行过程

python dm8_dsc.py

请输入配置文件:

dm8_dsc.conf

部署集群:2节点DSC环境,本地归档存储在ASM。
DM8_DSC>
在这里插入图片描述

执行步骤h 查看帮助信息
在这里插入图片描述

执行步骤01 SSH连接各机

在这里插入图片描述

执行步骤02 测试网络互通

在这里插入图片描述

执行步骤03 搭建DSC
在这里插入图片描述

执行步骤q 退出部署工具

测试集群功能可用性

在节点DSC01创建表t1,并插入数据,提交;

SQL> create table t1(id int ,name varchar2(50));
SQL> insert into test values(1,'joy'),(2,'san');
SQL> commit;

在这里插入图片描述

在节点DSC0可以查询到表test数据;

SQL> select * from t1;

在这里插入图片描述

此时DSC集群搭建成功!!
达梦社区地址:https://eco.dameng.com

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值