-
Notifications
You must be signed in to change notification settings - Fork 30.2k
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
Port 9229 in use by VS Code #85328
Comments
Have you been debugging extension tests? Could be related to #81397 But can you expand more on the actual issue? Debugging node uses a random port by default and shouldn't be blocked by this. |
I work mostly on the Azure Functions extension and we're having plenty of users reports this as mentioned in https://github.com/MicrosoftDocs/azure-docs/issues/42379. I doubt those people are developing extensions for VS Code, let alone running extension tests.
The issue is that some part of VS Code is using port 9229 when it shouldn't be. Default debugging might use a random port, but 9229 is still the default port used for node inspect and so I think a lot of other scenarios are affected. For example Azure Functions debugging always uses 9229. This was not a problem in v1.39 and now it's a problem in 1.40 |
With the change mentioned above we start the inspect protocol on the extension host process as soon as we detect that the process has become unresponsive. This is done because via the inspect protocol VS Code can better analyse what's going on in the extension host process. By default the extension host process is not listening for the inspect protocol (so no inspect port is open by default). To enter inspect mode VS Code sends signal From that moment on, inspect port 9229 is no longer available for other node.js processes. So if your node.js debugging relies on the default port 9229 (e.g. by using a We are planning to fix this problem by making VS Code use a random free port for inspecting the extension host process. Until we've fixed this, a simple workaround exists: just don't rely on the default port 9229 for your node.js debugging, e.g. specify a port yourself: Configuring node.js to use a random port when a SIGUSR1 signal is received can be done via this argument: |
Extension host profiling now uses a random port which means it very likely doesn't conflict with the default port 9229 anymore. If you are affected by this, the use next insiders or the workaround described above. @EricJizbaMSFT This process should only kick in when the extension host freezes for a few seconds and this is usually a sign of extensions using much CPU cycles. Does this rings a bell? Did you receive reports in that direction before? |
If you're running into this while debugging Azure Functions, the workaround is to update the debug port to something other than {
"version": "0.2.0",
"configurations": [
{
"name": "Attach to Node Functions",
"type": "node",
"request": "attach",
"port": 19229,
"preLaunchTask": "func: host start"
}
]
} |
Verification steps: Have an extension with something like vscode.commands.registerCommand('extension.helloWorld', () => {
while (true) { }
}); Run the command and the EH should stop responding. After a few seconds, check the devtools console, and you should see the port that the EH is listening on. It would have been 9229 before, and should be something else now. |
1 similar comment
Verification steps: Have an extension with something like vscode.commands.registerCommand('extension.helloWorld', () => {
while (true) { }
}); Run the command and the EH should stop responding. After a few seconds, check the devtools console, and you should see the port that the EH is listening on. It would have been 9229 before, and should be something else now. |
I'm not sure the issue has been resolved. A host error has occurred during startup operation '7ccc4111-b0b0-46c7-a1bc-710de30a8d49'. When I change the port in jaunch.json, I get the same error message with the altered port number in the above error message. |
Can you check which process is using 9229? |
netstat didnt return anything on 9229 |
We've had a lot of users run into issues where VS Code (likely the extension host process) is hanging on to port 9229 which means they fail to debug node projects. Users consistently say it repros on v1.40.1, but does not repro if they downgrade to v1.39.2. Most of the existing user reports come from #73818 (an older issue specific to nodemon - @weinand recommended creating a new issue) and https://github.com/MicrosoftDocs/azure-docs/issues/42379.
I have not personally reproduced this issue, but @jeffhollan @eduardolaureano @anthonychu have all hit it and can hopefully give more detail if necessary. I've also cherry-picked a few comments below which seem particularly relevant:
originally posted by @Yukaii in #73818 (comment):
originally posted by @hermanho in #73818 (comment):
The text was updated successfully, but these errors were encountered: