TNS-12531: TNS: 无法分配内存

记一次客户生产环境报错。

环境为windows server 2008,oracle监听突然失效外部无法连接,查看日志,alert_orcl.log报错ORA-00600,listener.log报错TNS-12531: TNS: 无法分配内存。

一开始以为是程序异常占用大量内存导致,重启观察一段时间监听再次报错,但是内存使用率仅50%,且cpu和文件句柄数其他都正常。

最后发现是windows共享内存不足导致的,windows没法查看共享内存的使用情况(这点很坑)。导致的原因为,人工误删了一个批处理文件,有一个程序会定期执行"start ***.bat"调用此脚本,当文件不存在时start命令会无限制循环重试,最后导致共享内存不足引起oracle监听异常。

总结:

windows环境下利用start 启动某个程序或脚本时一定要确保路径存在(call 命令没有验证过),不然资源管理器叶无法发现异常,不像linux能看到/dev/shm共享内存的使用情况。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值