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

Mac M1 - Electron process high CPU #329

Closed
tamet83 opened this issue Mar 12, 2022 · 6 comments
Closed

Mac M1 - Electron process high CPU #329

tamet83 opened this issue Mar 12, 2022 · 6 comments
Labels
bug Something isn't working waiting Waiting for confirmation, more information, ...

Comments

@tamet83
Copy link

tamet83 commented Mar 12, 2022

Hi,

I don't know why but when I use this plugin on my mac book air m1 I noticed that the electron process uses over the 100% of the CPU.

What kind of information can I give you to debug this behavior?

Thanks

@SchoofsKelvin
Copy link
Owner

  • Which version of VS Code are you using?
  • Did this start happening recently since an update, or have you never used the plugin before?
  • When exactly does this happen? The moment you start a SSH FS connection? And if so, only at the beginning? When opening/saving files? ...

@SchoofsKelvin SchoofsKelvin added bug Something isn't working waiting Waiting for confirmation, more information, ... labels Mar 18, 2022
@tamet83
Copy link
Author

tamet83 commented Mar 21, 2022

Hello,

sorry for the delay.

  1. I'm using VS Cose V. 1.65.2 (Universal)
  2. I installed the plugin lately, a month ago if I remember well.
  3. The problem happens immediately after I start a SSH session and remain active even if I quit VSC and I need to kill the process manually.

Here a screenshot:

Schermata 2022-03-21 alle 21 09 50

The CPU usage increases more and more after time as you can see:

Schermata 2022-03-21 alle 21 12 47

Whereas here the process info:

cwd
/
txt
/Applications/Visual Studio Code.app/Contents/MacOS/Electron
txt
/Applications/Visual Studio Code.app/Contents/Frameworks/Squirrel.framework/Versions/A/Squirrel
txt
/Applications/Visual Studio Code.app/Contents/Frameworks/Mantle.framework/Versions/A/Mantle
txt
/Library/Preferences/Logging/.plist-cache.4lhffmxv
txt
/Applications/Visual Studio Code.app/Contents/Frameworks/Electron Framework.framework/Versions/A/Resources/v8_context_snapshot.arm64.bin
txt
/Users/matteo/.vscode/extensions/keesschollaart.vscode-home-assistant-1.26.0/node_modules/bufferutil/prebuilds/darwin-x64+arm64/node.napi.node
txt
/Applications/Visual Studio Code.app/Contents/Frameworks/ReactiveObjC.framework/Versions/A/ReactiveObjC
txt
/Users/matteo/.vscode/extensions/keesschollaart.vscode-home-assistant-1.26.0/node_modules/utf-8-validate/prebuilds/darwin-x64+arm64/node.napi.node
txt
/usr/lib/dyld
txt
/Applications/Visual Studio Code.app/Contents/Frameworks/Electron Framework.framework/Versions/A/Libraries/libffmpeg.dylib
txt
/usr/share/icu/icudt68l.dat
txt
/Applications/Visual Studio Code.app/Contents/Frameworks/Electron Framework.framework/Versions/A/Resources/icudtl.dat
txt
/Applications/Visual Studio Code.app/Contents/Frameworks/Electron Framework.framework/Versions/A/Electron Framework
0
->0x4a1a107e1ad1e27
1
->0x4a1a107e1ad1fb7
2
->0x4a1a107e1ad2147
3
->0x4a1a107e1ad22d7
4
/Applications/Visual Studio Code.app/Contents/Frameworks/Electron Framework.framework/Versions/A/Resources/icudtl.dat
5
count=2, state=0x8
6
->0x1a55649e91ea665f
7
->0xb9842e3b614aff4f
8
->0xeefacd677c5ea242
9
->0xc4ee38849a90bb92
10
->0xb548269e42e765ca
11
->0x69cea77e0ea0749e
12
/Applications/Visual Studio Code.app/Contents/Frameworks/Electron Framework.framework/Versions/A/Resources/v8_context_snapshot.arm64.bin
13
count=0, state=0
14
->0x729e5cd626dda921
15
->0x13559512ccb46e35
16
->0x203269762bf4fecb
17
->0x3d92afbca2d874e3
18
count=0, state=0x12
19
count=0, state=0xa
20
->0x80b537d6e104d5f0
21
->0x97eed112b854ee21
22
->0x2f12c90be685e4c7
23
->0xb91df9bb0ba043c8
24
/dev/null

Let me know if you need other info and thanks for your help.

@SchoofsKelvin
Copy link
Owner

I don't know if you have access to the output pane when VS Code is frozen (I assume the extension host process is frozen, not the UI), but if possible:

  • Add DEBUG_SSH2 to the sshfs.flags array in VS Code's User Settings (settings.json)
    e.g. "sshfs.flags": ["DEBUG_SSH2"]
    • See this issue for more information about adding flags
  • If you already have a connection open, close it completely (or even reload the window)
  • Go to Output > SSH FS and copy the log from there after replicating your bug
  • While it should censor passwords/passphrases, I recommend checking it for (other) sensitive data first.
    (especially since DEBUG_SSH2 activates some internal logging, which is less likely to be censored)

Some more questions to help me figure out the cause:

  • What OS and version of OpenSSH (or similar) is your server running?
  • Do you have any special OpenSSH server settings?
  • Have you tried other servers? If so, does this issue also happen there?

@tamet83
Copy link
Author

tamet83 commented Mar 25, 2022

Hi,

I think the problem is with VSC, i'm not the only one as you can see here.
I tried to open an issue on VSC official github page

@SchoofsKelvin
Copy link
Owner

It looks like they did some upgrades and reverts regarding Electron between 1.64 and 1.65.2 which I assume lead to the issue. Something similar happened in #239 where an Electron upgrade resulted in certain algorithms crashing the extension host when used. Since the high CPU usage in your case only happens when you start a SSH connections, it might be something very similar. You can actually try adding the DF-GE and see if that fixes it. Very low chance, but it might.

I'll be closing this ticket for now. If something changes and it looks like the extension's fault again, or there's a quick fix I can implement (e.g. disabling certain ciphers/algorithms), feel free to comment and reopen this ticket.

@tamet83
Copy link
Author

tamet83 commented Mar 30, 2022

Hello, we find out what's causing this issue.
The fault wasn't from your addon. Right now the problem isn't solved, I had to disable the addon.
I leave the links for future reference.

  • Here the the hint from vsc github
  • Here the issue I opened on the maintainer github

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working waiting Waiting for confirmation, more information, ...
Projects
None yet
Development

No branches or pull requests

2 participants