ORA-12516 "TNS监听程序找不到符合协议堆栈要求的可用处理程序" 解决方案

前言

简单描述一下场景,总共两台应用服务器,每台安装3个tomcat进行集群,并通过nginx做了负载均衡,今天在生产环境中部署项目后进行测试,发现在一台应用服务器中同样的代码,tomcat1和tomcat2正常,而访问tomcat3时报404错误,去看了下log发现是数据库服务器出了问题:
这里写图片描述

然后登录到DB服务器去看看什么情况,结果登录时发现报以下错误:
这里写图片描述

居然已经登录不上了,根本原因就是因为oracle的process和session已经达到甚至超过最大值了,接下来就详细说明一下解决方案。

查看procress&session的参数值和占用值

上面提到由于超过连接最大值导致无法登录,所以用sys as dba也是登录不上的,首先需要先断开占用的procress,即停掉几个tomcat即可释放连接,接下来就可以登录了。在这里我停掉了所有tomcat,再通过sys用户登录sqlplus看一下procress和session的参数值和占用值:
这里写图片描述

可以看到在没有任何在程序没有连接数据库的时候procress的占用值是18,而参数值为300,所有此时占用量很小,那么接下来分别启动应用服务器下的tomcat,依次看一下应用服务器1下的第1个tomcat,应用服务器1下的第2个tomcat和应用服务器1下的第3个tomcat之后,procress占用值的变化~
启动第1个tomcat后访问主页:
这里写图片描述
启动第2个tomcat后访问主页:
这里写图片描述
启动第3个tomcat后访问主页:
这里写图片描述

不难发现每次process的值都增加了60,此时应用服务器1的tomcat已全部启动,那么也意味着应用服务器2的第二台tomcat启动后,process的值已超过300(198+120=318),所以当再启动应用服务器2的第3台tomcat时就无法登录了,所以我们仅需要修改process和session的最大值即可,修改语句如下:

 alter system set processes=1000 scope=spfile;
 alter system set sessions=1105 scope=spfile;

注意一下processes的值和sessions的值,Oracle官方文档中要求:

sessions=processes*1.5+5

也就是说sessions的值是根据processes的值计算后得到的,这里需要注意一下,最后重启一下Oracle服务即可,此时再分别开启应用服务器2的3个tomcat并依次访问主页后再看一下process和session的参数值和占用值情况:
这里写图片描述

如上图,可以看到process的值已经成功修改为1000,而此时开启了6个tomcat所占用的process值为378,session的占用值为375,都远远小于参数值,所以至此项目均已可以正常访问。

总结

简单记录一下这个Oracle异常的解决方案,希望对遇到同样问题的朋友有所帮助,The End。

  • 19
    点赞
  • 61
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
### 回答1: ORA-12514错误表示TNS监听程序无法识别当前请求的服务名称。这可能是因为服务名称不存在或TNS监听程序未正确配置。要解决此问题,您可以检查TNS监听程序的配置文件,确保服务名称正确配置并且监听程序正在运行。您还可以尝试重新启动TNS监听程序以解决此问题。 ### 回答2: ORA-12514错误提示意味着Oracle客户端无法连接到Oracle服务器。具体而言,处于客户端一侧的TNS监听程序无法识别所请求的连接标识符,这可能会是Oracle实例名称、主机名称或端口号等方面出现问题。 出现ORA-12514错误可能有多种原因,其中包括: 1. Oracle实例名称错误:如果TNS监听程序无法识别客户端比赛中请求的Oracle实例名称,则会弹出ORA-12514错误。 2. 监听程序未启动:如果TNS监听程序未在所需端口上运行,则无法识别客户端连接请求。 3. 主机名或IP地址错误:客户端可能无法确定正确的Oracle数据库服务器名称或IP地址,这可能会导致出现ORA-12514错误。 4. 网络连接问题:网络故障可能导致ORA-12514错误,这可能是由于路由不正确、安全策略或其他网络问题导致的。 解决ORA-12514错误的方法有以下几种: 1. 验证Oracle实例名称和监听程序是否正确:在客户端上手动验证Oracle实例名称和监听程序名称是否正确,确保它们与服务端一致。 2. 启动TNS监听服务:使用相应命令启动TNS监听服务,并确保其在所需端口上运行。 3. 验证主机名或IP地址正确:在客户端上验证主机名或IP地址是否正确,确保它们与服务端相同。 4. 检查网络连接:在本地机器和数据库服务器之间进行一些网络检查,确保网络连接的信息正确无误。 总之,ORA-12514是一个常见的Oracle数据库错误,可能由多种原因引起。解决此问题的最佳方法是仔细审查客户端和服务器之间的所有连接参数,并在客户端上手动验证所有连接参数。 ### 回答3: ORA-12514错误是Oracle数据库中常见的错误之一,通常是由于监听程序无法识别或不到指定的服务名或数据库实例名所导致的。这种类型的错误一般是由于以下几个原因引起的。 1.服务名或数据库实例名拼写错误 在Oracle数据库中,每个数据库都有一个唯一的服务名或数据库实例名。如果在连接字符串中输入错误的服务名或数据库实例名,则监听程序将无法识别它们,并显示ORA-12514错误。因此,在连接Oracle数据库之前,应该确认输入的服务名或数据库实例名是否正确。 2.监听程序未启动或配置错误 确保监听程序正在运行,并且所需的监听器已在监听程序的配置文件(listener.ora)中正确声明。另外,确保监听程序的版本与Oracle数据库版本兼容。如果监听程序未启动或配置错误,Oracle数据库将无法使用监听程序中声明的服务名或数据库实例名,并显示ORA-12514错误。 3.防火墙或网络故障 防火墙或网络故障可能导致监听程序无法到数据库实例,从而导致ORA-12514错误。如果发现防火墙或网络故障,应该检查防火墙或网络设置是否正确,并尝试重新启动监听程序。 4.Oracle数据库实例未启动 如果Oracle数据库实例未启动,则监听程序将无法到数据库实例,并显示ORA-12514错误。确保Oracle数据库实例已启动,并且所需的服务名已注册到监听程序中。 总之,ORA-12514错误是由于监听程序无法识别或不到指定的服务名或数据库实例名所导致的。要解决此错误,需要确认输入的服务名或数据库实例名是否正确、监听程序是否已正确配置、防火墙或网络是否设置正确,以及Oracle数据库实例是否已启动。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值