Oracle修改端口號(hào)之后無法啟動(dòng)的解決方案
一、問題根源分析??
??配置文件語法錯(cuò)誤??
- 修改listener.ora時(shí)遺漏關(guān)鍵符號(hào)(如括號(hào)不匹配)、格式錯(cuò)誤或路徑錯(cuò)誤會(huì)導(dǎo)致解析失敗。
- ??典型表現(xiàn)??:執(zhí)行l(wèi)snrctl start后報(bào)錯(cuò) TNS-12542: TNS: 監(jiān)聽器地址無效。
??端口被占用或防火墻攔截??
- 新端口可能被其他進(jìn)程占用(如Apache、其他數(shù)據(jù)庫)或被防火墻阻止。
- ??驗(yàn)證命令??:
# Linux/Unix netstat -tuln | grep <新端口號(hào)> # Windows netstat -ano | findstr "<新端口號(hào)>"
- ??未同步更新客戶端配置??
- 僅修改
listener.ora
而未更新tnsnames.ora
,導(dǎo)致客戶端無法連接,誤判為監(jiān)聽器故障。
- 僅修改
- ??SID或服務(wù)名未正確關(guān)聯(lián)??
- 監(jiān)聽器未綁定到正確的數(shù)據(jù)庫實(shí)例(SID),導(dǎo)致無法路由連接請(qǐng)求。
?二、保姆級(jí)解決方案??
??步驟1:修正監(jiān)聽器配置文件 (listener.ora)??
- ??文件路徑??:
$ORACLE_HOME/network/admin/listener.ora
- ??正確配置模板??:
LISTENER = (DESCRIPTION_LIST = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 主機(jī)名)(PORT = 新端口號(hào))) # 修改此處端口 ) ) SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (SID_NAME = 數(shù)據(jù)庫SID) # 例如 orcl (ORACLE_HOME = Oracle安裝路徑) # 例如 /u01/app/oracle/product/19.0.0/dbhome_1 ) )
??關(guān)鍵檢查點(diǎn)??:
- 括號(hào)必須成對(duì)閉合,避免嵌套錯(cuò)誤。
HOST
需為服務(wù)器IP或可解析的主機(jī)名(避免用localhost
)。
??步驟2:更新客戶端配置 (tnsnames.ora)??
- ??文件路徑??:
$ORACLE_HOME/network/admin/tnsnames.ora
- ??修改示例??:
服務(wù)別名 = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 主機(jī)名)(PORT = 新端口號(hào))) # 與listener.ora一致 (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = 數(shù)據(jù)庫服務(wù)名) # 例如 orcl ) )
步驟3:重啟監(jiān)聽器并驗(yàn)證?
# 停止監(jiān)聽器 lsnrctl stop # 啟動(dòng)監(jiān)聽器 lsnrctl start # 檢查狀態(tài) lsnrctl status
- ?預(yù)期輸出??:顯示
Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=xxx)(PORT=新端口號(hào)))
且狀態(tài)為 ??"Service ready"??。
??步驟4:處理端口占用與防火墻?
- ??釋放端口??:終止占用進(jìn)程(通過
kill -9 <PID>
或Windows任務(wù)管理器)。 - ??開放防火墻??:
# Linux firewall-cmd --add-port=<新端口號(hào)>/tcp --permanent firewall-cmd --reload # Windows:高級(jí)安全防火墻 → 新建入站規(guī)則
??步驟5:檢查環(huán)境變量與權(quán)限??
- ??確認(rèn)
ORACLE_HOME
正確??:
echo $ORACLE_HOME # Linux set ORACLE_HOME # Windows
- ??文件權(quán)限??:確保
oracle
用戶對(duì)listener.ora
和tnsnames.ora
有讀寫權(quán)限:
chown oracle:oinstall $ORACLE_HOME/network/admin/*.ora chmod 640 $ORACLE_HOME/network/admin/*.ora
三、預(yù)防性措施??
- ??變更前備份配置??:
cp listener.ora listener.ora.bak cp tnsnames.ora tnsnames.ora.bak
- ??使用工具驗(yàn)證配置??:
tnsping 服務(wù)別名
測(cè)試客戶端連通性。
- ??RAC環(huán)境特殊處理??:
- 通過
srvctl
更新集群監(jiān)聽配置:
- 通過
srvctl modify listener -l LISTENER -p "TCP:新端口號(hào)" srvctl modify scan_listener -p 新端口號(hào)
總結(jié)??
端口修改后監(jiān)聽器無法啟動(dòng)通常由??配置遺漏或語法錯(cuò)誤??引發(fā)(占案例80%以上)。嚴(yán)格遵循以下流程可徹底解決:
- ??雙文件同步??:同步修改
listener.ora
和tnsnames.ora
; - ??語法校驗(yàn)??:檢查括號(hào)閉合、參數(shù)格式;
- ??環(huán)境驗(yàn)證??:端口占用、防火墻、權(quán)限;
- ??重啟生效??:通過
lsnrctl status
確認(rèn)監(jiān)聽狀態(tài)。
若仍失敗,檢查 $ORACLE_HOME/log/diag/tnslsnr/主機(jī)名/listener/alert/log.xml
中的詳細(xì)錯(cuò)誤日志。
到此這篇關(guān)于Oracle修改端口號(hào)之后無法啟動(dòng)的解決方案的文章就介紹到這了,更多相關(guān)Oracle修改端口號(hào)無法啟動(dòng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
oracle的歸檔模式 ORACLE數(shù)據(jù)庫歸檔日志常用命令
Oracle數(shù)據(jù)庫有聯(lián)機(jī)重做日志,這個(gè)日志是記錄對(duì)數(shù)據(jù)庫所做的修改,比如插入,刪除,更新數(shù)據(jù)等,對(duì)這些操作都會(huì)記錄在聯(lián)機(jī)重做日志里2013-01-01Oracle的PDB數(shù)據(jù)庫創(chuàng)建DIRECTORY時(shí)遇到ORA-65254問題及解決方法
這篇文章主要介紹了Oracle的PDB數(shù)據(jù)庫創(chuàng)建DIRECTORY時(shí)遇到ORA-65254問題,本文給大家分享完美解決方案,需要的朋友可以參考下2023-06-06Oracle 要慌了!華為終于開源了自家的 Huawei JDK——畢昇 JDK!
畢昇 JDK 是華為內(nèi)部 OpenJDK 定制版 Huawei JDK 的開源版本,是一個(gè)高性能、可用于生產(chǎn)環(huán)境的 OpenJDK 發(fā)行版,感興趣的朋友跟隨小編一起看看吧2020-12-12Oracle9i數(shù)據(jù)庫異常關(guān)閉后的啟動(dòng)
Oracle9i數(shù)據(jù)庫異常關(guān)閉后的啟動(dòng)...2007-03-03Oracle數(shù)據(jù)庫中ora-12899錯(cuò)誤的解決方法
大家在使用oracle數(shù)據(jù)庫時(shí),經(jīng)常會(huì)遇到各種各樣的問題,其中ORA-12899就是前段時(shí)間我在將數(shù)據(jù)導(dǎo)入到我本地機(jī)器上的時(shí)候一直出現(xiàn)的問題.經(jīng)過一番倒騰問題順利解決,下面小編把實(shí)現(xiàn)思路分享到腳本之家平臺(tái)大家可以參考下2017-11-11Oracle數(shù)據(jù)庫部分遷至閃存存儲(chǔ)的實(shí)現(xiàn)方法
下面小編就為大家分享一篇Oracle數(shù)據(jù)庫部分遷至閃存存儲(chǔ)的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2017-12-12