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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
雪的季节19 分钟前
企业级 Qt 全功能项目薛定谔的猫-菜鸟程序员23 分钟前
2小时智能体开发一个智能体?我用CodeArts Agent 和 AtomCode 开发了一个适老化智能体。宋浮檀s34 分钟前
应急响应——Web漏洞:命令执行+SSRF+弱口令bigfootyazi1 小时前
python爬虫-基本库-urllib库(常用速查)瑶总迷弟1 小时前
使用 mis-tei 在昇腾310P上部署 bge-m3模型belong_my_offer2 小时前
认识到精通函数yurenpai(27届找实习中)2 小时前
redis_点评(21.好友关注——关注、取关功能实现;共同关注功能实现)Rick19932 小时前
索引的排序和分组爱莉希雅&&&2 小时前
zabbix快速搭建和使用JohnYan2 小时前
工作笔记 - PG分组极值