达梦DMDSC共享存储集群安装部署方案

一、DMDSC介绍

在前面的文章中,有介绍过DMDSC集群的一些基本概念,包括架构图,具体文章链接如下:

https://blog.csdn.net/weixin_39766655/article/details/121989858

在此不过多赘述,下面主要讲一下DMDSC集群的配置过程。

二、实验环境

Vmware 16 配置CentOS7.3 虚拟机 * 2,每台网卡 * 2,每台各一块本地存储磁盘,然后添加一块共享磁盘(虚拟机A和B共用这块共享磁盘),每个虚拟机,安装DM8数据库(不需要初始化)。
虚拟机A:192.168.116.138、192.168.134.142
虚拟机B:192.168.116.138、192.168.134.143
192.168.116.0网段用于内网MAL系统同信
192.168.134.0网段用于外网客户访问数据库
 

三、实验过程

1、配置共享存储

1).windows机器上打开cmd命令行,执行以下命令创建共享存储:

vmware-vdiskmanager.exe -c -s 10G -a lslogic -t 2 "C:\Users\leoisleo\Documents\Virtual Machines\DMHS\DMHS-2.vmdk"

该命令是调用vmware-vdiskmanager.exe这个程序去操作创建虚拟磁盘,注意执行路径是否正确;
该命令会创建一个10G大小的虚拟磁盘,注意和自己的需求是否一致;
该命令创建的虚拟磁盘保存在如下截图位置,这个路径在后面虚拟机添加磁盘时会用到;

2).虚拟机A添加磁盘

 

这里需要注意虚拟设备节点 SCSI 0:1,这个信息后面会用到。 

3).虚拟机B除去cmd不用执行命令,同样执行上面添加虚拟磁盘的操作。

4).虚拟机A和B,在虚拟机配置文件*.vmx末尾,以记事本的方式打开,添加磁盘不锁定的信息,避免重启虚拟机后,因磁盘锁定导致无法开机的情况 

scsi0:1.fileName = "C:\Users\leoisleo\Documents\Virtual Machines\DMHS\DMHS-2.vmdk"
scsi0:1.mode = "independent-persistent"
scsi0:1.SharedBus="Virtual"
disk.locking = "false"

注意添加内容开头的信息,scsi0:1,就是前面截图 虚拟设备节点 添加的共享磁盘信息。
若提示SCSI0:1 已定义,可以去掉添加的第一行内容。

5).两个虚拟机开机后,fdisk -l确认可以看到添加的共享磁盘(root用户执行),然后在其中一个虚拟机上,对这块共享磁盘做分区以及格式化(只用在一个机器上执行即可):

fdisk -l
fdisk /dev/sdb 输入 n -- p -- enter键 -- enter键 -- +100M 即第一个主分区分了100M的大小;然后继续 n -- p -- enter键 -- enter键 -- + 100M...最后按 w  保存退出(若划分分区错误,可以按 d -- 分区号  删除分区,然后重新划分,w保存退出)

最后执行命令格式化分区:

partprobe /dev/sdb 

总计花分四个主分区,大小根据实际需求来,本次实验划分具体大小如下所示:

6).两个虚拟机,均修改配置vim /etc/udev/rules.d/60-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"
ACTION=="add", KERNEL=="raw[1-4]", OWNER="dmdba", GROUP="dinstall", MODE="660"

直接添加到文件最下面,如下图所示:


执行命令重新加载配置
RH6执行命令:start_udev
Centos7执行命令: udevadm trigger --action=add

7).确认划分分区后的两个机器配置均一致

raw -qa 查询确认两个机器是否一致
blockdev --getsize64 /dev/raw/raw1 命令查看配置的共享磁盘分区大小,两节点信息需一致

到这里,共享存储配置完毕。

2、创建数据库实例

该步骤在此不做赘述,只需要执行./DMInstall -i 安装完毕,拉起DMAP服务即可,不需要做初始化实例的动作,本次实验数据库的安装目录为/home/dmdba。

3、编写配置文件(本次实验的配置文件均存放于/home/dmdba/config子目录下)
1).编写DCR配置文件 /home/dmdba/config/dmdcr_cfg.ini (两个机器配置文件需要一致),具体配置文件如下:

DCR_N_GRP           		= 3
DCR_VTD_PATH        		= /dev/raw/raw2
DCR_OGUID       			= 63635

[GRP]
	DCR_GRP_TYPE        	= CSS	
	DCR_GRP_NAME        	= GRP_CSS
	DCR_GRP_N_EP        	= 2
	DCR_GRP_DSKCHK_CNT  	= 60
[GRP_CSS]
	DCR_EP_NAME         	= CSS0
	DCR_EP_HOST         	= 192.168.116.138
	DCR_EP_PORT         	= 9341
[GRP_CSS]
	DCR_EP_NAME         	= CSS1
	DCR_EP_HOST         	= 192.168.116.137
	DCR_EP_PORT         	= 9343	
[GRP]
	DCR_GRP_TYPE        	= ASM
	DCR_GRP_NAME        	= GRP_ASM
	DCR_GRP_N_EP        	= 2
	DCR_GRP_DSKCHK_CNT  	= 60
[GRP_ASM]
	DCR_EP_NAME         	= ASM0
	DCR_EP_SHM_KEY      	= 93360
	DCR_EP_SHM_SIZE     	= 20
	DCR_EP_HOST         	= 192.168.116.138
	DCR_EP_PORT         	= 9349
	DCR_EP_ASM_LOAD_PATH 	= /dev/raw
[GRP_ASM]
	DCR_EP_NAME         	= ASM1
	DCR_EP_SHM_KEY      	= 93361
	DCR_EP_SHM_SIZE     	= 20
	DCR_EP_HOST         	= 192.168.116.137
	DCR_EP_PORT         	= 9351
	DCR_EP_ASM_LOAD_PATH 	= /dev/raw
	
[GRP]
	DCR_GRP_TYPE        	= DB
	DCR_GRP_NAME        	= GRP_DSC
	DCR_GRP_N_EP        	= 2
	DCR_GRP_DSKCHK_CNT  	= 60
[GRP_DSC]
	DCR_EP_NAME        	= DSC0
	DCR_EP_SEQNO		= 0
DCR_EP_PORT			= 5236
	DCR_CHECK_PORT		= 9741
[GRP_DSC]
	DCR_EP_NAME        	= DSC1
DCR_EP_SEQNO		= 1
	DCR_EP_PORT		= 5237
	DCR_CHECK_PORT		= 9742

2).编写 /home/dmdba/config/dmasvrmal.ini 配置文件,两个机器一致

[MAL_INST1]     
MAL_INST_NAME              = ASM0
MAL_HOST                    = 192.168.116.138
MAL_PORT                    = 7236
 
[MAL_INST2]     
MAL_INST_NAME              = ASM1
MAL_HOST                    = 192.168.116.137
MAL_PORT                    = 7237

3).编写 /home/dmdba/config/dmdcr.ini 配置文件

DMDCR_PATH     = /dev/raw/raw1
DMDCR_MAL_PATH =/home/dmdba/config/dmasvrmal.ini
DMDCR_SEQNO   = 0
#ASM
DMDCR_ASM_RESTART_INTERVAL =0
#DMDCR_ASM_STARTUP_CMD = /home/dmdba/bin/DmASMSvrServicedsc1 start
DMDCR_ASM_STARTUP_CMD = /home/dmdba/bin/dmasmsvr  dcr_ini=/home/dmdba/config/dmdcr.ini
#DB
DMDCR_DB_RESTART_INTERVAL = 0
#DMDCR_DB_STARTUP_CMD = /home/dmdba/bin/DmServicedsc1 start
DMDCR_DB_STARTUP_CMD = /home/dmdba/bin/dmserver  path=/home/dmdba/config/dsc1/dm.ini dcr_ini=/home/dmdba/config/dmdcr.ini

注意:DMDCR_SEQNO配置项,两个机器一个是0 一个是1

4、拉起css服务和asm服务

到两个机器的bin目录下执行命令(两个服务在两个机器均需要执行,先拉起CSS服务):

./dmcss dcr_ini=/home/dmdba/config/dmdcr.ini

./dmasmsvr dcr_ini=/home/dmdba/config/dmdcr.ini

 执行命令./dmcss dcr_ini=/home/dmdba/config/dmdcr.ini命令后,也可以在命令执行show命令,查看当前DSC集群各个节点状态,如下图所示:

5、创建日志磁盘组和数据磁盘组

通过dmasmtool工具,在一个机器操作即可:

./dmasmtool dcr_ini=/home/dmdba/config/dmdcr.ini
##创建日志磁盘组
create diskgroup 'DMLOG' asmdisk '/dev/raw/raw3'
##创建数据磁盘组
create diskgroup 'DMDATA' asmdisk '/dev/raw/raw4'

6、初始化数据库实例

在其中一个机器上,编写/home/dmdba/config/dminit.ini配置文件,配置文件内容如下:

db_name = dsc
system_path = +DMDATA/dmdba
system = +DMDATA/dmdba/dsc/system.dbf
system_size = 128
roll = +DMDATA/dmdba/dsc/roll.dbf
roll_size = 128
main = +DMDATA/dmdba/dsc/main.dbf
main_size = 128
ctl_path = +DMDATA/dmdba/dsc/dm.ctl
ctl_size = 8
log_size = 256
dcr_path = /dev/raw/raw1 ##dcr磁盘路径,目前不支持asm,只能是裸设备
dcr_seqno = 0
auto_overwrite = 1
[DSC0] ##inst_name跟dmdcr_cfg.ini中DB类型group中DCR_EP_NAME对应
config_path = /home/dmdba/dsc0_config
port_num = 5236
mal_host = 192.168.116.138
mal_port = 9340
log_path = +DMLOG/log/dsc0_log01.log
log_path = +DMLOG/log/dsc0_log02.log
[DSC1] ##inst_name跟dmdcr_cfg.ini中DB类型group中DCR_EP_NAME对应
config_path = /home/dmdba/dsc1_config
port_num = 5236
mal_host = 192.168.116.137
mal_port = 9341
log_path = +DMLOG/log/dsc1_log01.log
log_path = +DMLOG/log/dsc1_log02.log

数据库的bin目录下,执行下面命令,初始化数据库:

./dminit control=/home/dmdba/config/dminit.ini

 拷贝目录到另一个机器
scp -rp /home/dmdba/dsc1_config /home/dmdba/dsc dmdba@192.16.116.137:/home/dmdba

7、拉起数据库服务

在两个机器上,分别执行拉起数据库服务的命令:
./dmserver /home/dmdba/dsc0_config/dm.ini dcr_ini=/home/dmdba/config/dmdcr.ini
./dmserver /home/dmdba/dsc1_config/dm.ini dcr_ini=/home/dmdba/config/dmdcr.ini

至此,整个实验配置过程结束。

 三、测试结果测试

分别在两个机器上做数据库数据的增删改操作,另一个机器确认结果是否实时同步:

四、实验中遇到的问题:

问题1:ASM服务启动异常

 可能原因:1)、虚拟机防火墙未关闭

systemctl stop firewalld
systemctl disable firewalld

2)、ASM配置异常,修改配置文件

问题2:共享存储磁盘创建异常

尽量用本次实验cmd窗口,命令创建虚拟共享磁盘的方式,最开始实验测试,是图形界面直接修改A虚拟机配置,添加磁盘,然后B虚拟机添加这块磁盘,后来在初始化 dcrdisk 的时候一直报错,提示“不支持的磁盘格式”,按照cmd的方式创建后则正常。

问题3:虚拟机添加磁盘,修改.vmx配置文件后无法拉起,提示“.vmx配置文件损坏”

原因:添加的关于共享存储磁盘配置异常,可以先删除掉添加的配置,启动虚拟机。

了解更多达梦DMDSC共享集群相关技术,可以访问达梦官网学习

DM 数据库快速上手指南 | 达梦技术文档

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值