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.
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.
Oracle Exadata SQL Server Goldengate Weblogic EBS ve Linux konusunda aşağıdaki konularda 7×24 Uzman Danışmanlara yada Eğitimlere mi İhtiyacınız var [email protected] adresine mail atarak Bizimle iletişime geçebilirsiniz.
– Oracle Veritabanı Danışmanlığı
– Oracle Veritabanı Bakım ve Destek
– Exadata Danışmanlığı
– Exadata Bakım ve Destek
– SQL Server Veritabanı Danışmanlığı
– SQL Server Veritabanı Bakım ve Destek
– Goldengate Danışmanlığı
– Goldengate Bakım ve Destek
– Linux Danışmanlığı
– Linux Bakım ve Destek
– Oracle EBS Danışmanlığı
– Oracle EBS Bakım ve Destek
– Weblogic Danışmanlığı
– Weblogic Bakım ve Destek
– Oracle Veritabanı Eğitimleri
– Oracle VM Server Danışmanlığı
– Oracle VM Server Bakım ve Destek
– Oracle EPPM Danışmanlığı
– Oracle EPPM Bakım ve Destek
– Oracle Primavera Danışmanlığı
– Oracle Primavera Bakım ve Destek
– Oracle Eğitimleri
– SQL Server Eğitimleri
– Goldengate Eğitimleri
– Exadata Eğitimleri
– Linux Eğitimleri
– Oracle EBS Eğitimleri
– Oracle VM Server Eğitimleri
– Weblogic Eğitimleri
– Oracle EPPM Eğitimleri
– Oracle Primavera Eğitimleri