-
Notifications
You must be signed in to change notification settings - Fork 833
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
bash.exe -c "nohup winver.exe &" leaves init using 100% CPU on one core #12361
Comments
Logs are required for review from WSL teamIf this a feature request, please reply with '/feature'. If this is a question, reply with '/question'. How to collect WSL logsDownload and execute collect-wsl-logs.ps1 in an administrative powershell prompt:
The script will output the path of the log file once done. If this is a networking issue, please use collect-networking-logs.ps1, following the instructions here Once completed please upload the output files to this Github issue. Click here for more info on logging View similar issuesPlease view the issues below to see if they solve your problem, and if the issue describes your problem please consider closing this one and thumbs upping the other issue to help us prioritize it! Closed similar issues:
|
Thank you @dreamlayers. Interestingly I can't reproduce the issue. Could you share a coredump of the init process that's consuming CPU ? |
Here is a core dump generated via This was soon after booting into Windows. The first time I did |
Windows Version
Microsoft Windows [Version 10.0.19045.5131]
WSL Version
2.1.4.0
Are you using WSL 1 or WSL 2?
Kernel Version
4.4.0-19041-Microsoft
Distro Version
Ubuntu 24.04.1 LTS
Other Software
No response
Repro Steps
If I open an ordinary Windows cmd prompt window (not WSL). There run
bash.exe -c "nohup winver.exe &" or
wsl.exe -e bash -c "nohup winver.exe &".Expected Behavior
WSL should run temporarily, starting winver.exe and then closing.
Actual Behavior
After WSL exits, an init process remains, using 100% CPU on one core. Even after winver.exe is closed, that init process remains, endlessly wasting CPU time like that. Every time this is repeated, another init process like this is created, each wasting CPU time.
Other than this, everything seems fine. I am returned to the cmd prompt immediately, and winver remains running.
If the nohup is not used, or the
&
is not used, then this problem does not occur.Workaround: Using
bash.exe -c "winver.exe &"
gives more reasonable behaviour. The first run leaves behind two init processes, but they do not waste CPU time, and repeating it does not create more lingering init processes. Even though nohup is not used, winver remains running, probably because SIGHUP doesn't affect ordinary Windows processes. Another alternative that doesn't cause problems isbash.exe -c "winver.exe & disown"
Diagnostic Logs
No response
The text was updated successfully, but these errors were encountered: