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
相关推荐
m0_734949794 小时前
MySQL如何配置定时清理过期备份文件_find命令与保留周期策略
jvm·数据库·python
m0_514520574 小时前
MySQL索引优化后性能没提升_通过EXPLAIN查看索引命中率
jvm·数据库·python
NaMM CHIN4 小时前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
不瘦80斤不改名4 小时前
深入浅出 MySQL(一):一文理清 SQL 核心规范与五大分类
数据库·sql·mysql
woniu_buhui_fei4 小时前
MySQL知识整理二
数据库·mysql
Polar__Star5 小时前
如何在 AWS Lambda 中正确使用临时凭证生成 S3 预签名 URL
jvm·数据库·python
Lucifer三思而后行5 小时前
zCloud 中 Oracle 实例状态未知问题记录
数据库·oracle
island13146 小时前
最详细VMware Workstation 17 上安装 Ubuntu 系统
linux·数据库·ubuntu
卢傢蕊6 小时前
MongoDB
数据库·mongodb
m0_743623926 小时前
React 自定义 Hook 的命名规范与调用规则详解
jvm·数据库·python