Oracle监听端口被占用导致TNS-12541错误,需检查并更换端口(如1522),同步更新listener.ora、tnsnames.ora及JDBC连接串,重启监听;EM Express需单独配置HTTP端口;Windows下还需手动开放防火墙新端口。Oracle监听端口被占用,lsnrctl start 报 TNS-12541: TNS:no listener这不是监听没启动,而是端口根本 bind 失败。oracle 默认用 1521,但很多环境(尤其是开发机、docker、或装过其他数据库)早被 java、postgresql、甚至某个残留的 oracle-xe 进程占了。先确认:运行 netstat -an | grep 1521(linux/macos)或 netstat -ano | findstr :1521(windows),看 pid 是否非零且不属于 tnslsnr。改 listener.ora 端口后仍连不上,sqlplus /@orcl 提示 ORA-12170: TNS:Connect timeout occurred只改配置文件不够,必须同步更新三处:listener.ora 中 PORT 值(如改成 1522),路径通常是 $ORACLE_HOME/network/admin/listener.oratnsnames.ora 对应服务名的 PORT 必须一致(比如 orcl 条目里 (PORT=1522))如果用 JDBC,连接串里的端口号也得改,例如 jdbc:oracle:thin:@localhost:1522:orcl改完必须重启监听:lsnrctl stop && lsnrctl start;别只 reload,它不重读端口配置。修改端口后客户端能连,但 DBA_REGISTRY 显示组件状态异常或 EM Express 打不开EM Express(https://localhost:5500/em)默认绑定在数据库监听端口上,但它是通过数据库内部服务注册的,不是靠 listener.ora 配置。端口一改,EM 就断连。解决方法只有两个:手动为 EM 指定新端口:exec DBMS_XDB_CONFIG.SETHTTPPORT(5501);,然后重启数据库(不是监听)或者干脆关掉 EM:exec DBMS_XDB_CONFIG.SETHTTPPORT(0);,避免干扰注意:DBA_REGISTRY 异常往往只是 EM 相关组件报告"未就绪",不影响核心功能,别误判成数据库损坏。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
jiayong2313 小时前
MySQL 8.0 数据库恢复问题完整解决方案张二娃同学13 小时前
专栏第01篇_深度学习导论czlczl2002092513 小时前
普通索引和唯一索引 查询性能差异@小柯555m13 小时前
MySql(正则表达式--电话号码格式校验)van久13 小时前
Day29:Redis 缓存实战源码之家13 小时前
计算机毕业设计:Python医疗数据分析可视化系统 Flask框架 随机森林 机器学习 疾病数据 智慧医疗 深度学习(建议收藏)✅.柒宇.14 小时前
Redis哨兵模式详解重生之小比特14 小时前
【MySQL 数据库】复合查询夕除14 小时前
spring boot --07Elastic 中国社区官方博客14 小时前
Elasticsearch:为 AI Agent builder 创建 skill plugin