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

[经验分享] 用PS 分析Weblogic占用CPU高的问题(AIX平台)

[复制链接]

尚未签到

发表于 2017-2-17 10:28:36 | 显示全部楼层 |阅读模式
  出处:http://t3.seeblog.net/?p=38
  我们项目上使用的AIX5.3和weblogic10.3,近期一直有服务器出现Weblogic进程占用CPU过高。
原来都是用gdb或dbx来跟踪问题。但是生产环境不便进行这种操作,后来找到了通过ps和分析javacore来查找问题的方法,分享个大家。
1、首先,要通过ps 命令查看制定进程对应的线程状态,例如:
ps -mp -o <WebLogic 进程号> THREAD
例如:ps -mp 30140 -o THREAD
结果如下:
USER PID PPID TID ST CP PRI SC WCHAN F TT BND COMMAND
incs 30140 33284 – A 585 60 160 * 242001 – - /usr/java6/bin/java -Xms1024m -Xmx1536m -Dfile.encoding=GBK -da -Dplatform.home=/app/bea/wlserver_10.3 -Dwls.home=/app/bea/wlserver_10.3/server -Dweblogic.home=/app/bea/wlserver_10.3/server -Dweblogic.management.discover=true -Dwlw.iterativeDev=false -Dwlw.testConsole=false -Dwlw.logErrorsToConsole= -Dweblogic.ext.dirs=/app/bea/patch_wls1030/profiles/default/sysext_manifest_classpath:/app/bea/patch_cie660/profiles/default/sysext_manifest_classpath -Dweblogic.threadpool.MinPoolSize=50 -Dweblogic.threadpool.MaxPoolSize=100 -Dweblogic.Name=AdminServer -Djava.security.policy=/app/bea/wlserver_10.3/server/lib/weblogic.policy weblogic.Server
- – - 36885 S 0 82 1 ea004820 8410400 – - -
- – - 37603 S 0 82 1 ea004920 8410400 – - -
- – - 38105 S 0 60 1 ea004a20 8410404 – - -
- – - 43117 S 21 60 1 – 418400 – - -
- – - 44007 S 0 82 1 ea0055a0 8410400 – - -
- – - 44121 S 0 82 1 ea005620 8410400 – - -
- – - 44673 S 8 60 1 ea005720 8410400 – - -
- – - 45169 S 0 82 1 ea005820 8410400 – - -
- – - 45535 R 20 60 0 – 400000 – - -
- – - 45707 S 1 82 1 35c01fa0 c10400 – - -
- – - 46193 S 0 82 1 ea005a20 8410400 – - -
- – - 46865 S 0 82 1 ea005ba0 8410400 – - -
- – - 47331 S 0 82 1 ea005c20 8410400 – - -
- – - 47507 R 19 60 1 30117d28 c00000 – - -
- – - 47757 S 0 82 1 ea005d20 8410400 – - -
- – - 48057 S 0 82 1 ea005da0 8410400 – - -
- – - 49681 S 0 82 1 ea006120 8410400 – - -
- – - 50095 S 0 82 1 ea0061a0 8410400 – - -
。。。。。。
2、同时手工生成threaddump文件,执行 kill -3 <WebLogic 进程号>
这样会在你的domain目录下生成类似  javacore.20100318.092950.30140.0022.txt 之类的文本文件
3、同样的操作,每个3-5秒钟重复做几次
4、分析ps 得到的结果中“CP” 一列,数值较高的就是当前占用CPU较多的线程,例如上面列表中的TID为“43117”的 “CP”值为21,相对较大;
5、将该CP值转换成16进制数值(原来是十进制),43117->A86D
6、打开对应的javacore文件,查找A86D,
可以找到这样一行
“3XMTHREADINFO1            (native thread ID:0xA86D, native priority:0×5, native policy:UNKNOWN)”
后面就是该线程的堆栈信息,这样,你就可以从中了解到该现正等待的原因了。
例子中显示结果如下:
4XESTACKTRACE          at java/net/SocketInputStream.socketRead0(Native Method)
4XESTACKTRACE          at java/net/SocketInputStream.read(SocketInputStream.java:140(Compiled Code))
4XESTACKTRACE          at com/unisys/cc/common/tcp/PackageTool.readBytes(PackageTool.java:75)
4XESTACKTRACE          at com/unisys/cc/common/tcp/PackageTool.read(PackageTool.java:123)
4XESTACKTRACE          at com/unisys/cc/common/tcp/TcpClient.receiveDataFromServer(TcpClient.java:235)
4XESTACKTRACE          at com/unisys/cc/common/SocketWorker.submit(SocketWorker.java:75)
4XESTACKTRACE          at com/unisys/cc/common/SocketWorker.submit(SocketWorker.java:36)
该线程正在通过网络读取远程数据,说明网络传输可能存在问题。

运维网声明 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-343351-1-1.html 上篇帖子: WebLogic经验:发布Eclipse中的创建的工程 下篇帖子: weblogic之"记录上一个资源"事务优化
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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