ORACLE RAC系统是一个可以横向进行扩展的系统,当一个RAC系统计算能力不满足客户的需求时候,增加节点能够快速增加整个系统的计算能力,使得客户系统计算能力得到一定的提升,以满足客户不断增长的计算需求。

一、        增加节点的准备工作

俗话说,磨刀不误砍柴工,在RAC安装和增加节点过程中,该俗语充分体现了准备工作的重要性。硬件初始化主要包括服务器的安装、存储的连接、网络连接等步骤。本文所基于的基本环境如下:

1.         原有节点分别为cluster1和cluster2

2.         软件环境如下:

操作系统:solaris 10 u11

数据库软件:ORACLE Database 11g

OS用户: grid用户用于管理clusterware,oracle用户用于数据库

3.         IP地址具体规划如下:

192.168.0.12    cluster1

192.168.0.13    cluster2

192.168.0.14    cluster1-vip

192.168.0.16    cluster2-vip

192.168.0.15    cluster1-priv

192.168.0.17    cluster2-priv

192.168.0.19    scan-ip

4.         新节点环境规划:

操作系统和database软件必须采用原有节点一个版本的软件

创建grid和oracle用户,具体创建步骤参考下节内容

IP地址设置为:

192.168.0.18  cluster3

192.168.0.20  cluster3-vip

192.168.0.21  cluster-priv

u  主机系统环境的设置

1.  创建用户

groupadd -g 1000 oinstall

groupadd -g 1001 dba

useradd -u 1100 -g dba -G oinstall -d /export/home/grid -m grid

useradd -u 1101 -g dba -G oinstall -d /export/home/oracle -m oracle

2.设置password

passwd grid

passwd oracle

3.创建相应的目录

mkdir -p /oracle/app/grid

mkdir -p /oracle/app/11g

chown -R grid:dba /oracle/app/grid

chmod -R 775 /oracle/app/grid

mkdir -p ORACLE_BASE=/oracle/app/oracle

mkdir -p /oracle/app/oracle/product/11.2.0/dbhome_1

chown –R oracle:dba /oracle/app/oracle

4. grid user用的.profile文件

ORACLE_BASE=/oracle/app/grid; export ORACLE_BASE

ORACLE_HOME=/oracle/app/11g; export ORACLE_HOME

JAVA_HOME=$ORACLE_HOME/jdk; export JAVA_HOME

#ORACLE_PATH=/oracle/app/oracle/11g/common/oracle/sql; export ORACLE_PATH

ORACLE_SID=+ASM4; export ORACLE_SID

ORACLE_TERM=xterm; export ORACLE_TERM

NLS_DATE_FORMAT="DD-MON-YYYY HH24:MI:SS"; export NLS_DATE_FORMAT

TNS_ADMIN=$ORACLE_HOME/network/admin; export TNS_ADMIN

ORA_NLS11=$ORACLE_HOME/nls/data; export ORA_NLS11

PATH=$PATH:/usr/bin:/bin:/usr/bin/X11:/usr/local/bin:$JAVA_HOME/bin:$HOME/bin:$ORACLE_HOME/bin; export PATH

LD_LIBRARY_PATH=$ORACLE_HOME/lib:$ORACLE_HOME/oracm/lib:/lib:/usr/lib:/usr/local/lib

export LD_LIBRARY_PATH

CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib:$ORACLE_HOME/network/jlib; export CLASSPATH

NLS_LANG=American_america.zhs16gbk; export NLS_LANG

THREADS_FLAG=native; export THREADS_FLAG

TEMP=/tmp; export TEMP

TMPDIR=/tmp; export TMPDIR

# UMASK

umask 022

5. oracle用户的.profile文件

ORACLE_BASE=/oracle/app/oracle; export ORACLE_BASE

ORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1; export ORACLE_HOME

JAVA_HOME=$ORACLE_HOME/jdk; export JAVA_HOME

#ORACLE_PATH=/oracle/app/common/oracle/sql; export ORACLE_PATH

ORACLE_TERM=xterm; export ORACLE_TERM

ORACLE_SID=yxjb4; export ORACLE_SID

ORACLE_UNQNAME=yxjb; export ORACLE_UNQNAME

NLS_DATE_FORMAT="DD-MON-YYYY HH24:MI:SS"; export NLS_DATE_FORMAT

TNS_ADMIN=$ORACLE_HOME/network/admin; export TNS_ADMIN

ORA_NLS11=$ORACLE_HOME/nls/data; export ORA_NLS11

PATH=$PATH:/usr/bin:/bin:/usr/bin/X11:/usr/local/bin:$JAVA_HOME/bin:$HOME/bin:$ORACLE_HOME/bin; export PATH

LD_LIBRARY_PATH=$ORACLE_HOME/lib:$ORACLE_HOME/oracm/lib:/lib:/usr/lib:/usr/local/lib

export LD_LIBRARY_PATH

CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib:$ORACLE_HOME/network/jlib; export CLASSPATH

NLS_LANG=American_america.zhs16gbk; export NLS_LANG

THREADS_FLAG=native; export THREADS_FLAG

TEMP=/tmp; export TEMP

TMPDIR=/tmp; export TMPDIR

# UMASK

umask 022

6. 修改UDP-TCP的kernel参数

vi /etc/rc3.d/S99NddUDPTCP

#!/bin/sh

/usr/sbin/ndd -set /dev/tcp tcp_smallest_anon_port 9000

/usr/sbin/ndd -set /dev/tcp tcp_largest_anon_port 65500

/usr/sbin/ndd -set /dev/udp udp_smallest_anon_port 9000

/usr/sbin/ndd -set /dev/udp udp_largest_anon_port 65500 1.创建用户

chmod +x /etc/rc3.d/S99NddUDPTCP

6.设置主机的存储

根据具体存储进行设置,将原有ASM使用的磁盘在新节点上更改器属性,OCR的盘更改为grid:oinstall,数据盘更改为oracle:dba,这些盘都这对raw设备进行属性更改,读写属性都修改为660。

7.建立grid,oracle用户的ssh信任关系

具体如何建立ssh信任关系可以参考我的豆丁文档:

http://www.docin.com/p-656158896.html

二、        增加节点具体步骤:

准备工作完成后,就可以根据新环境将新节点增加到RAC系统了,RAC增加节点总共分为三步进行,第一步就是将clusterware软件系统进行扩展,将所有11g的clusterware软件添加到新节点,第二步就是将ORACLE数据库的软件扩展到新节点,最后一步就是使用dbca创建新节点的数据库实例instance。

1.         Clusterware软件扩展

软件的扩展就是在新节点上进行CRS软件的安装,此处无需使用原有的软件包来进行runInstaller的安装,只需要在现有的节点上执行脚本即可完成。

CRS软件的安装用户必须使用grid user,在10g里面还需要将CRS软件的home目录属性修改为grid的,使用完成后,在修改成root用户的。

以下为执行脚本的具体命令格式:

/oracle/app/11g/oui/bin/addNode.sh -silent "CLUSTER_NEW_NODES={cluster3}" "CLUSTER_NEW_VIRTUAL_HOSTNAMES={cluster3-vip}"

命令里面只需要将两个option的值改成新节点主机就可以直接执行了,具体的过程可以参考文档后面的附件一。

根据提示执行root.sh脚本将新节点加入到CRS中去,执行完成后就可以使用crs_stat –t命令查看新节点的crs状态了,root.sh脚本执行情况查阅文档后面的附件二。

2.         ORACLE数据库软件的扩展

使用oracle用户登录,执行以下脚本,该脚本能够将RAC群集节点上正常节点上的所有软件包远程拷贝到新节点上,无需做其他任何多余操作。

$  /oracle/app/oracle/product/11.2.0/dbhome_1/oui/bin/addNode.sh

该脚本运行过程可查阅附件三。

3.         DBCA创建cluster实例

当CRS和ORACLE数据库软件扩展到新节点后,crs_stat –t 显示三个节点都正常后,就可以直接使用dbca来创建第三个节点上的数据库实例了,这步骤就比较简单了,但需要注意的时候,dbca图形界面启动后,一定要选择 instance manager,后面选择add instance,后面就是next即可。

ORACLE RAC如何增加节点的更多相关文章

  1. Oracle 11g rac 添加新节点测试

    [转]https://blog.csdn.net/shiyu1157758655/article/details/60877076 前期准备: 操作系统设置OS版本必须相同,检查内核参数,系统内存.C ...

  2. oracle RAC的VIP和scan

    我们都知道Oracle RAC中每个节点都有一个虚拟IP,简称VIP,与公网IP在同一个网段. 没有VIP时,Oracle客户端是靠"TCP/IP协议栈超时"来判断服务器故障.而T ...

  3. Oracle RAC学习笔记:基本概念及入门

    Oracle RAC学习笔记:基本概念及入门 2010年04月19日 10:39 来源:书童的博客 作者:书童 编辑:晓熊 [技术开发 技术文章]    oracle 10g real applica ...

  4. 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:4.安装Oracle RAC FAQ-4.3.Oracle 集群节点间连通失败

    1.检查节点连通性的错误 [grid@linuxrac1 grid]$ ./runcluvfy.sh stage -post hwos -n linuxrac1,linuxrac2 -verbose ...

  5. [学习]仿照cnblog 搭建 Oracle RAC 双节点 困.. 后续做不下去了..

    1. 学习地址: https://blog.csdn.net/yuzifen?t=1 2. 克隆之前创建好的虚拟机: 3. 给虚拟机增加新的硬盘. 注意事项 1) 必须是厚置备的磁盘才可以. 2) 必 ...

  6. Oracle RAC集群添加节点

    一,节点环境 所有节点分发/etc/hosts,这里我添加两个节点,一个是上次删除的节点,另一个是什么都没有的节点,尝试添加 服务器介绍什么的都在这hosts文件了,大家自己琢磨下 [grid@nod ...

  7. Oracle RAC客户端tnsnames.ora相关配置及测试

    1.Oracle RAC服务端/etc/hosts部分内容如下 2.查看服务端的local_listener和remote_listener参数 3.客户端tnsnames.ora配置参考 3.1 1 ...

  8. Oracle RAC安装部署文档

    1.    部署环境步骤 1.1 软件环境 操作系统:CentOS release 6.5(推荐使用5.*的系统)192.168.1.151    racnode1 192.168.1.152    ...

  9. oracle rac安装

    http://blog.chinaunix.net/xmlrpc.php?r=blog/article&id=4681351&uid=29655480 参考 1.百度文库中的收藏 2. ...

随机推荐

  1. caffe-ssd使用预训练模型做目标检测

    首先参考https://www.jianshu.com/p/4eaedaeafcb4 这是一个傻瓜似的目标检测样例,目前还不清楚图片怎么转换,怎么验证,后续继续跟进 模型测试(1)图片数据集上测试 p ...

  2. No changes detected or App 'blog' could not be found. Is it in INSTALLED_APPS?

    出现该问题的原因: django没有在setting.py的配置文件中找到app内容,需要增加app的名称 E:\PycharmProjects\Mysite>python manage.py ...

  3. Binary Indexed Tree 总结

    特点 1. 针对 数组连续子序列累加和 问题(需要进行频繁的 update.sum 操作): 2. 并非是树型结构,只是逻辑上层次分明: 3. 可以通过 填坑法 来理解: 4. 中心思想:每一个整数都 ...

  4. 3.linux(ubuntu)常用服务器搭建

    1 ftp 1.1 ftp服务器 1.安装vsftpd服务器 sudo apt-get install vsftpd 2.配置vsftpd.conf文件 sudo vi /etc/vsftpd.con ...

  5. 计算机基础--http的基础整理和巩固

    一.前言 主要包括:1.http基础:TCP/IP,TCP协议,IP协议,DNS协议,URI与URL: 2.http协议:http报文,http方法,http状态码,常见问题 名词解释: (1)HTT ...

  6. USACO Sabotage, 2014 Mar 破坏阴谋(二分+贪心)

    一开始看完这题就有个想法: 只要把大于整个序列平均数的最大连续序列就是最优? 那把整个序列都减掉平均数 在做最大连续字序列和且记录长度? 仔细思考一下并不太对: 当子序列最大但长度较大 也许也比不上删 ...

  7. WEB前端开发常用的优化技巧汇总

    减少HTTP请求次数或者减少请求数据的大小 页面中每发送一次HTTP请求,都需要完成请求+响应这个完整的HTTP事务,会消耗一些时间,也可能会导致HTTP链接通道的堵塞,为了提高页面加载速度和运行的性 ...

  8. canvas制作刮刮乐案例

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. quartz定时任务框架调度机制解析

    转自集群调度机制调研及源码分析 quartz2.2.1集群调度机制调研及源码分析引言quartz集群架构调度器实例化调度过程触发器的获取触发trigger:Job执行过程:总结:附: 引言 qurat ...

  10. poj 2828 Buy Tickets【线段树 单点更新】

    倒着插,先不理解意思,后来看一篇题解说模拟一下 手动模拟一下就好理解了----- 不过话说一直写挫---一直改啊----- 好心塞------ #include <cstdio> #inc ...