-
Notifications
You must be signed in to change notification settings - Fork 312
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
log template messages and errors #4856
Conversation
log.error
accepting multiple arguments
Overall package sizeSelf size: 8.01 MB Dependency sizes| name | version | self size | total size | |------|---------|-----------|------------| | @datadog/libdatadog | 0.2.2 | 29.27 MB | 29.27 MB | | @datadog/native-appsec | 8.3.0 | 19.37 MB | 19.38 MB | | @datadog/native-iast-taint-tracking | 3.2.0 | 13.9 MB | 13.91 MB | | @datadog/pprof | 5.4.1 | 9.76 MB | 10.13 MB | | protobufjs | 7.2.5 | 2.77 MB | 5.16 MB | | @datadog/native-iast-rewriter | 2.5.0 | 2.51 MB | 2.65 MB | | @opentelemetry/core | 1.14.0 | 872.87 kB | 1.47 MB | | @datadog/native-metrics | 3.0.1 | 1.06 MB | 1.46 MB | | @opentelemetry/api | 1.8.0 | 1.21 MB | 1.21 MB | | import-in-the-middle | 1.11.2 | 112.74 kB | 826.22 kB | | msgpack-lite | 0.1.26 | 201.16 kB | 281.59 kB | | opentracing | 0.14.7 | 194.81 kB | 194.81 kB | | lru-cache | 7.18.3 | 133.92 kB | 133.92 kB | | pprof-format | 2.1.0 | 111.69 kB | 111.69 kB | | @datadog/sketches-js | 2.1.0 | 109.9 kB | 109.9 kB | | semver | 7.6.3 | 95.82 kB | 95.82 kB | | lodash.sortby | 4.7.0 | 75.76 kB | 75.76 kB | | ignore | 5.3.1 | 51.46 kB | 51.46 kB | | int64-buffer | 0.1.10 | 49.18 kB | 49.18 kB | | shell-quote | 1.8.1 | 44.96 kB | 44.96 kB | | istanbul-lib-coverage | 3.2.0 | 29.34 kB | 29.34 kB | | rfdc | 1.3.1 | 25.21 kB | 25.21 kB | | @isaacs/ttlcache | 1.4.1 | 25.2 kB | 25.2 kB | | tlhunter-sorted-set | 0.1.0 | 24.94 kB | 24.94 kB | | limiter | 1.1.5 | 23.17 kB | 23.17 kB | | dc-polyfill | 0.1.4 | 23.1 kB | 23.1 kB | | retry | 0.13.1 | 18.85 kB | 18.85 kB | | jest-docblock | 29.7.0 | 8.99 kB | 12.76 kB | | crypto-randomuuid | 1.0.0 | 11.18 kB | 11.18 kB | | koalas | 1.0.2 | 6.47 kB | 6.47 kB | | path-to-regexp | 0.1.10 | 6.38 kB | 6.38 kB | | module-details-from-path | 1.0.3 | 4.47 kB | 4.47 kB |🤖 This report was automatically generated by heaviest-objects-in-the-universe |
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## master #4856 +/- ##
==========================================
- Coverage 82.43% 76.97% -5.46%
==========================================
Files 290 283 -7
Lines 13193 13144 -49
==========================================
- Hits 10875 10117 -758
- Misses 2318 3027 +709 ☔ View full report in Codecov by Sentry. |
level: 'ERROR', | ||
|
||
// existing log.error(err) without message will be reported as 'Generic Error' | ||
message: message || 'Generic Error' |
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.
We are assigning the 'Generic Error' message to all errors logged without message.
It allows us to not to update all the log.error(err)
cases in the tracer but will be recommended to provide a message for each of the cases
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.
Not sure I understand. What is the current behaviour for this? Are we just logging nothing?
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.
It is the message for telemetry logs when there is no message.
We were sending the error message as telemetry log message but guys from telemetry complained about it due to cardinality and possible PII data problems.
Now, with the new log api, it is preferable whenever you log an error that is accompanied by a no dynamic message.
// if you call log.error with a message and an error
// logger:
// - logs 'Error loading file'
// - logs e
// telemetry:
// - sends 'Error loading file' message + e.stack
log.error('Error loading file', e)
But if a message is not provided 'Generic Error'
message is used
// logger:
// - logs e
// telemetry:
// - sends 'Generic Error' message + e.stack
log.error(e)
log.error
accepting multiple arguments
This is super subtle and I wonder if it's a behavior we want to rely on. Nobody reading code would think that a delegate is used just for this effect; it's quite cryptic. I'd rather fully embrace the fact this API is – among other things – a facade for telemetry logs and have a dedicated function name for a local-only logging, e.g. |
Co-authored-by: Attila Szegedi <[email protected]>
This is a side effect, I'll try to explain it. Delegates are used to "delay" the message composition after logger has checked if certain logging level is enabled: log.debug(() => `Setting new DSM Context: ${JSON.stringify(dataStreamsContext)}.`) // dataStreamsContext will only be stringifyed if debug level is enabled They are mostly used for debugging logs. These logs are not sent via telemetry. To know if a certain logging level is enabled we check if a particular log channel has subscribers But as we want to enable log collection globally, log channels (at the moment error logs so at least So I decided to execute the delegate only in |
Oh I see, basically you're saying that delegates are only used to log debug messages that are deferred as a performance concern. Okay, I guess that makes sense. |
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.
A few questions/comments but otherwise LGTM.
@rochdev changed an expression to make it work in node 12 because some integration-guardrails(12) tests were failing. |
* log.error accepting multiple arguments * clean up * warn, info, debug methods * Update packages/dd-trace/src/log/writer.js Co-authored-by: Attila Szegedi <[email protected]> * attila suggestion * include error type in the telemetry log * remove optional chaining to work in node 12 * remove optional chainingand ?? to work in node 12 --------- Co-authored-by: Attila Szegedi <[email protected]>
* log.error accepting multiple arguments * clean up * warn, info, debug methods * Update packages/dd-trace/src/log/writer.js Co-authored-by: Attila Szegedi <[email protected]> * attila suggestion * include error type in the telemetry log * remove optional chaining to work in node 12 * remove optional chainingand ?? to work in node 12 --------- Co-authored-by: Attila Szegedi <[email protected]>
* log.error accepting multiple arguments * clean up * warn, info, debug methods * Update packages/dd-trace/src/log/writer.js Co-authored-by: Attila Szegedi <[email protected]> * attila suggestion * include error type in the telemetry log * remove optional chaining to work in node 12 * remove optional chainingand ?? to work in node 12 --------- Co-authored-by: Attila Szegedi <[email protected]>
* log.error accepting multiple arguments * clean up * warn, info, debug methods * Update packages/dd-trace/src/log/writer.js Co-authored-by: Attila Szegedi <[email protected]> * attila suggestion * include error type in the telemetry log * remove optional chaining to work in node 12 * remove optional chainingand ?? to work in node 12 --------- Co-authored-by: Attila Szegedi <[email protected]>
What does this PR do?
Update
log
methods (error
andwarn
,info
,debug
) to accept multiple arguments in order to use template messages.util.format is used to format the templates
Notes
Legacy cases are still supported
There is a case, used often with
log.debug()
, where a callback or delegate is passed to the logger:log.debug(() => do_something_heavy())
.The delegate is executed by
log/writer.js
but not bytelemetry/log
.So when executing
log.error(() => error)
the error will be written to the configured logger but won't be sent via telemetry.Motivation
Plugin Checklist
Additional Notes