static { // Do this once here. // Scan for Metaspace update notices as part of the GC log, e.g. in this form: // [gc,metaspace ] GC(0) Metaspace: 11895K(14208K)->11895K(14208K) NonClass: 10552K(12544K)->10552K(12544K) Class: 1343K(1664K)->1343K(1664K)
metaSpaceRegexp = Pattern.compile(".*Metaspace: ([0-9]+).*->([0-9]+).*");
}
privatestaticvoid verifyContainsMetaSpaceUpdate(OutputAnalyzer output) { // At least one metaspace line from GC should show GC being collected. boolean foundCollectedMetaSpace = output.asLines().stream()
.filter(s -> s.contains("[gc,metaspace"))
.anyMatch(TestMetaSpaceLog::check);
Asserts.assertTrue(foundCollectedMetaSpace);
}
privatestaticboolean check(String line) {
Matcher m = metaSpaceRegexp.matcher(line); if (m.matches()) { // Numbers for Metaspace occupation should grow. long before = Long.parseLong(m.group(1)); long after = Long.parseLong(m.group(2)); return before > after;
} returnfalse;
}
privatestaticvoid testMetaSpaceUpdate() throws Exception { // Propagate test.src for the jar file.
String testSrc= "-Dtest.src=" + System.getProperty("test.src", ".");
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.