it编程 > 数据库 > Oracle

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

11人参与 2025-06-09 Oracle

一、问题根源分析​​

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

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

# linux/unix
netstat -tuln | grep <新端口号>
# windows
netstat -ano | findstr "<新端口号>"

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

​​步骤1:修正监听器配置文件 (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
    )
  )

​关键检查点​​:

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

服务别名 =
  (description =
    (address = (protocol = tcp)(host = 主机名)(port = 新端口号))  # 与listener.ora一致
    (connect_data =
      (server = dedicated)
      (service_name = 数据库服务名)  # 例如 orcl
    )
  )

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

# 停止监听器
lsnrctl stop
# 启动监听器
lsnrctl start
# 检查状态
lsnrctl status

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

# linux
firewall-cmd --add-port=<新端口号>/tcp --permanent
firewall-cmd --reload
# windows:高级安全防火墙 → 新建入站规则

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

echo $oracle_home  # linux
set oracle_home    # windows
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
srvctl modify listener -l listener -p "tcp:新端口号"
srvctl modify scan_listener -p 新端口号

总结​​

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

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

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

(0)

您想发表意见!!点此发布评论

推荐阅读

Oracle普通视图和物化视图的区别及说明

06-09

Oracle变量、输入输出、SELECT INTO、%TYPE与%ROWTYPE详解

06-09

Oracle条件判断之IF ELSE的使用方式

06-09

Oracle中的循环之FOR循环、WHILE循环和LOOP循环详解

06-09

Oracle日志表的使用方式

06-09

Oracle如何自定义函数

06-09

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论