ORA-12519:解决办法
OERR: ORA-12519 TNS:no appropriate service handler found 客户端连接间歇性失败,报错ORA-12519
OERR: ORA-12519 TNS:no appropriate service handler found
客户端连接间歇性失败,报错ORA-12519
查询解决方法:
查看一下数据库现有的进程数,,是否已经达到参数processes的大小。
1、select count(*) from v$process; 取得数据库目前的进程数。
2、select value from v$parameter where name = 'processes'; 取得进程数的上限。
3、如已达到上限,修改initSID.ora中的processes的大小。
4、重新启动数据库到nomount状态下,执行create spfile from pfile; 并startup open。
查询数据库自启动以来最大的并发数量
select * from v$license
=====================================================================================
在压力测试的时候,JDBC连接出现了ORA-12519错误。
连接是报错如下:
ORA-12519, TNS:no appropriate service handler found The Connection descriptor used by the client was: 172.0.2.58:1521:rac11g1 检查了半天metalink,最终发现是由于Oracle初始化参数的设置问题导致了bug。 SQL> SHOW PARAMETER SESSION NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ java_max_sessionspace_size integer 0 java_soft_sessionspace_limit integer 0 license_max_sessions integer 0 license_sessions_warning integer 0 session_cached_cursors integer 50 session_max_open_files integer 10 sessions integer 600 shared_server_sessions integer SQL> SHOW PARAMETER PROCESS NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ aq_tm_processes integer 0 db_writer_processes integer 2 gcs_server_processes integer 2 global_txn_processes integer 1 job_queue_processes integer 1000 log_archive_max_processes integer 4 processes integer 150 根据Oracle文档,SESSIONS和TRANSACTIONS的初始化参数应该源于PROCESSES参数,根据默认设置SESSIONS = PROCESSES * 1.1 + 5。 但是目前SESSIONS的设置达到了600,而PROCESSES的设置没有改变,仍然为150,导致了过多的用户会话连接到Oracle上时,Oracle没有足够的后台进程来支持这些会话。 详细的问题描述可以参考metalink的文档:Doc ID: Note:240710.1。 解决方法很简单,直接设置合适的PROCESSES产生就可以了。 ===================================================================================== 修改process的值的方法二(针对LINUX系统): 先到ORACLE_BASE/admin/你的实例名/profile/目录下找到一个init.ora的文件,然后修改里面的process的值,然后将该文件拷贝到ORACLE_HOME/dbs目录下,并将文件重命名为initorcl.ora(其中的orcl为你的数据库实例名,我的数据库实例为orcl所以命名为 initorcl.ora) 用sys用户同时以sysoper身份登录sqlplus 即 sqlplus sys/sa as sysoper; 进入SQLPLUS后,先把数据库关闭,可以使用shutdown abort命令,也可以使用shutdown immediate命令,推荐使用shutdown abort命令。然后使用命令startup force即可,说白了就是重启数据库。
推荐阅读
-
MAC下MYSQL5.7.17连接不上的问题及解决办法
-
JS获取浮动(float)元素的style.left值为空的快速解决办法
-
Acer 3810T改XP后HDMI无声音输出的解决办法
-
Android Data Binding 在 library module 中遇到错误及解决办法
-
浏览器总是提示shock wave flash has crashed的解决办法
-
Win10正式版除Edge之外 IE等浏览器无法上网的解决办法
-
VS2010复制代码到word时出现中文乱码的解决办法
-
笔记本开机进不去系统 错误代码0xc000000f的解决办法
-
IE浏览器当前网页正在试图打开您的受信任的站点列表中的站点的警告解决办法
-
显卡驱动安装不上的两种解决办法