我有一个简单的事件:
@Name("trace.dbquery")
public class QueryJfrEvent extends Event{
@Label("Event Name")
public String eventName;
@Label("Event Name2")
public String eventName2;
@Label("Event Name3")
public String eventName3;
@Label("timestamp")
public long timestamp;
}并使用它:
QueryJfrEvent qevent= new QueryJfrEvent();
if(qevent.isEnabled()){
String name = span.name();
System.out.println(" Check ---- " + name);
qevent.eventName = name;
qevent.eventName2 = name + "-bla-bla-bla";
qevent.eventName3 = "test-test-test";
qevent.timestamp = span.startTimestamp();
qevent.commit;
}当我第一次启动JFR (jcmd PID JFR.start name=test disk=true =./jfr/test.jfc filename=./jfr/result.jfr t.jfr duration=30s)时,一切正常。
显示所有字段eventName/eventName2/eventName3。
例如:
jfr print --events trace.dbquery result.jfr
trace.dbquery {
eventName = "SomeClassName"
eventName2 = "SomeClassName-bla-bla-bla"
eventName3 = "test-test-test"
timestamp = 1631023232432
}但是,当我第二次启动JFR时(相同的JVM,无需重启),因为"jcmd PID JFR.start name=test disk=true duration=30s=./jfr/test.jfc filename=./jfr/result2.jfr duration=30s“”字段eventName和eventName2为空,但测试正常“”event3 -name=test-eventName2“”
jfr print --events trace.dbquery result2.jfr
trace.dbquery {
eventName = N/A
eventName2 = N/A
eventName3 = "test-test-test"
timestamp = 1631023234343
}此代码"System.out.println(“Check -”+ name);“始终显示正确的名称值。
我尝试了Linux OpenJDK 11,16个最新版本。
发布于 2021-09-10 12:06:18
如果在JDK 17中修复了连续录制并向后移植到JDK 11.0.12,则会有一个bug导致字符串值丢失。
只有当字符串超过16个字符时,才会出现错误,因为这样可能会缓存该字符串。有关详细信息,请参阅:
https://stackoverflow.com/questions/69089892
复制相似问题