生成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. python - 請問這兩個地方是為什么呢?2. mysql優化 - mysql 一張表如果不能確保字段列長度一致,是不是就不需要用到char。3. python - 為什么match匹配出來的結果是<_sre.SRE_Match object; span=(0, 54), match=’’>4. mysql updtae追加數據sql語句5. javascript - 按鈕鏈接到另一個網址 怎么通過百度統計計算按鈕的點擊數量6. python中怎么對列表以區間進行統計?7. 大家都用什么工具管理mysql數據庫?8. Python處理Dict生成json9. 請教一個mysql去重取最新記錄10. mysql的循環語句問題
