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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
YummyJacky1 小时前
Hermes Agent自进化的实现方式qq_342295822 小时前
Redis怎样按照距离远近排序展示_通过GEORADIUS的ASC参数进行Geo排序2201_761040592 小时前
C#比较两个二进制文件的差异 C#如何实现一个二进制diff工具Csvn2 小时前
🌟 LangChain 30 天保姆级教程 · Day 23|Agent 进阶实战!Function Calling + 自动 Tool 注册,打造会“动Csvn2 小时前
🌟 LangChain 30 天保姆级教程 · Day 22|长文档处理三剑客!MapReduce、Refine、Map-Rerank,让 AI 消化整本手册皮卡蛋炒饭.2 小时前
线程的概念和控制John.Lewis2 小时前
Python小课(1)认识PythonPolar__Star2 小时前
SQL中如何实现特定顺序的查询:CASE WHEN自定义排序一只大袋鼠2 小时前
MyBatis 入门详细实战教程(一):从环境搭建到查询运行