- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 33.6k
trace_events: add more process metadata #21785
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
Now that TracedValue has landed, add more detailed process `__metadata` including versions, arch, platform, release detail, and argv/execArgv to the trace event log.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would really like it if we could avoid the overhead of these calls when tracing is not enabled, especially if this is going to be a more common pattern?
        
          
                src/node_internals.h
              
                Outdated
          
        
      | #include "uv.h" | ||
| #include "v8.h" | ||
| #include "tracing/trace_event.h" | ||
| #include "tracing/traced_value.h" | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we include these headers where they are used, rather than (almost) globally?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sure
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would really like it if we could avoid the overhead of these calls when tracing is not enabled, especially if this is going to be a more common pattern?
Retracting my own review comment: I think I have a good idea for how to do that, let me code that out real quick :)
Edit: No, sorry. My idea was to create a custom kind of smart pointer to use instead of std::unique_ptr<TracedValue>, which would mirror these methods and turn them into no-ops if the handle contained nullptr.
But that requires knowing in advance whether a tracing category is enabled, and I don’t really know how to do that :/
| There's a way. The difficulty with metadata events is that they are always implicitly enabled if any tracing at all is enabled. So we would need to separate them out to allow on demand creation. I can work on that. | 
| 
 I'll be pushing a commit in a few minutes... but the way to do this is to attach a  | 
| Ok, @addaleax ... take a look now. I'm using a  Note: by switching to this, just to keep things simple, the process metadata no longer includes the argv and execArgv details since those are not around when the  | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks!
Now that TracedValue has landed, add more detailed process `__metadata` including versions, arch, platform, release detail, and argv/execArgv to the trace event log. PR-URL: nodejs#21785 Reviewed-By: Anna Henningsen <[email protected]>
| Landed in ededb4b 🎉 | 
Now that TracedValue has landed, add more detailed process `__metadata` including versions, arch, platform, release detail, and argv/execArgv to the trace event log. PR-URL: #21785 Reviewed-By: Anna Henningsen <[email protected]>
Now that TracedValue has landed, add more detailed
process
__metadataincluding versions, arch, platform,release detail, and argv/execArgv to the trace event
log.
This adds an entry like:
{ "pid":46021, "tid":46021, "ts":4996201438, "tts":31331, "ph":"M", "cat":"__metadata", "name":"node", "dur":0, "tdur":0, "args":{ "process":{ "versions":{ "http_parser":"2.8.0", "node":"11.0.0-pre", "v8":"6.7.288.46-node.14", "uv":"1.22.0", "zlib":"1.2.11", "ares":"1.14.0", "modules":"64", "nghttp2":"1.32.0", "napi":"3", "openssl":"1.1.0h" }, "arch":"x64", "platform":"linux", "release":{ "name":"node" }, "argv":["./node"], "execArgv":["--trace-event-categories","node.perf"] } } }Checklist
(UNIX), orvcbuild test` (Windows) passes