Oracle12C R2+RAC安装测试

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle12C R2+RAC安装测试相关的知识,希望对你有一定的参考价值。

Oracle12C R2已经出来有一段时间了,一直想搞搞RAC可是由于安装Oracle12C R2 RAC对系统资源的高要求,使得每次在自己的虚拟机上安装都失败(失败的原因主要是由于内存太小所致),前几天在工作不忙的时候打开计算机啥也不做,就开几个虚拟机做RAC实验,最后也算成功了;---我自己的笔记本内存16G I7的内核

1、环境准备:

操作系统:Linux7.2-64

软件:linuxx64_12201_database 

     linuxx64_12201_grid_home             

 ASM磁盘组:使用裸设备

Oracle12C R2+RAC

安装介质:

软件包

名称

Linux7.164

操作系统

linuxx64_12201_database

数据库软件包

 linuxx64_12201_grid_home

数据库集群软件

ASM磁盘

共享存储

 

IP分配:

主机名

主机IP

PRIV

VIP

rac1

192.168.2.100

10.0.0.1

192.168.2.101

rac2

192.168.2.200

10.0.0.2

192.168.2.201

sacnIP

192.168.2.210



ISCSI服务器IP

192.168.2.88

两个节点只需配置公网和私有IP即可,虚拟IPscanIPhosts文件指定

 

安装目录:

Oracle软件

/opt/oracle/product/12/db

grid 软件

/opt/12/grid

CRS 软件

+DATT/testa/


---注明下:我做实验使用的共享存储盘  是采用ISCSI,单独开了一台服务器做的,本次做测试一共开了3台虚拟机(两台数据库主机各6G内存,ISCSI服务器500M)
ISCSI服务器共享存储配置步骤省略,需要用到的命令如下:

客户端发现目标服务器共享磁盘:

[[email protected] Server]# iscsiadm -m discovery -t sendtargets -p192.168.2.88

挂载目标服务器共享磁盘

[[email protected] ~]# iscsiadm -m node --loginall=all


2、开始部署RAC

2.1修改主机/etc/host解析文件(两节点都修改)

 [[email protected]~]# vim /etc/hosts

# Do not remove the following line, or various programs

# that require network functionality will fail.

127.0.0.1               localhost

::1            localhost6.localdomain6 localhost6

192.168.2.100   rac121

192.168.2.101  rac121-vip

10.0.0.1       rac121-priv

192.168.2.200   rac122

192.168.2.201  rac122-vip

10.0.0.2       rac122-priv

192.168.2.210  scan-rac

[[email protected] ~]# vim /etc/hosts

# Do not remove the following line, or various programs

# that require network functionality will fail.

127.0.0.1               localhost

::1            localhost6.localdomain6 localhost6

192.168.2.100   rac121

192.168.2.101  rac121-vip

10.0.0.1      rac121-priv

192.168.2.200   rac122

192.168.2.201  rac122-vip

10.0.0.2       rac122-priv

192.168.2.210  scan-rac

2.2 安装所需软件包(两个节点都执行)

[[email protected] Packages]# yum -y install binutils*glibc* libstdc* libaio* libX* make* sysstat* compat-* glibc-* unix*

2.3.修改linux内核参数(两个节点都执行)

 [[email protected]~]# vi/etc/sysctl.conf   (要根据自己服务器的内存合理配置)

----------------------------------------------

添加以下内容:--具体的大小值 由自己的内存决定,自行调整

fs.aio-max-nr =1048576

fs.file-max =6815744

kernel.shmall =2097152

kernel.shmmax = 2147483648

kernel.shmmni =4096

kernel.sem = 25032000 100 128

net.ipv4.ip_local_port_range= 9000 65500

net.core.rmem_default= 262144

net.core.rmem_max= 4194304

net.core.wmem_default= 262144

net.core.wmem_max= 1048586

 

 

 [[email protected]~]# sysctl -p --使设置生效

2.4 修改系统参数(两个节点都执行)

[[email protected] ~]# vim /etc/pam.d/login

session    required     pam_limits.so

 

[[email protected] ~]# vim /etc/pam.d/login

session    required     pam_limits.so

2.5 创建oraclegrid用户(两个节点都执行)

创建oracle用户与grid用户

[[email protected] ~]# groupadd -g400 oinstall

[[email protected] ~]# groupadd -g 401 dba

[[email protected] ~]# groupadd -g 402 asmadmin

[[email protected] ~]# groupadd -g 403 asmdba

[[email protected] ~]# groupadd -g 404 asmoper

[[email protected] ~]# groupadd -g 405 oper

[[email protected] ~]# useradd -u 400 -g oinstall -Gasmadmin,asmdba,asmoper,dba grid

[[email protected] ~]# useradd -u 401 -g oinstall -Gdba,asmdba,asmadmin,oper oracle

# passwd oracle 

# passwd grid

2.6 设置oracle用户与grid用户参数限制(两个节点都要做)

[[email protected] ~]# vim /etc/security/limits.conf

oracle         soft    nproc   2047

oracle         hard    nproc   16384

oracle         soft    nofile  1024

oracle         hard    nofile  65536做

grid              soft    nproc   2047

grid           hard    nproc   32768

grid           soft    nofile  1024

grid           hard    nofile  65536

2.7 创建oracle用户与grid用户所需目录(两个节点都执行)

[[email protected] ~]# mkdir -p /opt/grid                  

[[email protected] ~]# mkdir -p /opt/12/grid                

[[email protected] ~]# mkdir -p /opt/oracle/product/12/db  

[[email protected] ~]# mkdir -p /opt/oracle/oradata        

[[email protected] ~]# chown -R grid.oinstall /opt/grid    

[[email protected] ~]# chown -R grid.oinstall /opt/12

[[email protected] ~]# chown -R oracle.oinstall /opt/oracle/

[[email protected] ~]# chmod -R 775 /opt/   

2.8 分别设置oracle用户和grid用户环境变量:(两个节点都执行)

第一个节点:Oracle环境变量

export PATH

export ORACLE_BASE=/opt/oracle

export ORACLE_HOME=/opt/oracle/product/12/db

export ORACLE_SID=testdb

export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin:$ORACLE_HOME/OPatch

export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib

第一个节点:grid环境变量

export ORACLE_BASE=/opt/grid

export ORACLE_HOME=/opt/12/grid

export ORACLE_SID=+ASM1

export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin:$ORACLE_HOME/OPatch

 

第二个节点:Oracle环境变量

export PATH

export ORACLE_BASE=/opt/oracle

export ORACLE_HOME=/opt/oracle/product/12/db

export ORACLE_SID=testdb

export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin:$ORACLE_HOME/OPatch

export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib

 

第二个节点:grid环境变量

export ORACLE_BASE=/opt/grid

export ORACLE_HOME=/opt/12/grid

export ORACLE_SID=+ASM2

export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin:$ORACLE_HOME/OPatch

2.9 配置rac1rac2两个节点的SSH互信关系(两个节点都执行)

配置两个节点SSH信任:

[[email protected] ~]# su - oracle

[[email protected] ~]$ mkdir ~/.ssh

[[email protected] ~]$ chmod 700 ~/.ssh/

[[email protected] ~]$ cd ~/.ssh/

[[email protected] .ssh]$ ssh-keygen -t rsa

[[email protected] .ssh]$ ssh-keygen -t dsa

[[email protected] .ssh]$ cat id_rsa.pub >> authorized_keys

[[email protected] .ssh]$ cat id_dsa.pub >> authorized_keys

 

[[email protected] ~]# su – grid

[[email protected] ~]$ mkdir ~/.ssh

[[email protected] ~]$ cd ~/.ssh/

[[email protected] .ssh]$ cd ..

[[email protected] ~]$ chmod 700 ~/.ssh/

[[email protected] ~]$ cd ~/.ssh/

[[email protected] .ssh]$ ssh-keygen -t rsa

[[email protected] .ssh]$ ssh-keygen -t dsa

[[email protected] .ssh]$ cat id_rsa.pub >> authorized_keys

[[email protected] .ssh]$ cat id_dsa.pub >> authorized_keys

(节点二也要执行上述操作,然后将两个节点的公钥与私钥进行整合,分别拷贝到两个节点中)

完成后进行测试,是否成功

在两个节点切换到oraclegrid用户执行下属操作,(不输入密码就成功验证)

[[email protected] ~]# su - oracle

[[email protected] ~]$ ssh rac1 date

Thu Nov 27 04:56:46 EST 2014

[[email protected] ~]$ ssh rac2 date

Thu Nov 27 04:56:48 EST 2014

[[email protected] ~]$ ssh rac1-priv date

Thu Nov 27 04:56:54 EST 2014

[[email protected] ~]$ ssh rac2-priv date

Thu Nov 27 04:56:57 EST 2014

3、挂载共享磁盘(在两个节点依次执行)

 客户端发现目标服务器共享磁盘:

[[email protected] Server]# iscsiadm -m discovery -t sendtargets -p192.168.2.88

 挂载目标服务器共享磁盘

[[email protected] ~]# iscsiadm -m node --loginall=all

3.1、设置可用的ASM磁盘

[[email protected]~]# vim  hao.sh   ---编辑脚本

for i in c d e f g j h i j

do 

echo "KERNEL==\"sd?\",SUBSYSTEM==\"block\", PROGRAM==\"/usr/lib/udev/scsi_id--whitelisted --replace-whitespace --device=/dev/\$name\",RESULT==\"`/usr/lib/udev/scsi_id --whitelisted --replace-whitespace--device=/dev/sd$i`\", SYMLINK+=\"asm-disk$i\",OWNER=\"grid\", GROUP=\"asmadmin\",MODE=\"0660\"" 

done

 

[[email protected]~]# sh hao.sh    ----执行脚本

运行脚本得到如下内容:

KERNEL=="sd?", SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id --whitelisted --replace-whitespace--device=/dev/$name",RESULT=="14945540000000000ef376caea6d46a84b299aa2af675ec33",SYMLINK+="asm-diskc", OWNER="grid",GROUP="asmadmin", MODE="0660"

KERNEL=="sd?", SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id --whitelisted --replace-whitespace--device=/dev/$name",RESULT=="1494554000000000046b356d577df32a8ebb1bc37aa63263b",SYMLINK+="asm-diskd", OWNER="grid",GROUP="asmadmin", MODE="0660"

KERNEL=="sd?", SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id --whitelisted --replace-whitespace--device=/dev/$name",RESULT=="149455400000000000dbef13af1d00493893edc4ce2ba0109",SYMLINK+="asm-diske", OWNER="grid",GROUP="asmadmin", MODE="0660"

KERNEL=="sd?", SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id --whitelisted --replace-whitespace--device=/dev/$name",RESULT=="14945540000000000fa5fccd4e81b51abc3795d66e58fb835",SYMLINK+="asm-diskf", OWNER="grid",GROUP="asmadmin", MODE="0660"

KERNEL=="sd?", SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id --whitelisted --replace-whitespace--device=/dev/$name",RESULT=="14945540000000000545ef7c7a91cd370b7287e7498981e57",SYMLINK+="asm-diskg", OWNER="grid", GROUP="asmadmin",MODE="0660"

KERNEL=="sd?", SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id --whitelisted --replace-whitespace--device=/dev/$name",RESULT=="1494554000000000078e745363d1683b432ae66cb39a2171d",SYMLINK+="asm-diskj", OWNER="grid", GROUP="asmadmin",MODE="0660"

KERNEL=="sd?", SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id --whitelisted --replace-whitespace--device=/dev/$name",RESULT=="1494554000000000024c7e5803c9b66544cbc6e847bc36dcd",SYMLINK+="asm-diskh", OWNER="grid", GROUP="asmadmin",MODE="0660"

KERNEL=="sd?", SUBSYSTEM=="block", PROGRAM=="/usr/lib/udev/scsi_id--whitelisted --replace-whitespace --device=/dev/$name",RESULT=="14945540000000000a633b36c46b565abe1bf9735cc854e85",SYMLINK+="asm-diski", OWNER="grid",GROUP="asmadmin", MODE="0660"

KERNEL=="sd?", SUBSYSTEM=="block", PROGRAM=="/usr/lib/udev/scsi_id--whitelisted --replace-whitespace --device=/dev/$name",RESULT=="1494554000000000078e745363d1683b432ae66cb39a2171d",SYMLINK+="asm-diskj", OWNER="grid",GROUP="asmadmin", MODE="0660”

 

然后将上面的内容添加到系统文件:

[[email protected]~]# vim /etc/udev/rules.d/70-persistent-ipoib.rules

 

运行系统命令重新扫描磁盘:

[[email protected] ~]# partprobe

 

然后查看裸设备是否创建成功

[[email protected] ~]# ls -l /dev/sd*


4、安装grid软件:

注意:grid软件要解压到 grid用户的家目录,我们本次环境的home目录:

export ORACLE_HOME=/opt/12/grid

所以,把软件放到/opt/12/grid目录下,然后解压就可以了:

[[email protected] ~]$ cd /opt/12/grid/

[[email protected] grid]$ unzip  linuxx64_12201_grid_home


4.1、开始安装grid软件,如下所示:


技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享


出现上述图后,需要在两个节点执行脚本;

每个脚本依次在节点1和节点2上执行:

执行第二个脚本最后出现下图结构就说明执行成功了:

技术分享

执行完脚本以后,这些往下执行就可以:

技术分享

技术分享

技术分享

当我们执行完成后,如上图所示可能会报错,不过经过查看日志我们发现这个错没关系,可以忽略;

检查grid状态:---从下面的信息可以看到 我们安装的没有问题

[[email protected] ~]$crs_stat -t

Name           Type           Target    State    Host       

------------------------------------------------------------

ora....SM.lsnrora....er.type ONLINE    ONLINE    rac121     

ora.DATA.dg    ora....up.type ONLINE    ONLINE   rac121     

ora....ER.lsnrora....er.type ONLINE    ONLINE    rac121     

ora....AF.lsnrora....er.type OFFLINE   OFFLINE              

ora....N1.lsnrora....er.type ONLINE    ONLINE    rac121     

ora.MGMTLSNR   ora....nr.type ONLINE    ONLINE   rac121     

ora.asm        ora.asm.type   ONLINE   ONLINE    rac121     

ora.chad       ora.chad.type  ONLINE   ONLINE    rac121     

ora.cvu        ora.cvu.type   ONLINE   ONLINE    rac121     

ora.mgmtdb     ora....db.type ONLINE    ONLINE   rac121     

ora....networkora....rk.type ONLINE    ONLINE    rac121     

ora.ons        ora.ons.type   ONLINE   ONLINE    rac121     

ora.proxy_advmora....vm.type OFFLINE   OFFLINE              

ora.qosmserverora....er.type ONLINE    ONLINE    rac121     

ora....21.lsnrapplication    ONLINE    ONLINE   rac121     

ora.rac121.onsapplication    ONLINE    ONLINE   rac121     

ora.rac121.vipora....t1.type ONLINE    ONLINE    rac121     

ora....22.lsnrapplication    ONLINE    ONLINE   rac122     

ora.rac122.onsapplication    ONLINE    ONLINE   rac122     

ora.rac122.vipora....t1.type ONLINE    ONLINE    rac122     

ora.scan1.vip  ora....ip.type ONLINE    ONLINE   rac121     

[[email protected] ~]$


4.3、使用grid用户创建ASM磁盘组:

[[email protected] ~]$  /opt/12/grid/bin/asmca   ---执行命令

技术分享

技术分享

技术分享

从上面的图我们可以看到,我们需要的ASM磁盘组已经创建好了,接着安装Oracle软件即可:


5、使用Oracle用户开始,首先安装Oracle软件:

解压软件后开始安装,如下图所示:

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

安装上图的提示,执行root.sh脚本即可,然后会看到下图安装成功的提示:

技术分享


5.2、使用DBCA创建数据库:


技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享


至此安装步骤已经完整了,就等着安装完成就可以了,



本文出自 “笨小孩的dba之路” 博客,请务必保留此出处http://fengfeng688.blog.51cto.com/4896812/1935075

以上是关于Oracle12C R2+RAC安装测试的主要内容,如果未能解决你的问题,请参考以下文章

ORACLE 12C 三节点 RAC 安装报错 [INS-32025]

Oracle12c:安装后新建用户及其默认表空间,并创建表测试

Vagrant 安装Oracle19c RAC测试环境的简单学习

oracle 12c r2 rac + ORA-28040

ORACLE 12C R2 RAC实战首发

Oracle 12C RAC集群搭建