生成Java线程转储而不重新启动。
这是我们以编程方式进行的操作:http ://pastebin.com/uS5jYpd4
我们使用JMXThreadMXBean和ThreadInfo类:
ThreadMXBean mxBean = ManagementFactory.getThreadMXBean();ThreadInfo[] threadInfos = mxBean.getThreadInfo(mxBean.getAllThreadIds(), 0);...
您也可以kill -QUIT pid在〜unix下进行操作以将堆栈转储到标准输出中。还有jstack来转储JVM的堆栈。
我们还具有一个自动化功能,如果应用程序的平均负载高于某个阈值,则该功能将转储堆栈:
private long lastcpuTimeMillis;private long lastPollTimeMillis;public void checkLoadAverage() { long Now = System.currentTimeMillis(); long currentcpuMillis = getTotalcpuTimeMillis(); double loadAvg = calcLoadAveragePercentage(Now, currentcpuMillis); if (loadAvg > LOAD_AVERAGE_DUMP_THRESHOLD) {try { dumpStack('Load average percentage is ' + loadAvg);} catch (IOException e) { // Oh well, we tried} } lastcpuTimeMillis = currentcpuMillis; lastPollTimeMillis = Now;}private long getTotalcpuTimeMillis() { long total = 0; for (long id : threadMxBean.getAllThreadIds()) {long cpuTime = threadMxBean.getThreadcpuTime(id);if (cpuTime > 0) { total += cpuTime;} } // since is in nano-seconds long currentcpuMillis = total / 1000000; return currentcpuMillis;}private double calcLoadAveragePercentage(long Now, long currentcpuMillis) { long timeDiff = Now - lastPollTimeMillis; if (timeDiff == 0) {timeDiff = 1; } long cpuDiff = currentcpuMillis - lastcpuTimeMillis; double loadAvg = (double) cpuDiff / (double) timeDiff; return loadAvg;}解决方法
我想创建一个跟踪内存使用情况和cpu使用情况的线程。
如果应用程序达到较高级别,我想生成一个堆转储或线程转储。
有没有一种方法可以生成线程转储运行时而无需重新启动?
相关文章:
1. javascript - 关于数组的循环遍历问题2. javascript - 正则匹配字符串特定语句后的数字3. javascript - 请指条明路,angular的$event,在select中却是undefined?4. java 线程池序号一直增加问题5. python - Pycharm调试代码进行列表遍历时,如何直接赋值指定元素6. 在cmd下进入mysql数据库,可以输入中文,但是查看表信息,不显示中文,是怎么回事,怎新手,请老师7. python - 有一个函数名(字符串形式),如何能够调用这个函数?8. mysql优化 - mysql 多表联合查询,求一个效率最高的查询9. navicat与MYSQL5.7搭配问题10. MySQL客户端吃掉了SQL注解?

网公网安备