Merhaba Arkadaşlar,

Bu yazımda sizlere 2 Nodelu Oracle RAC ( Real Application Cluster ) veritabanında 1 olan controlfile dosyasının çoklanmasını anlatacağım. Controlfile ile ayrıntılı bilgiyi bu linkteki yazımdan bulabilirsiniz.Oracle Controlfile

Production ortamında bulunan veritabanlarının beyni niteliğinde görev yapan Controlfile dosyasının sayısı mutlaka 2 yada daha fazla olmalıdır. Çok kritik bir role sahip bu dosyanın her birinin farklı disk grubunda olması çok çok önemlidir. Çünkü olası bir Disk corruption problemi durumunda zarar gören yada kaybolan controlfile ın yerine diğer disk grubunda bulunan Controlfile devreye girecektir. Bu durum olası kötü senaryolara karşı önemli bir tedbirdir.

Şimdi 1 adet controlfile dosyası bulunan 2 nodelu RAC bir database in Controlfile ını aşağıdaki adımlarla 2 ye çıkarabilirsiniz. +DATA ASM ( Automatic Storage Management ) Disk grubunda bulunan orjinal controlfile dosyasının 2.adetini de yine shared alan olan +RECO ASM disk grubuna koymamız gerekmektedir.

İlk olarak instance adını aşağıdaki gibi sorguluyoruz.

SQL> select instance_name from v$instance;
INSTANCE_NAME
 ----------------
 POCDB1

Veritabanının orjinal controlfile dosyasını aşağıdaki gibi sorgulayabiliriz.

SQL> show parameter control_file
NAME TYPE VALUE
 ------------------------------------ ----------- ------------------------------
 control_file_record_keep_time integer 7
 control_files string +DATA/POCDB/controlfile/current.256.847487823

 

Sunucu üzerindeki Disk gruplarını aşağıdaki gibi kontrol edip Controlfile için alternatif disk grubu bakıyoruz. Aşağıdaki gibi +RECO disk grubuna Controlfile ı çoklayabiliriz.

oracle:oraserver01:/home/users/oracle:>asmcmd
 ASMCMD> lsdg
 State Type Rebal Sector Block AU Total_MB Free_MB Req_mir_free_MB Usable_file_MB Offline_disks Voting_files Name
 MOUNTED EXTERN N 512 4096 1048576 512000 510551 0 510551 0 N DATA/
 MOUNTED EXTERN N 512 4096 4194304 204800 203272 0 203272 0 Y RECO/
 ASMCMD>

 

Şimdi statik olan Control_files parametresini aşağıdaki gibi değiştiriyoruz. Virgülden önceki orjinal Controlfile dosyası ve virgülden sonra ise yeni controlfile dosyasının yerini +RECO olarak gösterdim. Bu parametrenin değerini aşağıdaki script ile her iki instanceda değişmesini sağlıyoruz. Ancak etkisini veritabanını restart ettikten sonra görebiliriz.

 SQL> alter system set control_files='+DATA/POCDB/controlfile/current.256.847487823', '+RECO' scope=spfile sid='*';
System altered.

 

Şimdi değiştirdiğimiz parametre için instanceları aşağıdaki gibi kapatıyoruz.

srvctl stop database -d POCDB

Kapattığımız instanceları aşağıdaki gibi nomount mode da açıyoruz.

srvctl start database -d POCDB -o nomount

Değiştirdiğimiz parametreyi aşağıdaki gibi sorguladığımızda spfile da ilgili parametrenin değiştiğini görüyoruz.

SQL> show parameter control_files
NAME TYPE VALUE
 ------------------------------------ ----------- ------------------------------
 control_files string +DATA/POCDB/controlfile/current.256.847487823, +RECO

Şimdi RMAN tooluna bağlanıp mevcut controlfile ı restore ediyoruz. Restore ettiğimiz zaman aşağıdaki gibi +DATA ve +RECO disk grubundada Controlfile dosyasının fiziksel halinin restore edildiğini görebilirsiniz.

connected to target database: POCDB (not mounted)
RMAN> restore controlfile from '+DATA/POCDB/controlfile/current.256.847487823';
Starting restore at 14-MAY-14
using target database control file instead of recovery catalog
 allocated channel: ORA_DISK_1
 channel ORA_DISK_1: SID=853 instance=POCDB1 device type=DISK
channel ORA_DISK_1: copied control file copy
 output file name=+DATA/POCDB/controlfile/current.256.847487823
 output file name=+RECO/POCDB/controlfile/current.263.847536995
 Finished restore at 14-MAY-14
RMAN>

 

Şimdi fiziksel olarak oluşturduğumuz Yeni Controlfile dosyasını eskisiyle beraber spfile dosyasında aşağıdaki gibi güncelliyoruz. Böylece veritabanı ilk başlatıldığı sırada her iki controlfile dosyasını kullanarak başlayacaktır.

 SQL> alter system set control_files='+DATA/POCDB/controlfile/current.256.847487823', +RECO/POCDB/controlfile/current.263.847536995'  scope=spfile sid='*';

 

Parametreyi değiştirdikten sonra nomount modda olan POCDB veritabanı instancelarını aşağıdaki gibi kapatabilirsiniz.

 

oracle:oraserver01:/home/users/oracle:>srvctl stop database -d POCDB

Kapattığımız veritabanı instancelarını aşağıdaki gibi tekrar açıyoruz.

 oracle:oraserver01:/home/users/oracle:>srvctl start database -d POCDB

 

Veritabanı instanceları açıldıktan sonra tekrar kontrol ettiğimiz zaman veritabanının her iki controlfile ıda kullandığını görüyoruz.

 

SQL> select instance_name from v$instance;
INSTANCE_NAME
 ----------------
 POCDB1
 SQL> show parameter control_files
NAME TYPE VALUE
 ------------------------------------ ----------- ------------------------------
 control_files string +DATA/POCDB/controlfile/current.256.847487823, +RECO/POCDB/controlfile/current.263.847536995

Böylece 2 nodelu POCDB RAC veritabanının kullanmış olduğu tek controlfile dosyasını 2 olarak çoklamış olduk. Bir sonraki yazıda görüşmek dileğiyle esen kalın.

Mehmet Salih DEVECİ

Oracle Veritabanı Yöneticisi

 

Reklamlar

Bir Cevap Yazın

Aşağıya bilgilerinizi girin veya oturum açmak için bir simgeye tıklayın:

WordPress.com Logosu

WordPress.com hesabınızı kullanarak yorum yapıyorsunuz. Çıkış  Yap / Değiştir )

Twitter resmi

Twitter hesabınızı kullanarak yorum yapıyorsunuz. Çıkış  Yap / Değiştir )

Facebook fotoğrafı

Facebook hesabınızı kullanarak yorum yapıyorsunuz. Çıkış  Yap / Değiştir )

Google+ fotoğrafı

Google+ hesabınızı kullanarak yorum yapıyorsunuz. Çıkış  Yap / Değiştir )

Connecting to %s