Oracle修改端口号之后无法启动的解决方案

 更新时间:2025年06月09日 11:44:52   作者:杜哥无敌  
Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系统性解决方案,需要的朋友可以参考下

一、问题根源分析​​

​​配置文件语法错误​​

  • 修改listener.ora时遗漏关键符号(如括号不匹配)、格式错误或路径错误会导致解析失败。
  • ​​典型表现​​:执行lsnrctl start后报错 TNS-12542: TNS: 监听器地址无效。

​​端口被占用或防火墙拦截​​

  • 新端口可能被其他进程占用(如Apache、其他数据库)或被防火墙阻止。
  • ​​验证命令​​:
# Linux/Unix
netstat -tuln | grep <新端口号>
# Windows
netstat -ano | findstr "<新端口号>"
  • ​未同步更新客户端配置​
    • 仅修改listener.ora而未更新tnsnames.ora,导致客户端无法连接,误判为监听器故障。
  • ​SID或服务名未正确关联​
    • 监听器未绑定到正确的数据库实例(SID),导致无法路由连接请求。

​二、保姆级解决方案​​

​​步骤1:修正监听器配置文件 (listener.ora)​​

  • ​文件路径​​:$ORACLE_HOME/network/admin/listener.ora
  • ​正确配置模板​​:
LISTENER =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 主机名)(PORT = 新端口号))  # 修改此处端口
    )
  )
SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (SID_NAME = 数据库SID)       # 例如 orcl
      (ORACLE_HOME = Oracle安装路径)  # 例如 /u01/app/oracle/product/19.0.0/dbhome_1
    )
  )

​关键检查点​​:

  • 括号必须成对闭合,避免嵌套错误。
  • HOST 需为服务器IP或可解析的主机名(避免用localhost)。

​​步骤2:更新客户端配置 (tnsnames.ora)​​

  • ​文件路径​​:$ORACLE_HOME/network/admin/tnsnames.ora
  • ​修改示例​​:
服务别名 =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 主机名)(PORT = 新端口号))  # 与listener.ora一致
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = 数据库服务名)  # 例如 orcl
    )
  )

步骤3:重启监听器并验证​

# 停止监听器
lsnrctl stop
# 启动监听器
lsnrctl start
# 检查状态
lsnrctl status
  • ​预期输出​​:显示Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=xxx)(PORT=新端口号)) 且状态为 ​​"Service ready"​​。

​​步骤4:处理端口占用与防火墙​

  • ​释放端口​​:终止占用进程(通过kill -9 <PID>或Windows任务管理器)。
  • ​开放防火墙​​:
# Linux
firewall-cmd --add-port=<新端口号>/tcp --permanent
firewall-cmd --reload
# Windows:高级安全防火墙 → 新建入站规则

​​步骤5:检查环境变量与权限​​

  • ​确认ORACLE_HOME正确​​:
echo $ORACLE_HOME  # Linux
set ORACLE_HOME    # Windows
  • ​文件权限​​:确保oracle用户对listener.oratnsnames.ora有读写权限:
chown oracle:oinstall $ORACLE_HOME/network/admin/*.ora
chmod 640 $ORACLE_HOME/network/admin/*.ora

三、预防性措施​​

  • ​变更前备份配置​​:
cp listener.ora listener.ora.bak
cp tnsnames.ora tnsnames.ora.bak
  • ​使用工具验证配置​​:
    • tnsping 服务别名 测试客户端连通性。
  • ​RAC环境特殊处理​​:
    • 通过srvctl更新集群监听配置:
srvctl modify listener -l LISTENER -p "TCP:新端口号"
srvctl modify scan_listener -p 新端口号

总结​​

端口修改后监听器无法启动通常由​​配置遗漏或语法错误​​引发(占案例80%以上)。严格遵循以下流程可彻底解决:

  • ​双文件同步​​:同步修改listener.oratnsnames.ora
  • ​语法校验​​:检查括号闭合、参数格式;
  • ​环境验证​​:端口占用、防火墙、权限;
  • ​重启生效​​:通过lsnrctl status确认监听状态。

若仍失败,检查 $ORACLE_HOME/log/diag/tnslsnr/主机名/listener/alert/log.xml 中的详细错误日志。

到此这篇关于Oracle修改端口号之后无法启动的解决方案的文章就介绍到这了,更多相关Oracle修改端口号无法启动内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Oracle备库宕机启动的完美解决方案

    Oracle备库宕机启动的完美解决方案

    这篇文章主要给大家介绍了关于Oracle备库宕机启动的完美解决方案,文中通过示例代码介绍的非常详细,对大家学习或者使用Oracle具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • Oracle 闪回 找回数据的实现方法

    Oracle 闪回 找回数据的实现方法

    闪回技术是Oracle强大数据库备份恢复机制的一部分,在数据库发生逻辑错误的时候,闪回技术能提供快速且最小损失的恢复。这篇文章主要介绍了Oracle 闪回 找回数据的实现方法,需要的朋友可以参考下
    2018-09-09
  • Windows server 2019安装Oracle 19c的图文教程

    Windows server 2019安装Oracle 19c的图文教程

    Oracle是是一款高效、可靠、吞吐量高的数据库,本文主要介绍了Windows server 2019安装Oracle 19c的图文教程,具有一定的参考价值,感兴趣的可以了解一下
    2024-04-04
  • Oracle Listener 动态注册 与 静态注册

    Oracle Listener 动态注册 与 静态注册

    注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到数据库
    2015-12-12
  • Oracle数据库中ORDER BY排序和查询按IN条件的顺序输出

    Oracle数据库中ORDER BY排序和查询按IN条件的顺序输出

    这篇文章主要介绍了Oracle数据库中ORDER BY排序和查询按IN条件的顺序输出的方法,其中ORDER BY的排序结果需要注意其是否稳定,需要的朋友可以参考下
    2015-11-11
  • rman备份脚本和rman增量备份脚本分享

    rman备份脚本和rman增量备份脚本分享

    这篇文章主要介绍了rman备份脚本和rman增量备份脚本,需要的朋友可以参考下
    2014-03-03
  • oracle 数据库连接分析

    oracle 数据库连接分析

    oracle 数据库连接个各种环境分析,让大家较快的解决一些数据库连接问题。
    2009-07-07
  • oracle中的trim函数使用介绍

    oracle中的trim函数使用介绍

    trim一般都是用在删除字符串两边的空格。实际上,trim也可以用来删除字符串两边的指定字符。并且trim指定删除的字符串只能是单个字符
    2014-08-08
  • Oracle数据库中lead和lag函数用法示例

    Oracle数据库中lead和lag函数用法示例

    lag与lead函数是跟偏移量相关的两个分析函数,通过这两个函数可以在一次查询中取出同一字段的前N行的数据(lag)和后N行的数据(lead)作为独立的列,这篇文章主要给大家介绍了关于Oracle数据库中lead和lag函数用法的相关资料,需要的朋友可以参考下
    2024-06-06
  • 检查Oracle数据库版本的7种方法汇总

    检查Oracle数据库版本的7种方法汇总

    在Oracle数据库的发展中,数据库一直处于不断升级状态,下面这篇文章主要给大家介绍了关于检查Oracle数据库版本的7种方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-10-10

最新评论