设为首页 收藏本站
查看: 709|回复: 0

[经验分享] WebLogic Server 性能优化 (1) 执行线程篇

[复制链接]

尚未签到

发表于 2017-2-17 10:34:10 | 显示全部楼层 |阅读模式
  说实话,执行线程的设置没有什么准确的计算公式,一切都得依赖测试和实际的运行情况。设置少了,会有等待队列;设置多了,性能也未必高。但是,对于调优,我还是建议先不足再增加,即先少后多。通常情况下,如果一开始就把各种资源设置的很高,那么很可能问题就被掩盖了。如果设置的少,当出现故障时会有比较明显的表征。
  虽然没有计算公式,但是根据经验值,一颗CPU可以配置25-30之间的执行线程,当然,也有人说可以按照50线程/CPU计算。这个经验值的前提是,主机上没有其他的大型的占用资源较多的应用在运行。也就是说,一台主机上WebLogic Server实例,无论是一个,还是多个,他们的执行线程的总和大概是25*CPU数量到30*CPU数量之间。我经历过一个应用的压力测试,4CPU的 HP主机,同样的测试脚本,在不同的执行线程配置下进行测试和比较。结果是配置50和120的时候,TPS在300左右,当配置70的时候,能够达到 400左右。有可能70也不是最好的,但是至少说明执行线程的配置不是越多越好。
  说到这里,想起来另外一个比较常见的问题,就是设置的执行线程的数量还算合适,没有过高也没有过低,但是就是在压力测试的时候,发现TPS值很低,CPU的利用率也上不去。我遇到的有两种情况:
  1. 操作系统的补丁问题
  在HP-UX上执行大型Java应用,需要打上很多的补丁,在HP的官方站点可以查到
  http://www.hp.com/products1/unix/java/patches/index.html
  其中有一个补丁包就是和线程调度相关的,如果不打上这些补丁,那么对于Java的线程调度存在问题,导致CPU利用率也不高,但是执行效率较低,甚至可能导致进程Crash。所以在安装软件之前去官方网站查看所需要的补丁以及经过认证的相关产品是一个好习惯。
  2. 同步代码
  如果代码中存在同步方法,并且是调用率比较高的,那么可能会出现CPU利用率低并且TPS也低的情况。通常Java应用自身的同步代码并不是很多,但是所用到的一些扩展的包,就有可能用到了同步代码。最典型的一个例子是Log4j. 给出一个示例的Thread Dump
  “ExecuteThread: ‘152′ for queue: ‘weblogic.kernel.Default’” daemon prio=1 tid=0×08d9fef8 nid=0×1f28 waiting for monitor entry [5a1fd000..5a1fe24c]
at org.apache.log4j.Category.callAppenders(Category.java:185)
- waiting to lock <0×838664b0> (a org.apache.log4j.spi.RootCategory)
at org.apache.log4j.Category.forcedLog(Category.java:372)
at org.apache.log4j.Category.info(Category.java:674)
  …
  152号执行线程在等待<0×838664b0> (a org.apache.log4j.spi.RootCategory) 对象被其他线程释放同步锁。在完整的Thread dump中可以看出,有大量的线程都在等待同一个对象。这个对象被158号线程使用:
  “ExecuteThread: ‘158′ for queue: ‘weblogic.kernel.Default’” daemon prio=1 tid=0×08da4d28 nid=0×1f28 waiting for monitor entry [59efd000..59efe24c]
at java.lang.StackTraceElement.toString(StackTraceElement.java:130)
at java.lang.String.valueOf(String.java:2131)
at java.lang.StringBuffer.append(StringBuffer.java:370)
- locked <0xa32e5370> (a java.lang.StringBuffer)
at java.lang.Throwable.printStackTrace(Throwable.java:512)
- locked <0xa326af28> (a org.apache.log4j.spi.VectorWriter)
at org.apache.log4j.spi.ThrowableInformation.getThrowableStrRep(ThrowableInformation.java:50)
at org.apache.log4j.spi.LoggingEvent.getThrowableStrRep(LoggingEvent.java:333)
at org.apache.log4j.WriterAppender.subAppend(WriterAppender.java:295)
at org.apache.log4j.WriterAppender.append(WriterAppender.java:150)
at org.apache.log4j.AppenderSkeleton.doAppend(AppenderSkeleton.java:221)
- locked <0×83866430> (a org.apache.log4j.ConsoleAppender)
at org.apache.log4j.helpers.AppenderAttachableImpl.appendLoopOnAppenders(AppenderAttachableImpl.java:57)
at org.apache.log4j.Category.callAppenders(Category.java:187)
- locked <0×838664b0> (a org.apache.log4j.spi.RootCategory)
at org.apache.log4j.Category.forcedLog(Category.java:372)
  由于Log4j的同步代码导致出现上述的问题。所以,如果不是为了跟踪问题,尽量将Log4j的日志级别设置的高一些。减少同步代码的调用,能够极大的利用硬件资源。
  如果一个应用中有部分页面执行时间较长,并且使用频率较低,可以为这些JSP/Servlet或者EJB配置独立的执行线程(当然了,尽量优化应用才是治本之道),将执行效率低下的放到一个执行线程队列,将效率高的放到一个执行线程队列,这样就避免因为一个执行效率低的页面影响整个应用了。
  下面是简单的步骤说明:
  1. 配置整个Web应用到单独的执行队列
  编辑web应用的weblogic.xml,加入<wl-dispatch-policy>节点: <wl-dispatch-policy>yourexecutequeue</wl-dispatch-policy>
  2. 配置JSP/Servlet到单独的执行队列
  如果是JSP,编辑web应用的web.xml,加入一个<servlet>节点
  <servlet>
<servlet-name>myServlet</servlet-name>
<jsp-file>/context/package/file.jsp</jsp-file>
</servlet>
  然后在weblogic.xml中对这些Servlet进行配置
  <servlet-descriptor>
<servlet-name>the servlet name or the servlet for the jsp file</servlet-name>
<dispatch-policy>your customized queue name</dispatch-policy>
</servlet-descriptor>
  3. 配置EJB到单独的执行队列
  编辑weblogic-ejb-jar.xml,例如:
  <weblogic-enterprise-bean>
<ejb-name>Hello</ejb-name>
<jndi-name>lab.ejb.Hello</jndi-name>
<dispatch-policy>your customized queue name</dispatch-policy>
</weblogic-enterprise-bean>
  详细可以参考:
  Developing Web Applications for WebLogic Server http://edocs.bea.com/wls/docs81/webapp/index.html
  Programming WebLogic Enterprise JavaBeans http://edocs.bea.com/wls/docs81/ejb/index.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-343357-1-1.html 上篇帖子: Spring使用Weblogic容器提供的数据源配置方法 下篇帖子: 配置了weblogic集群但部署的时候报错,高手指点一下
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表