生成Java線程轉(zhuǎn)儲(chǔ)而不重新啟動(dòng)。
這是我們以編程方式進(jìn)行的操作:http ://pastebin.com/uS5jYpd4
我們使用JMXThreadMXBean和ThreadInfo類:
ThreadMXBean mxBean = ManagementFactory.getThreadMXBean();ThreadInfo[] threadInfos = mxBean.getThreadInfo(mxBean.getAllThreadIds(), 0);...
您也可以kill -QUIT pid在?unix下進(jìn)行操作以將堆棧轉(zhuǎn)儲(chǔ)到標(biāo)準(zhǔn)輸出中。還有jstack來轉(zhuǎn)儲(chǔ)JVM的堆棧。
我們還具有一個(gè)自動(dòng)化功能,如果應(yīng)用程序的平均負(fù)載高于某個(gè)閾值,則該功能將轉(zhuǎn)儲(chǔ)堆棧:
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;}解決方法
我想創(chuàng)建一個(gè)跟蹤內(nèi)存使用情況和cpu使用情況的線程。
如果應(yīng)用程序達(dá)到較高級(jí)別,我想生成一個(gè)堆轉(zhuǎn)儲(chǔ)或線程轉(zhuǎn)儲(chǔ)。
有沒有一種方法可以生成線程轉(zhuǎn)儲(chǔ)運(yùn)行時(shí)而無需重新啟動(dòng)?
相關(guān)文章:
1. mac里的docker如何命令行開啟呢?2. 為什么我ping不通我的docker容器呢???3. Docker for Mac 創(chuàng)建的dnsmasq容器連不上/不工作的問題4. docker容器呢SSH為什么連不通呢?5. nignx - docker內(nèi)nginx 80端口被占用6. 關(guān)docker hub上有些鏡像的tag被標(biāo)記““This image has vulnerabilities””7. angular.js使用$resource服務(wù)把數(shù)據(jù)存入mongodb的問題。8. dockerfile - 我用docker build的時(shí)候出現(xiàn)下邊問題 麻煩幫我看一下9. docker gitlab 如何git clone?10. docker 下面創(chuàng)建的IMAGE 他們的 ID 一樣?這個(gè)是怎么回事????

網(wǎng)公網(wǎng)安備