达梦8MPP集群(2节点+顺序备)linux下部署

  1. 安装前准备

1.1集群规划

A机器

B机器

业务IP

192.168.125.148

192.168.125.149

心跳IP

192.168.125.148

192.168.125.149

实例名

MPP1_01

MPP1_02B

MPP1_02

MPP1_01B

实例端口

5236

5237

5236

5237

MAL端口

5336

5337

5336

5337

MAL守护进程端口

5436

5437

5436

5437

守护进程端口

5536

5537

5536

5537

OGUID

45331

45332

45332

45331

守护组

GMPP1_01

GMPP1_02

GMPP1_02

GMPP1_01

安装目录

/home/dmdba/dmdbms

实例目录

/home/dmdba/dmdbms/data/

归档上限

51200

确认监视器IP

192.168.125.149

1.2集群构架

2配置A机器MPP1_01库

2.1初始化实例

/home/dmdba/dmdbms/bin/dminit PATH=/home/dmdba/dmdbms/data/ DB_NAME=MPP1_01 INSTANCE_NAME=MPP1_01 PORT_NUM=5236 PAGE_SIZE=32 LOG_SIZE=2048

(注:初始化后前台启动在关闭才算是完成的初始化)

2.2启动归档、脱机备份

启动归档(bin目录)

./disql SYSDBA/SYSDBA@192.168.125.148:5236

SQL> ALTER DATABASE MOUNT;

SQL> ALTER DATABASE ARCHIVELOG;

SQL> ALTER DATABASE ADD ARCHIVELOG 'DEST=/home/dmdba/dmdbms/data/MPP1_01/arch, TYPE=LOCAL, FILE_SIZE=1024, SPACE_LIMIT=51200';

SQL> ALTER DATABASE OPEN;

脱机备份

cd /opt/dmdbms/bin

./dmrman

backup database '/home/dmdba/dmdbms/data/MPP1_01/dm.ini' to backup_file_01 backupset '/home/dmdba/dmdbms/data/MPP1_01/bak/backup_file_01'

(注:可以等B机器初始化完成后在拷贝。)

2.3配置dm.ini文件

PORT_NUM = 5236          #数据库实例监听端口,即对外端口,与 dmmal.ini 中 的 MAL_INST_PORT 对应

DW_INACTIVE_INTERVAL = 60  #接收守护进程消息超时时间

ALTER_MODE_STATUS = 0      #不允许手动方式修改实例模式/状态/OGUID, 

ENABLE_OFFLINE_TS = 2       #不允许备库 OFFLINE 表空间

MAL_INI = 1                 #打开 MAL 系统

ARCH_INI = 1                #打开归档配置

RLOG_SEND_APPLY_MON = 64  #统计最近 64 次的日志发送信息

2.4配置dmarch.ini

ARCH_WAIT_APPLY      = 0        

[ARCHIVE_LOCAL1]

ARCH_TYPE            = LOCAL        

ARCH_DEST            = /home/dmdba/dmdbms/data/MPP1_01/arch        

ARCH_FILE_SIZE       = 1024        

ARCH_SPACE_LIMIT     = 51200        

ARCH_FLUSH_BUF_SIZE  = 0        

[ARCHIVE_REALTIME]

  ARCH_TYPE                = REALTIME  #实时归档类型

  ARCH_DEST                = MPP1_01B  #实时归档目标实例名

2.5配置dmmal.ini

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

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

MAL_TEMP_PATH              = /home/dmdba/dmdbms/data/malpath/MPP1_01/  #临时文件目录

MAL_BUF_SIZE               = 512  #单个MAL缓存大小,单位MB

MAL_SYS_BUF_SIZE           = 2048  #MAL总大小限制,单位MB

MAL_COMPRESS_LEVEL         = 0  #MAL消息压缩等级,0表示不压缩

[MAL_INST1]

  MAL_INST_NAME            = MPP1_01  #实例名,和 dm.ini中INSTANCE_NAME一致

  MAL_HOST                 = 192.168.125.148  #MAL系统监听TCP连接的IP地址

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

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

  MAL_INST_PORT            = 5236  #实例对外服务端口,和dm.ini中PORT_NUM一致

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

  MAL_INST_DW_PORT         = 5536  #实例监听守护进程TCP连接的端口

[MAL_INST2]

  MAL_INST_NAME            = MPP1_01B

  MAL_HOST                 = 192.168.125.149

  MAL_PORT                 = 5337

  MAL_INST_HOST            = 192.168.125.149

  MAL_INST_PORT            = 5237

  MAL_DW_PORT              = 5437

  MAL_INST_DW_PORT         = 5537

[MAL_INST3]

  MAL_INST_NAME            = MPP1_02

  MAL_HOST                 = 192.168.125.149

  MAL_PORT                 = 5336

  MAL_INST_HOST            = 192.168.125.149

  MAL_INST_PORT            = 5236

  MAL_DW_PORT              = 5436

  MAL_INST_DW_PORT         = 5536

[MAL_INST4]

  MAL_INST_NAME            = MPP1_02B

  MAL_HOST                 = 192.168.125.148

  MAL_PORT                 = 5337

  MAL_INST_HOST            = 192.168.125.148

  MAL_INST_PORT            = 5237

  MAL_DW_PORT              = 5437

  MAL_INST_DW_PORT         = 5537

2.6配置dmmpp.ini

ARCH_WAIT_APPLY      = 0        

[ARCHIVE_LOCAL1]

ARCH_TYPE            = LOCAL        

ARCH_DEST            = /home/dmdba/dmdbms/data/MPP1_01/arch        

ARCH_FILE_SIZE       = 1024        

ARCH_SPACE_LIMIT     = 51200        

ARCH_FLUSH_BUF_SIZE  = 0        

[ARCHIVE_REALTIME]

  ARCH_TYPE                = REALTIME  #实时归档类型

  ARCH_DEST                = MPP1_01B  #实时归档目标实例名

2.7配置dmmpp.ctl

/home/dmdba/dmdbms/bin/dmctlcvt t2c /home/dmdba/dmdbms/data/MPP1_01/dmmpp.ini /home/dmdba/dmdbms/data/MPP1_01/dmmpp.ctl

2.8配置dmwatcher.ini

[GMPP1_01]

  DW_TYPE                  = GLOBAL  #全局守护类型

  DW_MODE                  = MANUAL  #故障手动切换模式

  DW_ERROR_TIME            = 20  #远程守护进程故障认定时间

  INST_ERROR_TIME          = 20  #本地实例故障认定时间

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

  INST_OGUID               = 45331  #守护系统唯一OGUID值

  INST_INI                 = /home/dmdba/dmdbms/data/MPP1_01/dm.ini  #dm.ini文件路径

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

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

  RLOG_SEND_THRESHOLD      = 0  #指定主库发送日志到备库的时间阈值,默认关闭

  RLOG_APPLY_THRESHOLD     = 0  #指定备库重演日志的时间阈值,默认关闭

[GMPP1_02]

  DW_TYPE                  = GLOBAL

  DW_MODE                  = MANUAL

  DW_ERROR_TIME            = 20

  INST_ERROR_TIME          = 20

  INST_RECOVER_TIME        = 60

  INST_OGUID               = 45332

  INST_INI                 = /home/dmdba/dmdbms/data/MPP1_02/dm.ini

  INST_AUTO_RESTART        = 1

  INST_STARTUP_CMD         = /home/dmdba/dmdbms/bin/dmserver

  RLOG_SEND_THRESHOLD      = 0

  RLOG_APPLY_THRESHOLD     = 0

2.9拷贝实例

scp -r /home/dmdba/dmdbms/data/MPP1_01/ dmdba@192.168.125.149:/home/dmdba/dmdbms/data/

(注:MPP1_01后面一定要有/)

2.10注册服务

注册实例服务

/home/dmdba/dmdbms/script/root/dm_service_installer.sh -t dmserver -p MPP1_01 -dm_ini /home/dmdba/dmdbms/data/MPP1_01/dm.ini -m mount

注册守护服务

/home/dmdba/dmdbms/script/root/dm_service_installer.sh -t dmwatcher -p MPP1_01 -watcher_ini /home/dmdba/dmdbms/data/MPP1_01/dmwatcher.ini

3配置B机器MPP1_02库

3.1初始化实例

/home/dmdba/dmdbms/bin/dminit PATH=/home/dmdba/dmdbms/data/ DB_NAME=MPP1_01 INSTANCE_NAME=MPP1_01 PORT_NUM=5236 PAGE_SIZE=32 LOG_SIZE=2048

(注:初始化后前台启动在关闭才算是完成的初始化)

3.2启动归档、脱机备份

启动归档(bin目录)

./disql SYSDBA/SYSDBA@192.168.125.148:5236

SQL> ALTER DATABASE MOUNT;

SQL> ALTER DATABASE ARCHIVELOG;

SQL> ALTER DATABASE ADD ARCHIVELOG 'DEST=/home/dmdba/dmdbms/data/MPP1_01/arch, TYPE=LOCAL, FILE_SIZE=1024, SPACE_LIMIT=51200';

SQL> ALTER DATABASE OPEN;

脱机备份

cd /opt/dmdbms/bin

./dmrman

backup database '/home/dmdba/dmdbms/data/MPP1_01/dm.ini' to backup_file_01 backupset '/home/dmdba/dmdbms/data/MPP1_01/bak/backup_file_01'

(注:可以等B机器初始化完成后在拷贝。)

3.3配置dm.ini文件

PORT_NUM = 5236          #数据库实例监听端口,即对外端口,与 dmmal.ini 中 的 MAL_INST_PORT 对应

DW_INACTIVE_INTERVAL = 60  #接收守护进程消息超时时间

ALTER_MODE_STATUS = 0      #不允许手动方式修改实例模式/状态/OGUID, 

ENABLE_OFFLINE_TS = 2       #不允许备库 OFFLINE 表空间

MAL_INI = 1                 #打开 MAL 系统

ARCH_INI = 1                #打开归档配置

RLOG_SEND_APPLY_MON = 64  #统计最近 64 次的日志发送信息

3.4配置dmarch.ini

ARCH_WAIT_APPLY      = 0        

[ARCHIVE_LOCAL1]

ARCH_TYPE            = LOCAL        

ARCH_DEST            = /home/dmdba/dmdbms/data/MPP1_02/arch        

ARCH_FILE_SIZE       = 1024        

ARCH_SPACE_LIMIT     = 51200        

ARCH_FLUSH_BUF_SIZE  = 0        

[ARCHIVE_REALTIME]

  ARCH_TYPE                = REALTIME  #实时归档类型

  ARCH_DEST                = MPP1_02B  #实时归档目标实例名

3.5配置dmmal.ini

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

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

MAL_TEMP_PATH              = /home/dmdba/dmdbms/data/malpath/MPP1_01/  #临时文件目录

MAL_BUF_SIZE               = 512  #单个MAL缓存大小,单位MB

MAL_SYS_BUF_SIZE           = 2048  #MAL总大小限制,单位MB

MAL_COMPRESS_LEVEL         = 0  #MAL消息压缩等级,0表示不压缩

[MAL_INST1]

  MAL_INST_NAME            = MPP1_01  #实例名,和 dm.ini中INSTANCE_NAME一致

  MAL_HOST                 = 192.168.125.148  #MAL系统监听TCP连接的IP地址

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

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

  MAL_INST_PORT            = 5236  #实例对外服务端口,和dm.ini中PORT_NUM一致

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

  MAL_INST_DW_PORT         = 5536  #实例监听守护进程TCP连接的端口

[MAL_INST2]

  MAL_INST_NAME            = MPP1_01B

  MAL_HOST                 = 192.168.125.149

  MAL_PORT                 = 5337

  MAL_INST_HOST            = 192.168.125.149

  MAL_INST_PORT            = 5237

  MAL_DW_PORT              = 5437

  MAL_INST_DW_PORT         = 5537

[MAL_INST3]

  MAL_INST_NAME            = MPP1_02

  MAL_HOST                 = 192.168.125.149

  MAL_PORT                 = 5336

  MAL_INST_HOST            = 192.168.125.149

  MAL_INST_PORT            = 5236

  MAL_DW_PORT              = 5436

  MAL_INST_DW_PORT         = 5536

[MAL_INST4]

  MAL_INST_NAME            = MPP1_02B

  MAL_HOST                 = 192.168.125.148

  MAL_PORT                 = 5337

  MAL_INST_HOST            = 192.168.125.148

  MAL_INST_PORT            = 5237

  MAL_DW_PORT              = 5437

  MAL_INST_DW_PORT         = 5537

3.6配置dmmpp.ini

[service_name1]

  mpp_seq_no               = 0

  mpp_inst_name            = MPP1_01

[service_name2]

  mpp_seq_no               = 1

  mpp_inst_name            = MPP1_02

3.7配置dmmpp.ctl

/home/dmdbms/bin/dmctlcvt t2c /opt/dmdbms/data/MPP1_02/dmmpp.ini /home/dmdba/dmdbms/data/MPP1_02/dmmpp.ctl

3.8配置dmwatcher.ini

[GMPP1_01]

  DW_TYPE                  = GLOBAL  #全局守护类型

  DW_MODE                  = MANUAL  #故障手动切换模式

  DW_ERROR_TIME            = 20  #远程守护进程故障认定时间

  INST_ERROR_TIME          = 20  #本地实例故障认定时间

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

  INST_OGUID               = 45331  #守护系统唯一OGUID值

  INST_INI                 = /home/dmdba/dmdbms/data/MPP1_01/dm.ini  #dm.ini文件路径

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

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

  RLOG_SEND_THRESHOLD      = 0  #指定主库发送日志到备库的时间阈值,默认关闭

  RLOG_APPLY_THRESHOLD     = 0  #指定备库重演日志的时间阈值,默认关闭

[GMPP1_02]

  DW_TYPE                  = GLOBAL

  DW_MODE                  = MANUAL

  DW_ERROR_TIME            = 20

  INST_ERROR_TIME          = 20

  INST_RECOVER_TIME        = 60

  INST_OGUID               = 45332

  INST_INI                 = /home/dmdba/dmdbms/data/MPP1_02/dm.ini

  INST_AUTO_RESTART        = 1

  INST_STARTUP_CMD         = /home/dmdba/dmdbms/bin/dmserver

  RLOG_SEND_THRESHOLD      = 0

  RLOG_APPLY_THRESHOLD     = 0

3.9拷贝实例

scp -r /home/dmdba/dmdbms/data/MPP1_02/ dmdba@192.168.125.148:/home/dmdba/dmdbms/data/

3.10注册服务

注册实例服务

/home/dmdba/dmdbms/script/root/dm_service_installer.sh -t dmserver -p MPP1_02 -dm_ini /home/dmdba/dmdbms/data/MPP1_02/dm.ini -m mount

注册守护服务

/home/dmdba/dmdbms/script/root/dm_service_installer.sh -t dmwatcher -p MPP1_02 -watcher_ini /home/dmdba/dmdbms/data/MPP1_02/dmwatcher.ini

4配置B机器MPP1_01B

4.1配置dm.ini

vi /opt/dmdbms/data/MPP1_01/dm.ini

INSTANCE_NAME              = MPP1_01B  #数据库实例名

PORT_NUM                   = 5237  #数据库实例监听端口

4.2配置dmarch.ini

ARCH_WAIT_APPLY      = 0        

[ARCHIVE_LOCAL1]

ARCH_TYPE            = LOCAL        

ARCH_DEST            = /home/dmdba/dmdbms/data/MPP1_01/arch        

ARCH_FILE_SIZE       = 1024        

ARCH_SPACE_LIMIT     = 51200        

ARCH_FLUSH_BUF_SIZE  = 0        

[ARCHIVE_REALTIME]

  ARCH_TYPE                = REALTIME  #实时归档类型

  ARCH_DEST                = MPP1_01  #实时归档目标实例名

4.3相同配置文件

包括dmmal.ini、dmmpp.ini、dmmpp.ctl,MPP1_01B和MPP1_01相同。

4.4注册服务

/home/dmdba/dmdbms/script/root/dm_service_installer.sh -t dmserver -p MPP1_01B -dm_ini /home/dmdba/dmdbms/data/MPP1_01/dm.ini -m mount

4.5脱机数据库还原与恢复

还原

restore database '/home/dmdba/dmdbms/data/MPP1_01/dm.ini' from backupset '/home/dmdba/dmdbms/data/MPP1_01/bak/backup_file_01'

恢复

recover database '/home/dmdba/dmdbms/data/MPP1_01/dm.ini' from backupset '/home/dmdba/dmdbms/data/MPP1_01/bak/backup_file_01'

更新

recover database '/home/dmdba/dmdbms/data/MPP1_01/dm.ini' update db_magic

5配置A机器MPP1_02B

5.1配置dm.ini

vi /home/dmdba/dmdbms/data/MPP1_02/dm.ini

INSTANCE_NAME              = MPP1_02B  #数据库实例名

PORT_NUM                   = 5237  #数据库实例监听端口

5.2配置dmarch.ini

ARCH_WAIT_APPLY      = 0        

[ARCHIVE_LOCAL1]

ARCH_TYPE            = LOCAL        

ARCH_DEST            = /home/dmdba/dmdbms/data/MPP1_02/arch        

ARCH_FILE_SIZE       = 1024        

ARCH_SPACE_LIMIT     = 51200        

ARCH_FLUSH_BUF_SIZE  = 0        

[ARCHIVE_REALTIME]

  ARCH_TYPE                = REALTIME  #实时归档类型

  ARCH_DEST                = MPP1_02  #实时归档目标实例名

5.3相同配置文件

包括dmmal.ini、dmmpp.ini、dmmpp.ctl,MPP1_01B和MPP1_01相同。

5.4注册服务

/home/dmdba/dmdbms/script/root/dm_service_installer.sh -t dmserver -p MPP1_02B -dm_ini /home/dmdba/dmdbms/data/MPP1_02/dm.ini -m mount

5.5脱机数据库还原与恢复

还原

restore database '/home/dmdba/dmdbms/data/MPP1_02/dm.ini' from backupset '/home/dmdba/dmdbms/data/MPP1_02/bak/backup_file_02'

恢复

recover database '/home/dmdba/dmdbms/data/MPP1_02/dm.ini' from backupset '/home/dmdba/dmdbms/data/MPP1_02/bak/backup_file_02'

更新

recover database '/home/dmdba/dmdbms/data/MPP1_02/dm.ini' update db_magic

6配置监视器

这里注册非确认监视器,这里在B机器上的bin目录下创建dmmonitor.ini文件

6.1配置dmmonitor.ini

MON_DW_CONFIRM             = 0  #0为非确认,1为确认

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

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

MON_LOG_FILE_SIZE          = 512  #单个日志大小,单位MB

MON_LOG_SPACE_LIMIT        = 2048  #日志上限,单位MB

[GMPP1_01]

  MON_INST_OGUID           = 45331  #组GMPP1_01的唯一OGUID 值

  MON_DW_IP                = 192.168.125.148:5436  #IP对应MAL_HOST,PORT对应MAL_DW_PORT

  MON_DW_IP                = 192.168.125.149:5437

[GMPP1_02]

  MON_INST_OGUID           = 45332  #组GMPP1_02的唯一OGUID 值

  MON_DW_IP                = 192.168.125.149:5436

  MON_DW_IP                = 192.168.125.148:5437

7启动实例服务并修改参数

7.1启动实例服务

这里启动所有实例服务(按顺序)

/home/dmdba/dmdbms/bin/DmServiceMPP1_01 start

/home/dmdba/dmdbms/bin/DmServiceMPP1_02 start

/home/dmdba/dmdbms/bin/DmServiceMPP1_01B start

/home/dmdba/dmdbms/bin/DmServiceMPP1_02B start

7.2修改参数

A机器-MPP1_01

/home/dmdba/dmdbms/bin/disql SYSDBA/SYSDBA@192.168.125.148:5236

SQL> SP_SET_OGUID(45331);

SQL> ALTER DATABASE PRIMARY;

B机器-MPP1_02

/home/dmdba/dmdbms/bin/disql SYSDBA/SYSDBA@192.168.125.149:5236

SQL> SP_SET_OGUID(45332);

SQL> ALTER DATABASE PRIMARY;

A机器-MPP1_02B

/home/dmdba/dmdbms/bin/disql SYSDBA/SYSDBA@192.168.125.148:5237

SQL> SP_SET_OGUID(45332);

SQL> SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);

SQL> ALTER DATABASE STANDBY;

SQL> SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);

B机器-MPP1_01B

/home/dmdba/dmdbms/bin/disql SYSDBA/SYSDBA@192.168.125.149:5237

SQL> SP_SET_OGUID(45331);

SQL> SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 1);

SQL> ALTER DATABASE STANDBY;

SQL> SP_SET_PARA_VALUE(1, 'ALTER_MODE_STATUS', 0);

8启动守护进程

A机器

/home/dmdba/dmdbms/bin/DmWatcherServiceMPP1_01 start

B机器

/home/dmdba/dmdbms/bin/DmWatcherServiceMPP1_02 start

9启动监视器

由于非确认监视器配置在了B机器,这里前台启动

/home/dmdba/dmdbms/bin/dmmonitor /home/dmdba/dmdbms/bin/dmmonitor.ini

10启停集群顺序

启动

A机器: /home/dmdba/dmdbms/bin/DmWatcherServiceMPP1_01 start

B机器: /home/dmdba/dmdbms/bin/DmWatcherServiceMPP1_02 start

停止

A机器: /home/dmdba/dmdbms/bin/DmWatcherServiceMPP1_01 stop

B机器: /home/dmdba/dmdbms/bin/DmWatcherServiceMPP1_02 stop

A机器: /home/dmdba/dmdbms/bin/DmServiceMPP1_01 stop

B机器: /home/dmdba/dmdbms/bin/DmServiceMPP1_02 stop

B机器: /home/dmdba/dmdbms/bin/DmServiceMPP1_01B stop

A机器: /home/dmdba/dmdbms/bin/DmServiceMPP1_02B stop

社区地址:https://eco.dameng.com

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值