weblogic最大线程

定义或什么是缠线?
 
如果线程 在设定 的时间 内连续工作(非空闲),则WebLogic Server会将其诊断为阻塞
您可以通过更改在诊断出线程被阻塞之前的时间长度( Stuck Thread Max Time ),以及通过更改服务器检查线程是否被阻塞的频率,来调整服务器的线程检测行为。 在此处查看如何更改“粘线最大时间”。

问题还是为什么“粘线”是邪恶的?
 
WebLogic Server自动检测执行队列中的线程何时变为“阻塞”状态。 由于卡住的线程无法完成其当前工作或接受新工作,因此服务器每次诊断出卡住的线程时都会记录一条消息。 如果执行队列中的所有线程都卡住,服务器将根据执行队列将其运行状况更改为“警告”或“严重”:

  • 如果默认队列中的所有线程都卡住,则服务器会将其运行状况更改为“ 严重” 。 (您可以将Node Manager应用程序设置为在严重运行状态下自动关闭和重新启动服务器。有关更多信息,请参阅“配置和管理WebLogic Server”中的“ Node Manager功能 ”。)
  • 如果weblogic.admin.HTTP,weblogic.admin.RMI或用户定义的执行队列中的所有线程都卡住了,则服务器会将其运行状况更改为“ 警告”
因此,实际上,几个“阻塞线程”可能不会使服务器崩溃,从而阻止服务器处理请求,但这是一个不好的信号。 通常,卡住的线程数将增加,并且服务器最终将崩溃。

为避免应用程序完全失败该怎么办?
 

WebLogic Server会定期检查卡住的线程(这是“ 卡住线程计时器间隔” ,您可以在此处进行调整)。 如果所有应用程序线程都卡住,则服务器实例将自身标记为失败,如果配置为失败,则退出。 您可以配置节点管理器或第三方高可用性解决方案以重新启动服务器实例以进行自动故障恢复。您可以将以下操作配置为在并非所有线程都卡住但卡住的线程数超过配置的阈值时发生:如果工作管理器卡住了线程,请关闭它。 关闭的工作管理器将通过发送拒绝消息来拒绝新工作并拒绝队列中的现有工作。 在群集中,群集客户端将故障转移到另一个群集成员。
  • 如果应用程序中存在线程阻塞,请关闭应用程序。 通过使其进入管理模式来关闭该应用程序。 属于该应用程序的所有工作管理器都将关闭,并按上述方式运行。
  • 将服务器实例标记为失败,如果服务器中存在线程阻塞,则将其关闭。 在群集中,已连接或尝试连接的群集客户端将故障转移到另一个群集成员。

如何识别问题?
 

推荐的方法是检查线程转储。 选中“ 发送电子邮件警报以查找有关带有线程转储线程卡住中间件魔术文章” ,使线程转储在发生时自动发送给您。

帮助您分析线程转储的工具有:

如何解决该问题?
 

确定导致卡住线程的代码(即执行所花费的时间超过堆栈线程的最大时间)后,可以使用工作管理器执行代码。 工作管理器具有“忽略卡住线程”选项,该选项使您能够执行长时间运行的作业。 见下文:

以下是有关如何创建工作管理器的一些帖子

测试:如何创建卡死线程?
 
如何创建“卡住线程”以测试您的weblogic设置? 将断点放在请求所调用的支持bean或模型方法中。 如果您在断点处等待“最大线程停留时间”,则会注意到服务器日志中将显示“线程滞留”跟踪:

<16 =?? 2011 12:28:22 ?? EET><Error><WebLogicServer><BEA-000337><[STUCK] ExecuteThread: '2' for queue: 
'weblogic.kernel.Default (self-tuning)' has been busy for "134" seconds working on the 
request "weblogic.servlet.internal.ServletRequestImpl@6e6f4718[
GET /---/---/----/---/days.xhtml HTTP/1.1
Connection: keep-alive
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/535.2 (KHTML, like Gecko) Chrome/15.0.874.120 Safari/535.2
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-GB,en-US;q=0.8,en;q=0.6
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3
Cookie: JSESSIONID=DYG5TDTZSnKLTFw5CMMdLCD9sPsZS4Jqlmxj9wdGNyt1BnPcfNrR!-1520792836




]", which is more than the configured time (StuckThreadMaxTime) of "60" seconds. Stack trace:
       --------------------------------------------(--------------------.java:83)
       javax.faces.component.UIComponentBase.encodeBegin(UIComponentBase.java:823)
       com.sun.faces.renderkit.html_basic.HtmlBasicRenderer.encodeRecursive(HtmlBasicRenderer.java:285)
       com.sun.faces.renderkit.html_basic.GridRenderer.renderRow(GridRenderer.java:185)
       com.sun.faces.renderkit.html_basic.GridRenderer.encodeChildren(GridRenderer.java:129)
       javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:848)
       org.primefaces.renderkit.CoreRenderer.renderChild(CoreRenderer.java:55)
       org.primefaces.renderkit.CoreRenderer.renderChildren(CoreRenderer.java:43)
       org.primefaces.component.fieldset.FieldsetRenderer.encodeContent(FieldsetRenderer.java:95)
       org.primefaces.component.fieldset.FieldsetRenderer.encodeMarkup(FieldsetRenderer.java:76)
       org.primefaces.component.fieldset.FieldsetRenderer.encodeEnd(FieldsetRenderer.java:53)
       javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:878)
       javax.faces.component.UIComponent.encodeAll(UIComponent.java:1620)
       javax.faces.render.Renderer.encodeChildren(Renderer.java:168)
       javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:848)
       org.primefaces.renderkit.CoreRenderer.renderChild(CoreRenderer.java:55)
       org.primefaces.renderkit.CoreRenderer.renderChildren(CoreRenderer.java:43)
       org.primefaces.component.panel.PanelRenderer.encodeContent(PanelRenderer.java:229)
       org.primefaces.component.panel.PanelRenderer.encodeMarkup(PanelRenderer.java:152)

更多挖掘:

src:

参考:ADF和Weblogic How To博客上, 我们的JCG合作伙伴 Spyros Doulgeridis 处理Weblogic的粘滞线程


翻译自: https://www.javacodegeeks.com/2012/05/dealing-with-weblogic-stuck-threads.html

weblogic最大线程

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐