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

src: add --disable-sigusr1 to prevent signal i/o thread #56441

Merged
merged 2 commits into from
Jan 13, 2025

Conversation

RafaelGSS
Copy link
Member

This commit adds a new flag --disable-sigusr1 to prevent the SignalIOThread to be up listening the SIGUSR1 events and then starting the debugging session.


This flag is handy when dealing with multiple apps in the same environment. I wouldn't call it a full security guarantee since one would require access to the environment in order to expose the debugger, and with that assumption, one can do anything one wants. However, I do believe this would serve as a seatbelt in some scenarios.

Please note users already do it by require('inspector').close(), but a flag seems more suitable.

@RafaelGSS RafaelGSS added the semver-minor PRs that contain new features and should be released in the next minor version. label Jan 2, 2025
@nodejs-github-bot nodejs-github-bot added c++ Issues and PRs that require attention from people who are familiar with C++. needs-ci PRs that need a full CI run. labels Jan 2, 2025
@juanarbol
Copy link
Member

Idk if this is the wait to do it. There's also SIGUSR2 among other signals. Wouldn't that be better to have a "blacklist" approach instead? So the logic scales to any signal.

@RafaelGSS
Copy link
Member Author

RafaelGSS commented Jan 2, 2025

Idk if this is the wait to do it. There's also SIGUSR2 among other signals. Wouldn't that be better to have a "blacklist" approach instead? So the logic scales to any signal.

Initially, I thought about the --disable-signal=SIGUSR1 but then I realized that there's no "damage" in receiving a SIGUSR2. AFAIK only SIGUSR1 would initiate the debugging session.

I could also rename the flag to --disable-sigusr1-debug to make it more explicit but, I don't think there's a need for that.

Also, having a --disable-signal and not implementing other signals might sound confusing to users.

@RafaelGSS RafaelGSS added the review wanted PRs that need reviews. label Jan 2, 2025
@juanarbol
Copy link
Member

I don't disagree w/ this patch. But if this is intended to disable/flip a default behaviour, it may need some update in the documentation side as well.

Useful when activating the inspector by sending the SIGUSR1 signal.

Refs: https://nodejs.org/docs/latest/api/cli.html#--inspect-porthostport

@RafaelGSS
Copy link
Member Author

Ok. I can update the --inspect documentation to explicitly mention when --disable-sigusr1 is passed, the debugging session initialized with SIGUSR1 won't work.

Copy link

codecov bot commented Jan 2, 2025

Codecov Report

Attention: Patch coverage is 75.00000% with 1 line in your changes missing coverage. Please review.

Project coverage is 89.13%. Comparing base (98d4ebc) to head (63d32a4).
Report is 71 commits behind head on main.

Files with missing lines Patch % Lines
src/env-inl.h 50.00% 0 Missing and 1 partial ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main   #56441      +/-   ##
==========================================
+ Coverage   88.53%   89.13%   +0.59%     
==========================================
  Files         657      662       +5     
  Lines      190741   191558     +817     
  Branches    36607    36861     +254     
==========================================
+ Hits       168881   170743    +1862     
+ Misses      15036    13686    -1350     
- Partials     6824     7129     +305     
Files with missing lines Coverage Δ
src/node_options.cc 87.94% <100.00%> (+0.01%) ⬆️
src/node_options.h 98.32% <100.00%> (+0.01%) ⬆️
src/env-inl.h 96.78% <50.00%> (-0.43%) ⬇️

... and 88 files with indirect coverage changes

@RafaelGSS
Copy link
Member Author

RafaelGSS commented Jan 3, 2025

PTAL @juanarbol

I have also changed the flag to be in stability 1.1 so we can re-evaluate if we need to rename or make it more generic in the future.

doc/api/cli.md Outdated Show resolved Hide resolved
@RafaelGSS RafaelGSS added the request-ci Add this label to start a Jenkins CI on a PR. label Jan 3, 2025
@github-actions github-actions bot removed the request-ci Add this label to start a Jenkins CI on a PR. label Jan 3, 2025
@nodejs-github-bot
Copy link
Collaborator

This commit adds a new flag `--disable-sigusr1` to prevent
the SignalIOThread to be up listening the SIGUSR1 events and
then starting the debugging session.
@RafaelGSS RafaelGSS force-pushed the add-disable-sigusr1-cli branch from 384dc99 to 196a470 Compare January 6, 2025 22:21
@RafaelGSS RafaelGSS added request-ci Add this label to start a Jenkins CI on a PR. commit-queue-squash Add this label to instruct the Commit Queue to squash all the PR commits into the first one. labels Jan 7, 2025
@github-actions github-actions bot removed the request-ci Add this label to start a Jenkins CI on a PR. label Jan 7, 2025
@nodejs-github-bot
Copy link
Collaborator

nodejs-github-bot commented Jan 7, 2025

@RafaelGSS RafaelGSS added review wanted PRs that need reviews. and removed review wanted PRs that need reviews. labels Jan 8, 2025
Copy link
Member

@juanarbol juanarbol left a comment

Choose a reason for hiding this comment

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

sgtm

@@ -0,0 +1,2 @@
console.log('pid is', process.pid);
setInterval(() => {}, 1000);
Copy link
Member

Choose a reason for hiding this comment

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

Suggested change
setInterval(() => {}, 1000);
setInterval(() => {}, 1000);

@RafaelGSS RafaelGSS added the commit-queue Add this label to land a pull request using GitHub Actions. label Jan 13, 2025
@nodejs-github-bot nodejs-github-bot removed the commit-queue Add this label to land a pull request using GitHub Actions. label Jan 13, 2025
@nodejs-github-bot nodejs-github-bot merged commit 496e17e into nodejs:main Jan 13, 2025
69 checks passed
@nodejs-github-bot
Copy link
Collaborator

Landed in 496e17e

Ceres6 pushed a commit to Ceres6/node that referenced this pull request Jan 13, 2025
This commit adds a new flag `--disable-sigusr1` to prevent
the SignalIOThread to be up listening the SIGUSR1 events and
then starting the debugging session.

PR-URL: nodejs#56441
Reviewed-By: Juan José Arboleda <[email protected]>
Reviewed-By: James M Snell <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
c++ Issues and PRs that require attention from people who are familiar with C++. commit-queue-squash Add this label to instruct the Commit Queue to squash all the PR commits into the first one. needs-ci PRs that need a full CI run. review wanted PRs that need reviews. semver-minor PRs that contain new features and should be released in the next minor version.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants