ORA-00119: invalid specification for system parameter LOCAL_LISTENER异常解决

在安装Oracle并创建多个数据库时遇到ORA-00119异常,问题源于SPFILE*.ORA文件中的LOCAL_LISTENER参数指向已删除的监听器。解决方案包括更新tnsnames.ora,基于spfile创建pfile,修改pfile以删除local_listener行,然后使用新的pfile启动数据库服务。

安装Oracle时,本地创建了多个数据库,但在创建第二个库时出现了问题,发现第一个库连接不上去了。
从oradim.log文件中看到以下异常:

D:\programs\oracle_data\product\11.2.0\dbhome_1\bin\oradim.exe -startup -sid test -usrpwd *  -log oradim.log -nocheck 0 
Fri May 08 16:53:35 2020
ORA-00119: invalid specification for system parameter LOCAL_LISTENER
ORA-00132: syntax error or unresolved network name 'LISTENER_TEST'

但很诡异的是,在listener.ora文件中,LISTENER_TEST这个监听配置已经不存在了(因为有多个库,监听已经修改成了LISTENER);
查找资料后得知,如果对监听进行过修改,对应数据库的SPFILE*.ORA文件中会存储LISTENER名称,此时即使再通过Oracle的工具或者手动修改listener.ora文件中的内容,都不会影响到SPFILE文件中的配置!启动的时候还是使用SPFILE*.ORA文件中local_listener对应的监听去连接;但此时listener.ora文件中已经没有这个监听了,就会导致启动不起来报这个异常。
出现这种情况时,需要修改SPFILE*.ORA文件中的内容,但这个文件是以二进制方式存储的,直接修改后ORACLE识别不了!
经过摸索,通过以下方式可以修改(以数据库名为test时为例):

  1. 在tnsnames.ora中增加以下内容:
TEST =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = LAPTOP-K49AVDSD)(PORT = 1521))
    (CONNEC
从你提供的错误信息来看,执行 JOB 时在发送邮件环节报错,错误信息如下: ``` ORA-29277: invalid SMTP operation ORA-06512: at "SYS.UTL_SMTP", line 80 ORA-06512: at "SYS.UTL_SMTP", line 647 ORA-06512: at "ECOLOGY.CUXHL2_MAIL_PKG", line 822 ORA-29278: SMTP transient error: 421 4.3.2 Service not available ORA-06512: at "ECOLOGY.CUXHL2_MAIL_PKG", line 899 ORA-06512: at "ECOLOGY.DCC_PENDINGAPPROVAL_PKG", line 74 ``` ### 报错原因分析: 1. **ORA-29277: invalid SMTP operation** - 表示调用 `UTL_SMTP` 包时执行了非法的 SMTP 操作,可能是连接未建立就执行了发送邮件操作。 2. **ORA-29278: SMTP transient error: 421 4.3.2 Service not available** - 表示 Oracle 试图通过 SMTP 发送邮件时,邮件服务器暂时不可用。可能是邮件服务器宕机、网络不通、SMTP 配置错误或权限问题。 3. **调用栈信息** - 错误发生在 `ECOLOGY.CUXHL2_MAIL_PKG` 包的第 822 和 899 行,说明邮件发送逻辑在此包中实现,而最终调用的是 `SYS.UTL_SMTP` 包。 - `DCC_PENDINGAPPROVAL_PKG` 第 74 行调用了邮件发送包。 ### 解决方案建议: 1. **检查 SMTP 邮件服务器状态** - 确认邮件服务器是否正常运行。 - 使用 `telnet mail_server_ip 25` 检查端口是否开放。 2. **检查 Oracle 的 UTL_SMTP 配置** - 确保 `UTL_SMTP` 调用的 SMTP 地址、端口配置正确。 - 检查是否配置了 ACL(访问控制列表),确保 Oracle 有权限访问邮件服务器。 3. **检查邮件发送包代码逻辑** - 查看 `CUXHL2_MAIL_PKG` 包中邮件发送逻辑,确保连接、发送、关闭流程正确。 - 检查是否缺少异常处理导致错误未被捕获。 4. **查看数据库警报日志和邮件服务器日志** - 可以帮助进一步定位是网络问题、权限问题还是邮件服务器拒绝连接。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值