处理Weblogic卡住的线程

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

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

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

您可以采取什么措施来避免应用程序完全失败?
 

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

如何识别问题?
 

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

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

  • TDA –线程转储分析器
  • 武士

如何解决该问题?
 

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

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

  • https://blogs.oracle.com/jamesbayer/entry/work_manager_leash_for_slow_js
  • http://jdeveloperfaq.blogspot.com/2011/05/faq-34-using-weblogic-work-managers-to.html

测试:如何创建卡死线程?
 
如何创建“卡住线程”以测试您的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)

更多挖掘:

  • 弗兰克·芒茨(Frank Munz)的精彩文章: WebLogic卡住了线程:创建,理解和处理它们 。 已针对Weblogic 12c更新。 还包括用于创建“粘滞线程”的示例应用程序。
  • http://stackoverflow.com/questions/2709410/weblogic-stuck-thread-protection

src:

  • Maxence Button的精彩文章: http : //m-button.blogspot.com/2008/07/using-wlst-to-perform-regular.html
  • http://download.oracle.com/docs/cd/E13222_01/wls/docs81/perfor/WLSTuning.html#1125714
  • http://download.oracle.com/docs/cd/E21764_01/web.1111/e13701/overload.htm
  • http://java.sys-con.com/node/358060?page=0,0

参考:在ADF和Weblogic How To博客上, 与我们的JCG合作伙伴 Spyros Doulgeridis 处理Weblogic的卡死线程有关 。


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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/372466.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

控件自定义左键点击消息相应函数的问题(请懂的人来解答一下)

【问题描述】 自定义CTouchInputEdit类&#xff0c;继承自CEdit。 实现一个新的功能&#xff0c;当点击edit控件的时候&#xff0c;弹出一个输入框。 下面的代码片段1&#xff0c;当点击控件之后&#xff0c;会弹出输入框&#xff0c;退出输入框以后&#xff0c;在窗体的任何位…

电话圈(floyd)

题意&#xff1a; 如果两个人相互打电话&#xff0c;则说他们在同一个电话圈里。例如&#xff0c;a打给b&#xff0c;b打给c&#xff0c;c打给d&#xff0c;d打给a&#xff0c;则这4个人在同一个圈里&#xff1b;如果e打给f但f不打给e&#xff0c;则不能推出e和f在同一个电话圈…

计算机二级网址打不开,大神为你解决win7系统打不开二级网页链接的操作教程...

许多win7系统电脑的时候,常常会遇到win7系统打不开二级网页链接的情况&#xff0c;比如近日有用户到本站反映说win7系统打不开二级网页链接的问题&#xff0c;但是却不知道要怎么解决win7系统打不开二级网页链接&#xff0c;我们依照首先我们打开IE浏览器&#xff0c;然后点击上…

3步实现Jetty和Eclipse集成

本教程将引导您逐步了解如何集成Jetty和Eclipse&#xff0c;以及如何在Eclipse中的Jetty服务器上运行Web应用程序。 脚步&#xff1a; 安装Jetty Eclipse插件 建立网路应用程式 运行网络应用 1 –安装Jetty Eclipse插件 将服务器添加到“服务器”视图时&#xff0c;将不会…

【Linux开发】如何更改linux文件的拥有者及用户组(chown和chgrp)

本文整理自&#xff1a; http://blog.163.com/yanenshun126/blog/static/128388169201203011157308/http://ydlmlh.iteye.com/blog/1435157一、基本知识在Linux中&#xff0c;创建一个文件时&#xff0c;该文件的拥有者都是创建该文件的用户。该文件用户可以修改该文件的拥有者…

使用Akka处理1000万条消息

Akka演员承诺并发。 有什么更好的模拟方式&#xff0c;看看使用商品硬件和软件处理1000万条消息需要花费多少时间&#xff0c;而无需进行任何低级调整。我用Java编写了整个1000万条消息的处理过程&#xff0c;整个结果令我惊讶。 当我在具有Intel i5 – 4核&#xff0c;4 Gb RA…

PHP中unset,array_splice删除数组中元素的区别

php中删除数组元素是非常的简单的&#xff0c;但有时删除数组需要对索引进行一些排序要求我们会使用到相关的函数&#xff0c;这里我们来介绍使用unset,array_splice删除数组中的元素区别吧 如果要在某个数组中删除一个元素&#xff0c;可以直接用的unset&#xff0c;但是数组的…

dart服务器开发性能,DartVM服务器开发(第四天)--代码优化

优化请求上一篇文章中&#xff0c;我们通过依赖第三方http_server这个包实现将html页面返回给浏览器&#xff0c;但是一般的服务器都包含请求html&#xff0c;json格式的传递&#xff0c;这样就有可能造成了混乱&#xff0c;下面我们使用http_server这个包进行优化吧&#xff0…

JBox2D和JavaFX:事件与力量

在昨天的示例中&#xff0c;您看到了如何创建一个简单的世界并使用WorldView进行显示&#xff0c;以及如何提供自定义渲染器。 现在&#xff0c;我们将添加一些用户输入。 我们将创建一个类似于弹球机中的鳍状肢的控件。 为此&#xff0c;我们将创建一个关节。 在JBox2D中&…

【Android】SVG和VectorDrawable——相关格式转换

SVG是矢量图&#xff0c;刚接触尚不能仔细介绍&#xff0c;但只需记得一点&#xff1a;放大不失真&#xff0c;存储也方便。 因为多数户型图使用SVG格式&#xff0c;Android要用的话必须通过相关转换工具&#xff0c;将原SVG格式文件&#xff0c;转换为XML后缀的VectorDrawable…

服务器时间维护制度,网络设备及服务器日常维护管理制度

第一章总则第一条&#xff1a;为保证机房设备与信息的安全&#xff0c;保障本校服务器及网络系统在良好、稳定、高效、快速的安全运行。特制定本制度。第二条&#xff1a;为确保中心机房网络设备特别是服务器安全&#xff0c;根据岗位职责设立机房管理员&#xff0c;负责对机房…

SELinux入门简介

操作系统有两类访问控制&#xff1a;自主访问控制&#xff08;DAC&#xff09;和强制访问控制&#xff08;MAC&#xff09;。标准Linux安全是一种DAC&#xff0c;SELinux为Linux增加了一个灵活的和可配置的的MAC。 进程启动时所拥有的权限就是运行此进程的用户权限&#xff0c;…

RESTEasy教程第3部分:异常处理

在开发软件应用程序时&#xff0c;异常处理是显而易见的要求。 如果在处理用户请求时发生任何错误&#xff0c;我们应该向用户显示一个错误页面&#xff0c;其中包含详细的异常消息&#xff0c;错误代码&#xff08;可选&#xff09;&#xff0c;更正输入和重试的提示&#xff…

WinForm关闭窗体彻底的退出方式

//System.Environment.Exit(0); //Process.GetCurrentProcess().Kill(); //System.Threading.Thread.CurrentThread.Abort(); System.Diagnostics.Process.GetCurrentProcess().Kill();Application.Exit(); 转载于:https://www.cnblogs.com/XuPengLB/p/5799178.html

创建css的时候选择器有哪几类,CSS3-CSS的选择器共有几类?

CSS 3对属性选择器的又增加了3种子字符串的匹配方式&#xff1a;E[att^"val"]匹配所有E元素中att属性的值以“val”开始的所有元素。E[att$"val"]匹配所有E元素中att属性的值以“val”结束的所有元素。E[att*”val”]匹配所有E元素中att属性的值中包含字符…

在Grails 2.0中使用Servlet 3.0异步功能

上周&#xff0c;我与某人谈论了Grails 2中对Servlet 3.0异步功能的新支持&#xff0c;并意识到我对可用功能并不了解。 所以我想我会尝试一下并分享一些例子。 该文档对这个主题有些了解&#xff0c;因此首先介绍一些背景信息。 在3.0规范中进行异步工作的主要方式是javax.ser…

接口怎么实例化?

最开始看到数据库连接的时候忽然想到这个问题&#xff1a; Connection connull;try {Class.forName(Driver);} catch (ClassNotFoundException e) {e.printStackTrace();}try {conDriverManager.getConnection(url, user, pass);} catch (SQLException e) {e.printStackTrace()…

css中基线指的是哪一条线,如何设置基线网络_CSS, Vertical Rhythm 教程_W3cplus

首先&#xff0c;当谈到排版&#xff0c;我们先要了解基线是什么&#xff1f;维基百科是这样定义)的&#xff1a;在排版和书法中&#xff0c;基线是以字终sit底线为基础&#xff0c;并且向两边延伸的直线。好极了&#xff0c;但我为什么要忽视他呢&#xff1f;好希望你充满激情…

libvirt里的面向对象的C语言

C语言&#xff1a;类的声明和定义 1 // 通用父类的定义2 struct _virClass {3 virClassPtr parent;4 5 unsigned int magic;6 char *name;7 size_t objectSize;8 9 virObjectDisposeCallback dispose; 10 }; 11 typedef struct _virClass virClass; 12 typ…

使用JGroups进行ElasticMQ消息复制

ElasticMQ是一台消息服务器&#xff0c;具有Scala&#xff0c;Java和与Amazon SQS兼容的接口。 它通过跨服务器群集复制消息来支持有保证的消息传递&#xff0c;并通过日志记录实现消息持久性。 消息复制是ElasticMQ的核心功能之一。 但是&#xff0c;如果您看一下代码&#xf…