windows 程连接 Oracle 报 ORA-12541

远程连接 Oracle 报 ORA-12541 完整修复教程

适用场景:本地能连 Oracle、远程连接报错 ORA-12541: TNS:no listener,Windows 环境

一、问题原因

从你的日志可明确:

  1. Oracle 监听默认只绑定 127.0.0.1,仅允许本机访问
  2. 监听重启后数据库实例未自动注册,远程依然无法识别服务

二、前置准备

  1. 登录Oracle 所在服务器 ,以管理员身份打开 CMD

  2. 找到监听配置文件路径(以你的环境为例):

    复制代码
    E:\BaiduNetdiskDownload\network\admin\listener.ora

三、第一步:修改监听配置,允许远程访问

  1. 打开 listener.ora 文件

  2. 全量替换 为以下配置(直接复制覆盖):

    ini 复制代码
    LISTENER =
      (DESCRIPTION_LIST =
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCP)(HOST = 0.0.0.0)(PORT = 1521))
          (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
        )
      )
    
    SID_LIST_LISTENER =
      (SID_LIST =
        (SID_DESC =
          (SID_NAME = CLRExtProc)
          (ORACLE_HOME = E:\BaiduNetdiskDownload)
          (PROGRAM = extproc)
        )
      )
  3. 保存并关闭文件

四、第二步:重启监听生效

管理员 CMD 中依次执行:

cmd 复制代码
lsnrctl stop
lsnrctl start

重启成功后执行:

cmd 复制代码
lsnrctl status

看到 HOST=0.0.0.0 即配置生效:

复制代码
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=0.0.0.0)(PORT=1521)))

五、第三步:注册数据库实例到监听

监听启动后,数据库不会自动注册,需手动执行:

  1. CMD 登录数据库:

    cmd 复制代码
    sqlplus / as sysdba
  2. 执行注册语句:

    sql 复制代码
    alter system register;
  3. 退出 SQL:

    sql 复制代码
    exit
  4. 再次查看监听状态:

    cmd 复制代码
    lsnrctl status

出现以下内容即为正常:

复制代码
服务 "orcl" 包含 1 个实例。
实例 "orcl", 状态 READY...

六、第四步:开放服务器 1521 端口

  1. 管理员 CMD 执行放行命令:

    cmd 复制代码
    netsh advfirewall firewall add rule name="Oracle 1521" dir=in action=allow protocol=TCP localport=1521
  2. 云服务器需额外在控制台安全组开放 1521 端口

七、远程连接测试

  1. 远程电脑使用服务器公网/内网IP连接
  2. 连接信息示例:
    • IP:服务器真实IP
    • 端口:1521
    • 服务名:orcl
  3. 测试连接,ORA-12541 错误消失

八、常见验证命令汇总

  • 查看监听状态:lsnrctl status
  • 停止监听:lsnrctl stop
  • 启动监听:lsnrctl start
  • 数据库注册监听:alter system register;
  • 测试端口通断:telnet 服务器IP 1521
相关推荐
Meepo_haha2 小时前
配置MyBatis-Plus打印执行的 SQL 语句到控制台或日志文件中
数据库·sql·mybatis
Carino_U3 小时前
MySQL中Explain详解与索引最佳实践
数据库·mysql
蜡台3 小时前
Mysql 安装使用时常见问题解决记录
数据库·mysql
God__is__a__girl3 小时前
Docker Desktop 在 Windows 上启动失败:500 Internal Server Error 完整排查与修复指南
windows·docker·容器
摸鱼的后端3 小时前
Docker容器中Kingbase数据库授权到期更换解决方案
数据库·docker·容器
极创信息3 小时前
企业信创产品认证全流程:从信创适配到信创认证的实操指南(2026版)
java·数据库·spring boot·mysql·matlab·mybatis·软件工程
桌面运维家3 小时前
Windows 10音频故障排除:驱动、设备、DirectX修复指南
windows·音视频
onebound_noah3 小时前
【实战解析】如何高效获取京东商品详情数据(含多语言SDK接入)
java·前端·数据库
PD我是你的真爱粉3 小时前
MySQL 高性能实战与底层原理
数据库·mysql·adb