替換OCR和表決磁碟後,重啟叢集,資料庫資源的叢集狀態為OFFLINE
1 系統概述
業務系統需要更換SSD儲存裝置,需要將所有的磁碟替換掉。更換資料磁碟、OCR 、表決磁碟後,在節點1重啟叢集進行驗證,發現資料庫例項的資源狀態為OFFLINE,使用叢集命令servctl也不能啟動,報ORA-15017: diskgroup "OCR" cannot be mounted
2 啟動資料庫,檢視叢集狀態,發現資料庫資源狀態為offline
啟動資料庫
SYS@test1 >startup
ORACLE instance started.
Total System Global Area 2.3517E+11 bytes
Fixed Size 2267464 bytes
Variable Size 5.0466E+10 bytes
Database Buffers 1.8415E+11 bytes
Redo Buffers 553766912 bytes
Database mounted.
Database opened.
檢視資料庫是否啟動
[grid@testdb1 ~]$ ps -ef|grep smon
root 13667 1 8 Mar26 ? 12:56:12 /opt/app/11.2.0.4/grid/bin/osysmond.bin
grid 15764 1 0 Mar26 ? 00:00:17 asm_smon_+ASM1
grid 17875 1 0 Mar26 ? 00:26:00 ora_smon_test1
grid 163774 163708 0 15:22 pts/1 00:00:00 grep smon
檢視叢集狀態,發現節點1資料庫例項的狀態不對
ora.test.db
1 ONLINE OFFLINE Instance Shutdown
2 ONLINE ONLINE testdb2 Open
3 ONLINE ONLINE testdb3 Open
3 關閉資料庫,使用叢集命令進行啟動,發現報錯的原因為沒有OCR磁碟組,此磁碟組在1小時前已經進行替換和刪除。
SYS@test1 >shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SYS@test1 >exit
試著用叢集命令啟動,發現報錯
[grid@testdb1 ~]$ srvctl start instance -d test -i test1
PRCR-1013 : Failed to start resource ora.test.db
PRCR-1064 : Failed to start resource ora.test.db on node testdb1
CRS-5017: The resource action "ora.OCR.dg start" encountered the following error:
ORA-15032: not all alterations performed
ORA-15017: diskgroup "OCR" cannot be mounted
ORA-15040: diskgroup is incomplete
. For details refer to "(:CLSN00107:)" in "/opt/app/11.2.0.4/grid/log/testdb1/agent/crsd/oraagent_grid//oraagent_grid.log".
CRS-2674: Start of 'ora.OCR.dg' on 'testdb1' failed
4 檢視報錯資訊的trace檔案,還是在尋找OCR磁碟組
2022-03-26 02:23:40.443: [ora.asm][1424000768]{1:20237:2} [check] AsmProxyAgent::createAsmOcrKeys host: testdb1 oracleSid_lc:
+asm1 oracleSid_uc: +ASM1 tempHost1: testdb1.+asm1
[ OCRAPI][1424000768]a_is_valid_user_group: User [oracle] does not match with init user
[ OCRUTL][1424000768]u_fill_errorbuf: Error Info : [User [oracle] does not match with initialized user]
[ OCRAPI][1424000768]a_create_n_set_key:THE SECURITY ATTRIBUTE PASSED is invalid
2022-03-26 02:23:40.454: [ OCRAPI][1424000768]a_batch_execute: Check batch exec failed [5]
2022-03-26 02:23:40.454: [ OCRAPI][1424000768]a_batch_execute: Failed to execute batch. Return [5]
2022-03-26 02:23:40.454: [ora.asm][1424000768]{1:20237:2} [check] OcrBatch Execute failed 5
2022-03-26 02:23:40.455: [ora.asm][1424000768]{1:20237:2} [check] AsmProxyAgent::createAsmOcrKeys failed
[ OCRUTL][1424000768]u_check_tag: Tag check failed on 0th comparison for [PROCRKEY]. Ptr passed was [40446f0] Byte was [0]
2022-03-26 02:23:40.455: [ora.asm][1424000768]{1:20237:2} [check] AsmProxyAgent::createAsmOcrKeys exit }
2022-03-26 02:23:40.455: [ora.asm][1424000768]{1:20237:2} [check] CrsCmd::ClscrsCmdData::stat entity 1 statflag 33 useFilter 0
2022-03-26 02:23:40.477: [ora.OCR.dg][787871488]{1:20237:207} [start] ORA-15032: not all alterations performed
ORA-15017: diskgroup "OCR" cannot be mounted
ORA-15040: diskgroup is incomplete
2022-03-26 02:23:40.478: [ USRTHRD][1424000768]{1:20237:2} CrsCmd::ClscrsCmdData::destroy
2022-03-26 02:23:40.478: [ora.OCR.dg][787871488]{1:20237:207} [start] clsnUtils::error Exception type=2 string=
CRS-5017: The resource action "ora.OCR.dg start" encountered the following error:
ORA-15032: not all alterations performed
ORA-15017: diskgroup "OCR" cannot be mounted
ORA-15040: diskgroup is incomplete
. For details refer to "(:CLSN00107:)" in "/opt/app/11.2.0.4/grid/log/testdb1/agent/crsd/oraagent_grid//oraagent_grid.log".
5 原因分析
根據如上資訊,可以確定叢集需要OCR磁碟組,但此磁碟組由於更換儲存裝置,已經進行了刪除,遷移到新的磁碟組下。故判斷是由於將資料庫相關資訊註冊到OCR磁碟組下,導致叢集狀態不正常及不能使用叢集命令啟動資料庫。檢視20分鐘官方文件,未找到合適的官方文件,經過思考,認為就是叢集註冊資訊在老的OCR磁碟組下,故可以將資料庫及例項的叢集註冊資訊刪除,並重建,估計就恢復正常了。經測試,一切OK。
5.1 關閉所有資料庫例項
5.2 使用如下命令刪除資料庫資源的相關資訊
刪除:
cd /opt/app/11.2.0.4/grid/bin
./srvctl remove database -d test
./srvctl remove instance -d test -i test1
./srvctl remove instance -d test -i test2
./srvctl remove instance -d test -i test3
5.3 使用如下命令新增資料庫資源的相關資訊
新增:
srvctl add database -d test -o $ORACLE_HOME
srvctl add instance -d test -i test1 -n testdb1
srvctl add instance -d test -i test2 -n testdb2
srvctl add instance -d test -i test3 -n testdb3
5.4 使用叢集命令啟動資料庫,並檢視叢集資訊,發現叢集資訊已經恢復正常
ora.test.db
1 ONLINE ONLINE testdb1 Open
2 ONLINE ONLINE testdb2 Open
3 ONLINE ONLINE testdb3 Open
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69996316/viewspace-2885419/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 資料庫叢集資料庫
- MySQL資料庫叢集MySql資料庫
- Redis叢集 - cluster叢集、資料分片Redis
- 【資料庫】Redis叢集篇資料庫Redis
- RAC叢集資料庫搭建資料庫
- 4 管理資料庫例項和叢集資料庫資料庫
- 資料庫代理服務和叢集管理資料庫
- 替換oracle叢集中的OCR 映象Oracle
- 時序資料庫的叢集方案?資料庫
- Moebius資料庫多活叢集資料庫
- 修改叢集資料庫的歸檔模式資料庫模式
- RabbitMQ叢集重啟報錯MQ
- [專業術語]資料庫叢集資料庫
- 叢集資料庫新增控制檔案資料庫
- 新增叢集資料庫服務service資料庫
- SequoiaDB資料庫之叢集管理資料庫
- redis資料庫叢集三種模式Redis資料庫模式
- 資料庫叢集技術漫談資料庫
- VCS叢集狀態為 STALE_ADMIN_WAIT的解決AI
- 通過memberlist庫實現gossip管理叢集以及叢集資料互動Go
- 淺談高效能資料庫叢集——分庫分表資料庫
- 在GI安裝完成後檢視叢集狀態時發現,磁碟組狀態不對
- MySQL 叢集的安全關閉和重啟方法MySql
- oracle資料庫叢集新增表空間操作規範Oracle資料庫
- Redis資料型別, Redis主從哨兵和叢集(將資料匯入叢集) ubuntu使用Redis資料型別Ubuntu
- 亞馬遜雲資料庫Redshift解決叢集難題WE亞馬遜資料庫
- 資料庫Mysql5.7 MGR叢集的搭建資料庫MySql
- 小知識:使用oracle使用者檢視RAC叢集資源狀態Oracle
- 大資料分享Spark任務和叢集啟動流程大資料Spark
- 搞懂 ZooKeeper 叢集的資料同步
- 開源大資料叢集部署(十一)Ranger 整合Hadoop叢集大資料RangerHadoop
- oracle 11gR2 grid 叢集資源設定跟隨叢集自動啟動Oracle
- 【巨杉資料庫SequoiaDB】巨杉Tech | 四步走,快速診斷資料庫叢集狀態資料庫
- EJB叢集和Webservice叢集的討論Web
- oracle RAC 診斷叢集狀態命令Oracle
- impala 資料表在叢集間遷移方案
- Redis叢集模式和常用資料結構Redis模式資料結構
- 叢集資料庫重要檔案的檢視管理資料庫