Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-8245120

JFR: Parser unable to return typed version

XMLWordPrintable

    • Icon: Bug Bug
    • Resolution: Fixed
    • Icon: P2 P2
    • 15
    • 14.0.1, 15
    • hotspot
    • None
    • jfr
    • b25
    • Verified

        When a recording is parsed, known types are materialized in a Java representation, such as j.j.c.RecordedThread. For some reason this doesn't work, leading to the object defaulting to j.j.c.RecordedObject, which then can't be cast, resulting in j.l.ClassCastException.


        java.lang.ClassCastException: class jdk.jfr.consumer.RecordedObject cannot be cast to class jdk.jfr.consumer.RecordedThread (jdk.jfr.consumer.RecordedObject and jdk.jfr.consumer.RecordedThread are in module jdk.jfr of loader 'bootstrap')
        at jdk.jfr/jdk.jfr.consumer.RecordedEvent.getThread(RecordedEvent.java:70)
        at JFRStreamingIssue$JFRStreamConsumer.onEvent(JFRStreamingIssue.java:64)
        at JFRStreamingIssue$JFRStreamConsumer.access$0(JFRStreamingIssue.java:61)
        at jdk.jfr/jdk.jfr.internal.consumer.Dispatcher$EventDispatcher.offer(Dispatcher.java:52)
        at jdk.jfr/jdk.jfr.internal.consumer.Dispatcher.dispatch(Dispatcher.java:165)
        at jdk.jfr/jdk.jfr.internal.consumer.EventDirectoryStream.processOrdered(EventDirectoryStream.java:211)
        at jdk.jfr/jdk.jfr.internal.consumer.EventDirectoryStream.processRecursionSafe(EventDirectoryStream.java:139)
        at jdk.jfr/jdk.jfr.internal.consumer.EventDirectoryStream.process(EventDirectoryStream.java:97)
        at jdk.jfr/jdk.jfr.internal.consumer.AbstractEventStream.execute(AbstractEventStream.java:243)
        at jdk.jfr/jdk.jfr.internal.consumer.AbstractEventStream$1.run(AbstractEventStream.java:265)
        at jdk.jfr/jdk.jfr.internal.consumer.AbstractEventStream$1.run(AbstractEventStream.java:262)
        at java.base/java.security.AccessController.doPrivileged(AccessController.java:391)
        at jdk.jfr/jdk.jfr.internal.consumer.AbstractEventStream.run(AbstractEventStream.java:262)
        at jdk.jfr/jdk.jfr.internal.consumer.AbstractEventStream.start(AbstractEventStream.java:222)
        at jdk.jfr/jdk.jfr.consumer.RecordingStream.start(RecordingStream.java:329)
        at JFRStreamingIssue.subscribeJFR(JFRStreamingIssue.java:46)
        at java.base/java.lang.Thread.run(Thread.java:832)



        Reproducer:
        import jdk.jfr.consumer.RecordedEvent;
        import jdk.jfr.consumer.RecordingStream;

        import java.io.BufferedWriter;
        import java.io.FileWriter;
        import java.io.IOException;
        import java.io.Writer;
        import java.util.concurrent.ExecutorService;
        import java.util.concurrent.SynchronousQueue;
        import java.util.concurrent.ThreadPoolExecutor;
        import java.util.concurrent.TimeUnit;

        public class JFRStreamingIssue {
            public static void main(String[] args) {
                Thread jfrStreamThread = new Thread(JFRStreamingIssue::subscribeJFR);
                jfrStreamThread.start();
                ExecutorService executor = new ThreadPoolExecutor(0, Integer.MAX_VALUE,
                        5L, TimeUnit.SECONDS,
                        new SynchronousQueue<Runnable>());
                for (int i = 0; i < 10000; i++) {
                    executor.submit(() -> {
                        try {
                            Thread.sleep(100);
                        } catch (Exception ex) {

                        }
                    });
                }
                System.out.println("done");
            }

            private static void subscribeJFR() {
                System.out.println("subscribeJFR");
                try {
                    try (Writer writer = new BufferedWriter(new FileWriter("events.txt"))) {
                        JFRStreamConsumer consumer = new JFRStreamConsumer(writer);
                        try (RecordingStream st = new RecordingStream()) {
                            st.enable("jdk.ThreadStart");
                            st.enable("jdk.ThreadEnd");
                            st.enable("jdk.ThreadSleep");
                            st.enable("jdk.ThreadPark");
                            st.onEvent("jdk.ThreadStart", consumer::onEvent);
                            st.onEvent("jdk.ThreadEnd", consumer::onEvent);
                            st.onEvent("jdk.ThreadSleep", consumer::onEvent);
                            st.onEvent("jdk.ThreadPark", consumer::onEvent);
                            st.start();
                        }
                    }
                } catch (IOException ex) {

                }
            }

            private static class JFRStreamConsumer {
                private final Writer writer;

                public JFRStreamConsumer(Writer writer) {
                    this.writer = writer;
                }

                private void onEvent(RecordedEvent event) {
                    String serializedEvent = null;
                    try {
                        serializedEvent = String.valueOf(event.getThread());
                    } catch (Exception ex) {
                        ex.printStackTrace();
                        return;
                    }
                    try {
                        writer.write(serializedEvent);
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                }
            }
        }

              egahlin Erik Gahlin
              egahlin Erik Gahlin
              Votes:
              0 Vote for this issue
              Watchers:
              4 Start watching this issue

                Created:
                Updated:
                Resolved: