Skip to content
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

doc: warn about using util.inspect/util.format in prod #17791

Closed
wants to merge 1 commit into from

Conversation

jasnell
Copy link
Member

@jasnell jasnell commented Dec 20, 2017

Because of the potential performance bottlenecks that may be introduced
by util.inspect() and util.format() in production code.

Based on real user feedback, it is not obvious that these are intended
to be debugging tools.

/cc @mcollina @lucamaraschi

Checklist
  • make -j4 test (UNIX), or vcbuild test (Windows) passes
  • documentation is changed or added
  • commit message follows commit guidelines
Affected core subsystem(s)

doc

@nodejs-github-bot nodejs-github-bot added doc Issues and PRs related to the documentations. util Issues and PRs related to the built-in util module. labels Dec 20, 2017
@Trott
Copy link
Member

Trott commented Dec 20, 2017

Two questions: Isn't util.format() used by console.log() and friends under the hood? Should there be a warning on those too?

Second, and I know this is an unpopular opinion, but can we remove *Note*: here? Everyone who adds a paragraph to our docs thinks it needs to be emphasized and that the way to do that is to use *Note*:. They're wrong on both counts. The way we render these, contrary to adding emphasis, it actually makes the paragraph look like an unimportant footnote.

These are non-blocking questions. I don't intend to demand an answer before this lands or anything. Just trying to offer some helpful suggestions.

@jasnell
Copy link
Member Author

jasnell commented Dec 20, 2017

I think the console.*** methods are a bit more well understood to be debug tools and do not really need the warning. What I have seen in several cases, however, are folks using util.inspect() in logging code within hot paths, and that's really the kind of thing the warning is meant to discourage.

@lucamaraschi
Copy link
Contributor

LGTM but I would probably make the warning for console.*** explicit too.

@BridgeAR
Copy link
Member

BridgeAR commented Dec 20, 2017

I am confused by these comments. I recently optimized both functions in e.g. #14881 #14492 #15422 and when looking at the history, others optimized util.format as well.

Right now there is likely little that can be done to further improve the performance of those functions.

It should also not be much of a performance issue depending on the user input. If a huge array is inspected, it is indeed a lot of work. The problem in that case is that Object.keys has to be called in such a case and that is expensive. We could add a option to deactivate this default behavior for arrays, by the way, as it is only necessary for untypical arrays (extra properties on the array instead of only regular indices).

@jasnell
Copy link
Member Author

jasnell commented Dec 20, 2017

Yes, they've been optimized about as much as they can be but they are still something that should never be used in hot paths. That's not what they've been optimized for and not what they are intended for. I've seen this pop up in flame graphs as a significant bottleneck a number of times (as recently as this morning in fact, which is what prompted this PR now).

@BridgeAR
Copy link
Member

Well, using it in a hot code path is not really smart (and I wonder what they did - but that is another story). But the wording oft this should be different out of my perspective.

What about e.g.

Please note that `util.format()` is a synchronous method that is mainly intended
as debugging tool. Depending on the values to format it could have a significant
performance overhead that would block the event loop. Use this function
therefore with care and never in a hot code path.

doc/api/util.md Outdated
@@ -250,6 +250,11 @@ without any formatting.
util.format('%% %s'); // '%% %s'
```

It is immportant to note that `util.format()` is a synchronous method that is
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

s/immportant/important

(also below)

@jasnell
Copy link
Member Author

jasnell commented Dec 21, 2017

@BridgeAR ... PTAL now :-)

Copy link
Member

@BridgeAR BridgeAR left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👍

Copy link
Member

@mcollina mcollina left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM but it needs to be rebased already.

Because of the potential performance bottlenecks that may be introduced
by `util.inspect()` and `util.format()` in production hot path code.

Based on real user feedback, it is not obvious that these are intended
to be debugging tools.
@jasnell jasnell force-pushed the doc-inspect-warning branch from 6d3c6b8 to 680b659 Compare December 21, 2017 15:41
@jasnell
Copy link
Member Author

jasnell commented Dec 21, 2017

Rebased :-)

@jasnell jasnell added the fast-track PRs that do not need to wait for 48 hours to land. label Dec 21, 2017
jasnell added a commit that referenced this pull request Dec 21, 2017
Because of the potential performance bottlenecks that may be introduced
by `util.inspect()` and `util.format()` in production hot path code.

Based on real user feedback, it is not obvious that these are intended
to be debugging tools.

PR-URL: #17791
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
@jasnell
Copy link
Member Author

jasnell commented Dec 21, 2017

Landed in a4f44ac

@MylesBorins
Copy link
Contributor

This does not land cleanly on v9.x, would someone be willing to manually backport?

targos pushed a commit that referenced this pull request Mar 24, 2018
Because of the potential performance bottlenecks that may be introduced
by `util.inspect()` and `util.format()` in production hot path code.

Based on real user feedback, it is not obvious that these are intended
to be debugging tools.

PR-URL: #17791
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
@targos
Copy link
Member

targos commented Mar 24, 2018

Trivial conflict. Landed in 742b304.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
doc Issues and PRs related to the documentations. fast-track PRs that do not need to wait for 48 hours to land. util Issues and PRs related to the built-in util module.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

8 participants