189 8069 5689

Java程序卡住了怎么办

本篇内容介绍了“Java程序卡住了怎么办”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

成都创新互联是专业的榆次网站建设公司,榆次接单;提供成都网站制作、网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行榆次网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!

1.获取现场故障信息

jstack 6688

参数为PID,这时我们看堆栈信息,发现没有自己程序相关的类,但发现下面这样的句子:

"Druid-ConnectionPool-Create-418179060" #25 daemon prio=5 os_prio=0 tid=0x00007fa74d8ad000 nid=0x15a84 waiting on condition [0x00007fa6f8a30000]
   java.lang.Thread.State: WAITING (parking)
	at sun.misc.Unsafe.park(Native Method)
	- parking to wait for  <0x00000000c47d0990> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)
	at java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)
	at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2039)
	at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2480)

哦,原来是Druid在等待导致线程卡住,那怎么办呢?

2.根据打印信息检索解决方案

开始使用必应检索了一下,发现这篇讨论:线程卡死在druiddatasource上

3.根据检索到的信息做出尝试

既然讨论中提到可能和版本有关就检查了自己使用的版本,发现版本很新,出问题的可能很小。那么就调大最大活跃数进行试验。 发现在调大最大活跃数之后,使用top命令查询,果然,cpu不再占用率很低,cpu开始开心地跑起来了。通过了这个并发数量的压力测试。

4.其它有益的思路

  1. 如果使用中文无法搜索出想要的结果,尝试使用英文搜索。

  2. 如果自己已经尝试过三个方案结果失败或者已经尝试半个工作日了,请立即上报上一级或请教周边有经验的人员(工作不是训练场,解决问题最首要)。

“Java程序卡住了怎么办”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!


分享标题:Java程序卡住了怎么办
网站链接:http://jkwzsj.com/article/gjoisg.html

其他资讯