千家信息网

Oracle 10g RAC 加入新节点

发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,1、在一台裸机上安装Linux系统c3,准备让其加入c1,c2两节点的rac环境要有两个网卡eth0,eth2(略)2、调整/etc/hosts文件将三个节点都变成如下127.0.0.1localho
千家信息网最后更新 2025年01月22日Oracle 10g RAC 加入新节点

1、在一台裸机上安装Linux系统c3,准备让其加入c1,c2两节点的rac环境

要有两个网卡eth0,eth2

(略)

2、调整/etc/hosts文件

将三个节点都变成如下

127.0.0.1localhost

192.168.33.101c1
192.168.33.201c1-vip
10.0.0.2c1-priv

192.168.33.102c2
192.168.33.202c2-vip
10.0.0.3c2-priv

192.168.33.103c3
192.168.33.203c3-vip
10.0.0.4c3-priv

10.0.0.1san


3、配置hangcheck-timer:用于监视 Linux 内核是否挂起
vim /etc/modprobe.conf


options hangcheck-timer hangcheck_tick=30 hangcheck_margin=180

4、自动加载hangcheck-timer 模块/u01/app/oracle/product/10.2.0/db_1
vim /etc/rc.local
modprobe hangcheck-timer
检查hangcheck-timer模块是否已经加载:
lsmod | grep hangcheck_timer


5、创建组dba & oinstall,创建用户oracle
groupadd oinstall

groupadd dba

usreadd -g oinstall -G dba oracle

6、配置集群互信
在新节点创建key:
su - oracle
ssh-keygen -t rsa
ssh-keygen -t dsa
cd .ssh
cat *.pub >> authorized_keys

然后三个节点进行轮流追加(略)

7、c3配置ntp

vim /etc/ntp.conf
--------------------------------------
server 192.168.0.253
restrict 192.168.0.253 mask 255.255.255.255 nomodify notrap noquery

crontab -e

*/5 * * * * /usr/sbin/ntpdate san

8、导入san存储

yum install iscsi-initiator-utils -y
service iscsid start
iscsiadm -m discovery -t st -p san
service iscsi start
chkconfig iscsid on
chkconfig iscsi on

9、用udev进行绑定

vim /etc/udev/rules.d/60-raw.rules

ACTION=="add", KERNEL=="sdf1", RUN+="/bin/raw /dev/raw/raw1 %N"
ACTION=="add", KERNEL=="sdg1", RUN+="/bin/raw /dev/raw/raw2 %N"

KERNEL=="raw1", OWNER="oracle", GROUP="oinstall", MODE="660"
KERNEL=="raw2", OWNER="oracle", GROUP="oinstall", MODE="660"

然后启动udev

start_udev

9.5、为了将来在c3上开启实例方便

可以直接拷贝c1的

/etc/sysctl.conf

/etc/security/limits.conf

/home/oracle/.bashrc

然后进行相应的修改

10、检查集群节点

cd /soft/clusterware/cluvfy/
./runcluvfy.sh stage -pre crsinst -n c1,c2,c3 -verbose

11、添加clusterware

从老节点启动添加节点向导:

cd /u01/crs_1/oui/bin/

./addNode.sh

在Specify Cluster Nodes to Add to Installation页

加入c3,c3-priv,c3-vip信息

执行三个脚本

c3上执行

/u01/app/oracle/oraInventory/orainstRoot.sh

c1上执行

/u01/crs_1/install/rootaddnode.sh

c3上执行

/u01/crs_1/root.sh

12、添加数据库软件

cd /u01/app/oracle/produt/10.2.0/db1/oui/bin/

./addNode.sh

在Specify Cluster Nodes to Add to Installation页

勾选c3

执行一个脚本

在c3上执行

/u01/app/oracle/product/10.2.0/db_1/root.sh

13、配置监听

在老节点c1启动netca

选择Cluster configuration

选择c3节点

Listener configuration

Add

LISTENER

TCP

Use the standard port number of 1521

14、扫描ASM磁盘

在c3安装oracleasmlib、oracleasm、oracle-support包

/etc/init.d/oracleasm configure

/etc/init.d/oracleasm scandisks

15、启动dbca配置ASM实例

Configure Automatic Storage Management

选择c1和c3(c1是自动选择的)

16、添加实例

还是使用dbca

Instance Management

Add Instance

确认左侧的Database Services是一个服务,

右侧的实例是三个,都选择Preferred,TAF选择Basic

完成

17、启动新实例

在16步完成后可能会无法启动实例3,下面需要这样几步来修改

在c1实例上

ALETR SYSTEM SET CLUSETER_DATABASE_INSTANCES=3 SCOPE=SPFILE;

CREATE PFILE='/tmp/init.ora' FROM SPFILE;

把pfile拷贝到c3上

scp /tmp/init.ora c3:/tmp/init.ora

在c3主机上

修改内容

kdata1.__db_cache_size=352321536
kdata2.__db_cache_size=356515840
kdata3.__db_cache_size=352321536
kdata2.__java_pool_size=4194304
kdata1.__java_pool_size=4194304
kdata3.__java_pool_size=4194304
kdata2.__large_pool_size=4194304
kdata1.__large_pool_size=4194304
kdata3.__large_pool_size=4194304
kdata1.__shared_pool_size=230686720
kdata2.__shared_pool_size=226492416
kdata3.__shared_pool_size=226492416
kdata2.__streams_pool_size=0
kdata1.__streams_pool_size=0
kdata3.__streams_pool_size=0
*.audit_file_dest='/u01/app/oracle/admin/kdata/adump'
*.background_dump_dest='/u01/app/oracle/admin/kdata/bdump'
*.cluster_database_instances=3
*.cluster_database=true
*.compatible='10.2.0.1.0'
*.control_files='+AS/kdata/controlfile/current.268.803056777'#Restore Controlfile
*.core_dump_dest='/u01/app/oracle/admin/kdata/cdump'
*.db_block_size=8192
*.db_create_file_dest='+AS'
*.db_create_online_log_dest_1='+AS'
*.db_domain=''
*.db_file_multiblock_read_count=16
*.db_name='kdata'
*.dispatchers='(PROTOCOL=TCP) (SERVICE=kdataXDB)'
kdata1.instance_number=1
kdata2.instance_number=2
kdata3.instance_number=3

*.job_queue_processes=10
*.log_archive_dest='+AS'
*.open_cursors=300
*.pga_aggregate_target=199229440
*.processes=150
*.remote_listener='LISTENERS_kdata'
*.remote_login_passwordfile='exclusive'
*.sga_target=599785472
kdata2.thread=2
kdata1.thread=1
kdata3.thread=3
*.undo_management='AUTO'
kdata1.undo_tablespace='UNDOTBS1'
kdata2.undo_tablespace='UNDOTBS2'
kdata3.undo_tablespace='UNDOTBS3'
*.user_dump_dest='/u01/app/oracle/admin/kdata/udump'

在c3上

STARTUP PFILE='/tmp/init.ora'

在c3上

CREATE SPFILE='+AS/KDATA/spfilekdata.ora' FROM PFILE='/tmp/init.ora';

在c3上修改initkdata3.ora

SPFILE='+AS/KDATA/spfilekdata.ora'

至此,所有的部分都修改完毕。


0