mirror of
https://github.com/spring-projects/spring-boot.git
synced 2024-07-05 00:56:58 +08:00
Add MemoryInfo to ProcessInfo
This commit is contained in:
parent
895fbd7057
commit
a9fce43b8d
@ -16,6 +16,10 @@
|
|||||||
|
|
||||||
package org.springframework.boot.info;
|
package org.springframework.boot.info;
|
||||||
|
|
||||||
|
import java.lang.management.ManagementFactory;
|
||||||
|
import java.lang.management.MemoryMXBean;
|
||||||
|
import java.lang.management.MemoryUsage;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Information about the process of the application.
|
* Information about the process of the application.
|
||||||
*
|
*
|
||||||
@ -50,6 +54,24 @@ public class ProcessInfo {
|
|||||||
return runtime.availableProcessors();
|
return runtime.availableProcessors();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Memory information for the process. These values can provide details about the
|
||||||
|
* current memory usage and limits selected by the user or JVM ergonomics (init, max,
|
||||||
|
* committed, used for heap and non-heap). If limits not set explicitly, it might not
|
||||||
|
* be trivial to know what these values are runtime; especially in (containerized)
|
||||||
|
* environments where resource usage can be isolated (for example using control
|
||||||
|
* groups) or not necessarily trivial to discover. Other than that, these values can
|
||||||
|
* indicate if the JVM can resize the heap (stop-the-world).
|
||||||
|
* @return heap and non-heap memory information
|
||||||
|
* @since 3.4.0
|
||||||
|
* @see MemoryMXBean#getHeapMemoryUsage()
|
||||||
|
* @see MemoryMXBean#getNonHeapMemoryUsage()
|
||||||
|
* @see MemoryUsage
|
||||||
|
*/
|
||||||
|
public MemoryInfo getMemory() {
|
||||||
|
return new MemoryInfo();
|
||||||
|
}
|
||||||
|
|
||||||
public long getPid() {
|
public long getPid() {
|
||||||
return this.pid;
|
return this.pid;
|
||||||
}
|
}
|
||||||
@ -62,4 +84,53 @@ public class ProcessInfo {
|
|||||||
return this.owner;
|
return this.owner;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static class MemoryInfo {
|
||||||
|
|
||||||
|
private static final MemoryMXBean memoryMXBean = ManagementFactory.getMemoryMXBean();
|
||||||
|
|
||||||
|
private final MemoryUsageInfo heap;
|
||||||
|
|
||||||
|
private final MemoryUsageInfo nonHeap;
|
||||||
|
|
||||||
|
MemoryInfo() {
|
||||||
|
this.heap = new MemoryUsageInfo(memoryMXBean.getHeapMemoryUsage());
|
||||||
|
this.nonHeap = new MemoryUsageInfo(memoryMXBean.getNonHeapMemoryUsage());
|
||||||
|
}
|
||||||
|
|
||||||
|
public MemoryUsageInfo getHeap() {
|
||||||
|
return this.heap;
|
||||||
|
}
|
||||||
|
|
||||||
|
public MemoryUsageInfo getNonHeap() {
|
||||||
|
return this.nonHeap;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class MemoryUsageInfo {
|
||||||
|
|
||||||
|
private final MemoryUsage memoryUsage;
|
||||||
|
|
||||||
|
MemoryUsageInfo(MemoryUsage memoryUsage) {
|
||||||
|
this.memoryUsage = memoryUsage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getInit() {
|
||||||
|
return this.memoryUsage.getInit();
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getUsed() {
|
||||||
|
return this.memoryUsage.getUsed();
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getCommited() {
|
||||||
|
return this.memoryUsage.getCommitted();
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getMax() {
|
||||||
|
return this.memoryUsage.getMax();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -18,6 +18,8 @@ package org.springframework.boot.info;
|
|||||||
|
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import org.springframework.boot.info.ProcessInfo.MemoryInfo.MemoryUsageInfo;
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -35,6 +37,17 @@ class ProcessInfoTests {
|
|||||||
assertThat(processInfo.getPid()).isEqualTo(ProcessHandle.current().pid());
|
assertThat(processInfo.getPid()).isEqualTo(ProcessHandle.current().pid());
|
||||||
assertThat(processInfo.getParentPid())
|
assertThat(processInfo.getParentPid())
|
||||||
.isEqualTo(ProcessHandle.current().parent().map(ProcessHandle::pid).orElse(null));
|
.isEqualTo(ProcessHandle.current().parent().map(ProcessHandle::pid).orElse(null));
|
||||||
|
|
||||||
|
MemoryUsageInfo heapUsageInfo = processInfo.getMemory().getHeap();
|
||||||
|
MemoryUsageInfo nonHeapUsageInfo = processInfo.getMemory().getNonHeap();
|
||||||
|
assertThat(heapUsageInfo.getInit()).isPositive().isLessThanOrEqualTo(heapUsageInfo.getMax());
|
||||||
|
assertThat(heapUsageInfo.getUsed()).isPositive().isLessThanOrEqualTo(heapUsageInfo.getCommited());
|
||||||
|
assertThat(heapUsageInfo.getCommited()).isPositive().isLessThanOrEqualTo(heapUsageInfo.getMax());
|
||||||
|
assertThat(heapUsageInfo.getMax()).isPositive();
|
||||||
|
assertThat(nonHeapUsageInfo.getInit()).isPositive();
|
||||||
|
assertThat(nonHeapUsageInfo.getUsed()).isPositive().isLessThanOrEqualTo(heapUsageInfo.getCommited());
|
||||||
|
assertThat(nonHeapUsageInfo.getCommited()).isPositive();
|
||||||
|
assertThat(nonHeapUsageInfo.getMax()).isEqualTo(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user