JavaでサーバーのCPUとメモリの使用状況を確認する必要があります。誰でもそれを行う方法を知っていますか?
JavaでサーバーのCPUとメモリの使用状況を確認する必要があります。誰でもそれを行う方法を知っていますか?
回答:
JVMのメモリを特に探している場合:
Runtime runtime = Runtime.getRuntime();
NumberFormat format = NumberFormat.getInstance();
StringBuilder sb = new StringBuilder();
long maxMemory = runtime.maxMemory();
long allocatedMemory = runtime.totalMemory();
long freeMemory = runtime.freeMemory();
sb.append("free memory: " + format.format(freeMemory / 1024) + "<br/>");
sb.append("allocated memory: " + format.format(allocatedMemory / 1024) + "<br/>");
sb.append("max memory: " + format.format(maxMemory / 1024) + "<br/>");
sb.append("total free memory: " + format.format((freeMemory + (maxMemory - allocatedMemory)) / 1024) + "<br/>");
ただし、これらはあくまでも目安としてください...
package mkd.Utils;
import java.io.File;
import java.text.NumberFormat;
public class systemInfo {
private Runtime runtime = Runtime.getRuntime();
public String Info() {
StringBuilder sb = new StringBuilder();
sb.append(this.OsInfo());
sb.append(this.MemInfo());
sb.append(this.DiskInfo());
return sb.toString();
}
public String OSname() {
return System.getProperty("os.name");
}
public String OSversion() {
return System.getProperty("os.version");
}
public String OsArch() {
return System.getProperty("os.arch");
}
public long totalMem() {
return Runtime.getRuntime().totalMemory();
}
public long usedMem() {
return Runtime.getRuntime().totalMemory() - Runtime.getRuntime().freeMemory();
}
public String MemInfo() {
NumberFormat format = NumberFormat.getInstance();
StringBuilder sb = new StringBuilder();
long maxMemory = runtime.maxMemory();
long allocatedMemory = runtime.totalMemory();
long freeMemory = runtime.freeMemory();
sb.append("Free memory: ");
sb.append(format.format(freeMemory / 1024));
sb.append("<br/>");
sb.append("Allocated memory: ");
sb.append(format.format(allocatedMemory / 1024));
sb.append("<br/>");
sb.append("Max memory: ");
sb.append(format.format(maxMemory / 1024));
sb.append("<br/>");
sb.append("Total free memory: ");
sb.append(format.format((freeMemory + (maxMemory - allocatedMemory)) / 1024));
sb.append("<br/>");
return sb.toString();
}
public String OsInfo() {
StringBuilder sb = new StringBuilder();
sb.append("OS: ");
sb.append(this.OSname());
sb.append("<br/>");
sb.append("Version: ");
sb.append(this.OSversion());
sb.append("<br/>");
sb.append(": ");
sb.append(this.OsArch());
sb.append("<br/>");
sb.append("Available processors (cores): ");
sb.append(runtime.availableProcessors());
sb.append("<br/>");
return sb.toString();
}
public String DiskInfo() {
/* Get a list of all filesystem roots on this system */
File[] roots = File.listRoots();
StringBuilder sb = new StringBuilder();
/* For each filesystem root, print some info */
for (File root : roots) {
sb.append("File system root: ");
sb.append(root.getAbsolutePath());
sb.append("<br/>");
sb.append("Total space (bytes): ");
sb.append(root.getTotalSpace());
sb.append("<br/>");
sb.append("Free space (bytes): ");
sb.append(root.getFreeSpace());
sb.append("<br/>");
sb.append("Usable space (bytes): ");
sb.append(root.getUsableSpace());
sb.append("<br/>");
}
return sb.toString();
}
}
freeMemory
ここでは、非常に異なるJVMで使用可能なメモリ量を返します
Sun JVMを使用していて、アプリケーションの内部メモリ使用量(アプリが使用している割り当てメモリのうちどれだけを使用するか)に関心がある場合は、JVM組み込みガベージコレクションロギングをオンにすることをお勧めします。起動コマンドに-verbose:gcを追加するだけです。
Sunのドキュメントから:
コマンドライン引数-verbose:gcは、すべてのコレクションで情報を出力します。-verbose:gc出力の形式は、J2SEプラットフォームのリリース間で変更される可能性があることに注意してください。たとえば、大規模なサーバーアプリケーションからの出力を次に示します。
[GC 325407K->83000K(776768K), 0.2300771 secs] [GC 325816K->83372K(776768K), 0.2454258 secs] [Full GC 267628K->83769K(776768K), 1.8479984 secs]
ここには、2つのマイナーコレクションと1つのメジャーコレクションがあります。矢印の前後の数字
325407K->83000K (in the first line)
ガベージコレクション前後のライブオブジェクトの合計サイズをそれぞれ示します。マイナーコレクションの後、カウントには、必ずしも生きているわけではないが再利用できないオブジェクトが含まれます。それらは直接生きているか、またはそれらが古い世代内にあるか、またはその世代から参照されているためです。括弧内の数字
(776768K) (in the first line)
利用可能な合計スペースで、永続的な世代のスペースは含まれません。これは、合計ヒープからサバイバースペースの1つを引いたものです。マイナーコレクションには約1/4秒かかりました。
0.2300771 secs (in the first line)
詳細については、http://java.sun.com/docs/hotspot/gc5.0/gc_tuning_5.htmlを参照してください。
ここから
OperatingSystemMXBean operatingSystemMXBean = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();
RuntimeMXBean runtimeMXBean = ManagementFactory.getRuntimeMXBean();
int availableProcessors = operatingSystemMXBean.getAvailableProcessors();
long prevUpTime = runtimeMXBean.getUptime();
long prevProcessCpuTime = operatingSystemMXBean.getProcessCpuTime();
double cpuUsage;
try
{
Thread.sleep(500);
}
catch (Exception ignored) { }
operatingSystemMXBean = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();
long upTime = runtimeMXBean.getUptime();
long processCpuTime = operatingSystemMXBean.getProcessCpuTime();
long elapsedCpu = processCpuTime - prevProcessCpuTime;
long elapsedTime = upTime - prevUpTime;
cpuUsage = Math.min(99F, elapsedCpu / (elapsedTime * 10000F * availableProcessors));
System.out.println("Java CPU: " + cpuUsage);
operatingSystemMXBean.getProcessCpuLoad();
ですか?Oracleのドキュメントによると、このメソッドは「Java仮想マシンプロセスの「最近のCPU使用量」を返します。」しかし、私はあなたの方法とこの方法の間に比較的大きな数の違いを見ます。
OperatingSystemMXBean
クラスがあります。1つは、で提供されるインターフェイスjava.lang
です。しかし、これをで拡張した別のバージョンもありcom.sun.management
ます。それはそれからである私が言及していた方法だOperatingSystemMXBean
ここで多くの回答に掲載されているruntime / totalMemoryソリューションを使用している場合(私は多くのことを行いました)、かなり正確で一貫した結果が必要な場合は、最初に2つのガベージコレクションを強制するようにしてください。
効率を上げるために、Javaは通常、GCを強制する前にガベージがすべてのメモリを埋めることを許可し、それでも通常は完全なGCではないため、runtime.freeMemory()の結果は常に「実際の」空きメモリ量と0の間のどこかにあります。 。
最初のGCはすべてを取得するのではなく、ほとんどを取得します。
上昇傾向は、freeMemory()呼び出しを実行するだけでは絶対に役に立たず、大きく変動する数値を取得することですが、2 gcを最初に実行する場合、それは非常に信頼できるゲージです。また、ルーチンがかなり遅くなります(おそらく数秒)。
CPU負荷を追跡する次の方法も追加します。
import java.lang.management.ManagementFactory;
import com.sun.management.OperatingSystemMXBean;
double getCpuLoad() {
OperatingSystemMXBean osBean =
(com.sun.management.OperatingSystemMXBean) ManagementFactory.
getPlatformMXBeans(OperatingSystemMXBean.class);
return osBean.getProcessCpuLoad();
}
JConsoleは、実行中のJavaアプリケーションを監視する簡単な方法です。または、プロファイラーを使用して、アプリケーションの詳細情報を取得できます。これにはNetBeans Profilerを使用するのが好きです。
YourKitのJavaプロファイラは、優れた商用ソリューションです。詳細については、CPUプロファイリングとメモリプロファイリングに関するドキュメントをご覧ください。
Eclipseの場合は、TPTP(Test and Performance Tools Platform)を使用してメモリ使用量などを分析できます。詳細