【RAC】如何修改vip 或者vip 對應的hostname
在oracle 10g 和 11g 的Clusterware 環境中,客戶端使用vip(Virtual IP)來連線資料庫,客戶端應用程式透過vip訪問對應的節點上的資料庫例項。每個節點都要有一個vip,這些vip是靜態的ip地址,必須與公共網路屬於同一個子網。每一個vip也要對應一個主機名,而且對於客戶端來說,這個主機名應該能夠被解析為VIP.VIP透過DNS,/etc/hosts檔案來解析(11GR2 可以使用GNS),在安裝GI軟體時候,會提示為每一個節點填寫對應的VIP和VIP對應的hostname,vip資訊會儲存在OCR和HA架構相關的元件中。
通常來說,VIP的修改需要在規定的時間視窗內,cluster 停止服務。然而對於某種情況下,是不需要停機時間,比如只是修改一個節點的vip維護操作只要在那個節點上就可以了,而不必停止整個cluster。
從10.2.0.3 以來,oracle 去除了ASM/DATABSE對vip的依賴關係,這樣對vip的修改可以在不必停止ASM/DATABASE例項的情況下進行,需要做的僅僅是與這個節點連線的客戶端受到影響。
實驗環境:
版本:
Clusterware :11.2.0.2
database :11.2.0.1
修改vip的操作步驟:
舊vip:
10.10.10.201 rac1-vip
10.10.10.202 rac2-vip
新vip:
10.250.7.111 rac1-vip
10.250.7.112 rac2-vip
子網 10.250.7.0
掩碼 255.255.255.0
1 確定vip
對於 10g and 11gR1, 以CRS的屬主:
$ srvctl config nodeapps -n -a
比如:
$ srvctl config nodeapps -n racnode1 -a
VIP exists.: /racnode1-vip/101.17.80.184/255.255.254.0/eth1
對於 11gR2, 以Grid 屬主:
$ srvctl config nodeapps -a
grid@rac1:/home/grid>srvctl config nodeapps -a
網路存在: 1/10.250.7.0/255.255.255.0/eth0, 型別 static
VIP 存在: /rac1-vip/10.10.10.201/10.250.7.0/255.255.255.0/eth0, 託管節點 rac1
VIP 存在: /rac2-vip/10.10.10.202/10.250.7.0/255.255.255.0/eth0, 託管節點 rac2
2. 確定VIP的狀態
grid@rac1:/home/grid>crs_stat -t | grep vip
Name Type Target State Host
------------------------------------------------------------
ora.rac1.vip ora....t1.type ONLINE ONLINE rac1
ora.rac2.vip ora....t1.type ONLINE ONLINE rac2
ora.scan1.vip ora....ip.type ONLINE ONLINE rac1
grid@rac1:ifconfig -a
.....省略.....
eth0:2 Link encap:Ethernet HWaddr 00:50:56:8F:25:0A
inet addr:10.10.10.201 Bcast:10.250.7.255 Mask:255.255.255.0
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
Base address:0x2400 Memory:d8960000-d8980000
.....省略.....
Stopping Resources
3. 停止nodeapps資源和所有依賴於VIP的資源(如果有計劃的中斷所有服務,則停止ASM/DB 例項)
10g and 11gR1,以CRS的屬主:
$ srvctl stop asm -n
$ srvctl stop instance -d -i
$ srvctl stop nodeapps -n
比如:
$ srvctl stop asm -n racnode1
$ srvctl stop instance -d RACDB -i RACDB1
$ srvctl stop nodeapps -n racnode1
11gR2,以Grid屬主:
$ srvctl stop instance -d -n
$ srvctl stop vip -n -f
grid@rac1:srvctl stop database -d rac -o immediate
PRCD-1027 : 無法檢索資料庫 rac
PRCD-1229 : 嘗試訪問資料庫 rac 的配置時被拒絕, 因為其版本 11.2.0.1.0 不同於程式版本 11.2.0.2.0。請改從 /opt/rac/oracle/11.2.0/dbs 執行程式。
oracle@rac1:/home/oracle>srvctl stop database -d rac -o immediate
grid@rac1:/home/grid>srvctl stop vip -n rac1 -f -v
已成功停止 VIP。
grid@rac1:/home/grid>srvctl stop vip -n rac2 -f -v
已成功停止 VIP。
Note: 在 11GR2版本中,-f選項是必須的,否則會報如下錯誤:
PRCR-1014 : Failed to stop resource ora.rac1.vip
PRCR-1065 : Failed to stop resource ora.rac1.vip
CRS-2529: Unable to act on 'ora.rac1.vip' because that would require stopping or relocating 'ora.LISTENER.lsnr', but the force option was not specified
...
grid@rac1:/home/grid>srvctl stop listener -n rac1
PRCC-1017 : LISTENER 已在 rac1 上停止
PRCR-1005 : 資源 ora.LISTENER.lsnr 已停止
grid@rac1:/home/grid>srvctl stop listener -n rac2
PRCC-1017 : LISTENER 已在 rac2 上停止
PRCR-1005 : 資源 ora.LISTENER.lsnr 已停止
為了防止變更未被確認,而asm 或者db 例項的自動啟動,需要將此自動重啟功能暫時禁用。
$ srvctl disable database -d
$ srvctl disable asm -n (對於11.2 版本之前的)
$ srvctl disable nodeapps (使用與 11.2 版本以後的)
而我執行srvctl disable nodeapps命令時遇到如下情況(因為vip服務已經停止了)。不會影響最終的操作。
grid@rac1:/home/grid>srvctl disable nodeapps
PRKO-2409 : GSD 已在節點上禁用: rac1,rac2
PRCR-1071 : 無法註冊或更新 資源 ora.rac1.vip
CRS-0245: User doesn't have enough privilege to perform. the operation
PRCR-1071 : 無法註冊或更新 資源 ora.net1.network
CRS-0245: User doesn't have enough privilege to perform. the operation
4.確認VIP是否已經offline,並且不再繫結到公共網路卡上:
grid@rac1:/home/grid>crs_stat -t | grep vip
ora.rac1.vip ora....t1.type OFFLINE OFFLINE
ora.rac2.vip ora....t1.type OFFLINE OFFLINE
ora.scan1.vip ora....ip.type ONLINE ONLINE rac1
使用 ifconfig -a
5 修改VIP和對應的屬性值,確保先在OS上做相應的變更 比如/etc/hosts 或者DNS。如果網路卡改變了,先確保新的網路卡可用。
舊vip:
10.10.10.201 rac1-vip
10.10.10.202 rac2-vip
新vip
10.250.7.111 rac1-vip
10.250.7.112 rac2-vip
子網 10.250.7.0
掩碼 255.255.255.0
6. 修改VIP資源
以root使用者執行如下命令:
[root@rac1 ~]# /opt/11202/11.2.0/grid/bin/srvctl modify nodeapps -n rac1 -A rac1-vip/255.255.255.0/eth0
[root@rac1 ~]# /opt/11202/11.2.0/grid/bin/srvctl modify nodeapps -n rac2 -A rac2-vip/255.255.255.0/eth0
Note 1: 對於windows平臺,如果網路卡名稱有空格,必須使用 ""
比如:
> srvctl modify nodeapps -n racnode1 -A 110.11.70.11/255.255.255.0/"Local Area Connection 1
Note 2: 從 11.2 開始,VIP依賴於network資源(ora.net1.network),OCR 僅僅只是記錄VIP 的hostname或者vip 的ip地址。vip的網路屬性比如子網和掩碼是記錄在network資源裡的。
From 11.2.0.2起 , 可以使用srvctl modify network 命令修改網路資源資訊
grid@rac1:/home/grid>srvctl modify network -h
修改 Oracle Clusterware 中的網路配置。
用法: srvctl modify network [-k ] [-S /[/if1[|if2...]]] [-w ] [-v]
-k 網路編號 (預設編號為 1)
-S //[if1[|if2...]] 網路的 NET 地址說明
-w 網路型別 (static, dhcp, mixed)
-h 輸出用法
-v 詳細輸出
以root使用者:
# srvctl modify network -k 1 -S 110.11.70.0/255.255.255.0/eth2
7. 確認變更:
grid@rac1:/home/grid>srvctl config nodeapps -a
網路存在: 1/10.250.7.0/255.255.255.0/eth0, 型別 static
VIP 存在: /rac1-vip/10.250.7.111/10.250.7.0/255.255.255.0/eth0, 託管節點 rac1
VIP 存在: /rac2-vip/10.250.7.112/10.250.7.0/255.255.255.0/eth0, 託管節點 rac2
8. 重新啟動nodeapps資源和相關依賴資源
grid@rac1:/home/grid>srvctl enable nodeapps
PRKO-2415 : VIP 已在節點上啟用: rac1,rac2
PRKO-2416 : 網路資源已啟用。
oracle@rac1:/home/oracle>srvctl enable database -d rac
grid@rac1:/home/grid>
grid@rac1:/home/grid>srvctl start listener -n rac2
grid@rac1:/home/grid>srvctl start listener -n rac1
grid@rac1:/home/grid>
oracle@rac1:/home/oracle>
oracle@rac1:/home/oracle>srvctl start database -d rac
grid@rac1:/home/grid>
9. 檢視新的VIP的狀態
grid@rac1:/home/grid>crs_stat -t | grep vip
ora.rac1.vip ora....t1.type ONLINE ONLINE rac1
ora.rac2.vip ora....t1.type ONLINE ONLINE rac2
ora.scan1.vip ora....ip.type ONLINE ONLINE rac1
grid@rac1:/home/grid>
grid@rac1:/home/grid>
grid@rac1:/home/grid>/sbin/ifconfig
eth0 Link encap:Ethernet HWaddr 00:50:56:8F:25:0A
inet addr:10.250.7.225 Bcast:10.250.7.255 Mask:255.255.255.0
inet6 addr: fe80::250:56ff:fe8f:250a/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:560742 errors:0 dropped:0 overruns:0 frame.:0
TX packets:1472284 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:56118003 (53.5 MiB) TX bytes:126169027 (120.3 MiB)
Base address:0x2400 Memory:d8960000-d8980000
eth0:1 Link encap:Ethernet HWaddr 00:50:56:8F:25:0A
inet addr:10.250.7.210 Bcast:10.250.7.255 Mask:255.255.255.0
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
Base address:0x2400 Memory:d8960000-d8980000
eth0:2 Link encap:Ethernet HWaddr 00:50:56:8F:25:0A
inet addr:10.250.7.111 Bcast:10.250.7.255 Mask:255.255.255.0
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
Base address:0x2400 Memory:d8960000-d8980000
eth1 Link encap:Ethernet HWaddr 00:50:56:8F:6F:49
inet addr:10.10.10.101 Bcast:10.10.10.255 Mask:255.255.255.0
inet6 addr: fe80::250:56ff:fe8f:6f49/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:6842717 errors:0 dropped:0 overruns:0 frame.:0
TX packets:4120949 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:4798726508 (4.4 GiB) TX bytes:1472194319 (1.3 GiB)
Base address:0x2440 Memory:d8980000-d89a0000
eth1:1 Link encap:Ethernet HWaddr 00:50:56:8F:6F:49
inet addr:169.254.51.141 Bcast:169.254.255.255 Mask:255.255.0.0
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
Base address:0x2440 Memory:d8980000-d89a0000
grid@rac1:/home/grid>
對於11gR2,只是修改vip的hostname 而不修改其ip地址和vip的其他屬性不變:
1.修改VIP 使其指向另一個可用的 hostname,比如rac1
# srvctl modify nodeapps -n racnode1 -A rac2-vip/255.255.255.0/eth2
2.修改 VIP 指定新的hostname
# srvctl modify nodeapps -n racnode1 -A rac1-nvip/255.255.255.0/eth2
3. 確定 USR_ORA_VIP 的值:
# crsctl stat res ora.rac1.vip
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22664653/viewspace-712690/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 【RAC】Oracle rac 如何修改公網及vipOracle
- Oracle RAC修改public, VIP, SCAN IPOracle
- rac vip failback issueAI
- RAC的VIP切換測試
- rac 新增第二public ip 和 vip
- 11g RAC 修改PUBLIC-IP、VIP、PRIV-IP、SCAN-IP
- Oracle RAC ASM磁碟組擴容時遇到的VIP漂移OracleASM
- Oracle 12. 2 RAC public IP與vip 互換方法Oracle
- VIP影片解析
- parameter hj8828vip installed Oracle h518vip onOracleH5
- 【rac故障】root.sh報錯Unable to get VIP info for new node
- keepalived(二)vip漂移
- Python抓取VIP電影Python
- MHA高可用+VIP漂移
- www.hj518.vip@17008768000@www.hj518.vip@我要發大財
- 如何跟蹤11g vip及SCN IP的輸出
- Ubuntu18.04 修改hostnameUbuntu
- centos7修改hostnameCentOS
- 【RAC】Oracle RAC如何修改心跳網路Oracle
- linux 修改hosts檔案以及修改hostnameLinux
- 送滿vip的手遊平臺哪個好?上線就送滿vip版手遊平臺排行
- 百度VIP音樂爬取
- linux start_udev 導致VIP漂移Linuxdev
- 怎麼會wwwhj518vip18587065666
- 如何修改rac的系統時間
- 愛奇藝星鑽VIP會員怎麼升級? 愛奇藝成為星鑽VIP會員的技巧
- vip-admin 管理系統v1.0.0
- MySQL Orchestrator自動導換+VIP切換MySql
- HAC叢集部署vip及相關操作
- 百度網盤vip下載-軟體
- kube-vip高可用k8s群K8S
- PG12.9-Repmgr5.1.0-vip-3節點部署
- www.hj278.com18587065666www.hj518.vip
- www.hj518.vip@18587065666@www.hj278.com
- 如何檢視Oracle RAC的asm磁碟的udev對應關係OracleASMdev
- 【VIP視訊網站專案上線】基於Nodejs的Express框架開發的VIP視訊網站專案及完整程式碼分享...網站NodeJSExpress框架
- 安利一個看全網vip影片的微信小程式微信小程式
- [藍橋杯][演算法提高VIP]大數加法演算法
- 咕泡學院JAVA架構師VIP課程Java架構