-
Notifications
You must be signed in to change notification settings - Fork 310
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
remote-ssh: Add possibility to invoke a login shell #1671
Comments
@roblourens two ways we could solve this:
I'm leaning towards the former as the solution is inside the ssh ext and won't affect anything else. It could probably be called in a similar way to this how we use There is of course then the problem of |
Option 1 sounds find to me. :) IMO from a user's point of view, it seems like a login shell should be the default though -- just to mirror how local VS Code behaves. I realize that would be a change at this point, but it seems like it would solve more random issues than it would create. (e.g. PATH isn't as expected so scripts fail, etc) But either way 👍 |
@Codelica I think we reason we didn't do that is because a regular ssh session does not run a login shell, so currently it's very similar to a regular ssh setup (unless you run |
By "regular ssh session", do you mean invoking a typical remote ssh connection from a terminal shell like: As that seems to always provide a login shell from what I've seen. |
@Codelica yes, based on my testing it didn't. That's also the reason you're seeing this behavior, if it was a login shell I don't think this issue should exist. |
@Tyriar @Codelica I've also run into this problem when trying to get my team set up with the remote-ssh extension. We have a lot of environment that's set up in |
@peter-b yeah you're doing it right. We can consider change this to be the default but we would need to do some thinking on what might break as a result of that. |
@Tyriar I believe any new SSH connection/session should give you an interactive login shell to start. But if you begin another shell in an existing session you then get an interactive non-login shell, which is what is at work here. I think. :) When the Remote SSH plugin initially connects (to form the session, install what's needed, etc) I can see it is given a login shell sourcing .profile, etc. (which it may appreciate :) ). However any interactive VS Code terminal that the user brings up (once connected) just uses that established session, and is not a login shell. At least I think that's the case based on what I've seen. While that technically may be "correct" behavior for bringing up an additional shell in an established remote session, it's different from how the VS Code terminal behaves when working locally -- which brings up a login shell each time. So I guess if the intent of the Remote SSH plugin is to "work on a remote host as if it's local", that feels like a disconnect. That got long, but the answer here has more information if you're interested. https://unix.stackexchange.com/questions/38175/difference-between-login-shell-and-non-login-shell Thanks for considering this! |
I'm a little confused - we do already set up the extension host environment based on a login shell. Essentially we spawn So if you are setting PATH or other environment variables in your In my case, I have Side note, since I had forgotten this: We only discover the environment once then cache it for the rest of the server's session. If you change your dot scripts and want to see that change reflected when you open a new vscode window, you will have to restart the remote server with the command "Kill VS Code Server on Host". |
Hi @roblourens, this is the part that I was missing. It isn't at all obvious that this is the behaviour; it comes as a big surprise to me that VS Code continues to run on the remote server after the last window connected to it has been closed. Are you sure this behaviour is desirable? |
So restarting the server fixes it for your case?
No, not at all. However, connecting to the remote is kind of slow already and I'm hesitatant to do anything that could make it slower, like starting a process to check the environment that won't change 99% of the time. Not sure what to do. |
Hi @roblourens, I do not have a conda environment or any similar setup. I still cannot see changes which sourcing .profile should reflect. The terminals open a non-login shell for me. Restarting the server does not fix anything. |
Can you give more details about what "changes" you have so I can reproduce it? |
UPDATE:Apologies. All of my tests below comply with what you have written here. I was a little confused.
Either way, as it stands, The terminal given is not a login shell. Thank you @roblourens Okay, so I tried retesting and I'll tell you what occurred. Let me know if I should open another issue for this. Test1
Test2 (Run directly after Test1)
Test3
Implies .profile was sourced and the current terminal is a child process of a login shell. Test4
|
We have established that the |
Yes, I agree. There is no bug here, as I mentioned in the UPDATE section, all the tests comply with expected behavior. Please consider this as a feature request to "Add possibility to invoke a login shell". Perhaps in the "Select Default Shell", there can be two options, one for plain Also, adding |
Is there any way to make terminals work as login shell? I'm a Ruby dev, without it RVM does not work. |
Same if you are using a virtualenv or pyenv or really anything that relies on having a login shell session. Which is the case for a lot of development scenarios. |
I'm experiencing the same (.profile not being sourced in Integrated Terminal) but using Docker (not remote SSH connection). I always use "bash -l" as the command to execute when I want an interactive shell on a Docker container. So in my case following doc and adding:
in devcontainer.json made the trick. |
THAT'S the answer. I was having the same problems with the non-login shell terminals. This fixed it! |
This unfortunately didn't work for me. I tried adding the bash flag to the user, workspace, and server settings (and their combinations) to no avail. Additionally, doing this caused my terminal to crash. Would love to see this feature implemented as it would be very useful. Regardless, sending my thanks to the vscode dev team for such an outstanding dev experience ❤️ |
I ended up here trying to get a working Go environment in remote-ssh with gimme. I run Visual Studio Code on Windows 10, and have source code and my Go environment in a remote Linux VM. When I was connecting, I would get a message that go wasn't found. That's because I manage my Go environments with a tool called gimme which is sort of like virtualenv or rvm, but for Go. When I started, I had Here's what i had to do to fix it.
|
Thank you, PatrickLang. Some clarity! I think your post illustrates the problem best. If I change my .profile or .bash_profile, then open a new terminal in the context of a remote-ssh workspace, I should see the consequences. Period. Please fix this dis-functional aspect of this otherwise awesome tool. EDIT: additionally, I'm seeing all of the elements in my PATH, from .bash_profile, twice. More or less benign, but hacky looking. |
@bavis-m now that
This command (as far as I understand) will be used by the initial connection (thus the need for the trailing Or even simpler, now that I think of it,
Of course this workaround means that now every SSH connection to |
Helps for opening a new shell:
But: when I leave more than one terminal open while closing vscode window and open it later only one terminal is restored and it is started without .bash_profile environment. Leaving one terminal open, starts on reopen one terminal with correct .bash_profile environment. Edit: with vscode 1.79.2 i can no longer reproduce this issue, it seems to be solved for me. |
I wonder if the thing to do here is to fork the extension and make it follow the decades-old tradition of 'the shell at the top of the process hierarchy is a login shell', accepting that some folk will have customised things in a way that breaks, and then let folk migrate over to this setup that is consistent with local logins? |
I can confirm this issue. Happening to me too. |
I am facing the same issue when connecting to Azure ML compute instance with Remote SSH. The Azure ML compute instances rely on We can workaround it by manually changing the remote
|
I have been confused many times why I don't see environment variables changes on starting a new terminal on a remote ssh session in vscode. But I realized that the full profile is sourced on the start of the vscode remote process. I used to do what @sevillal mentioned in all my workspaces, and it works. The other way around, uglier to do, is to kill current remote server and reload the window. I do not see why the argument "-l" would not be by default for remote ssh and for docker dev containers, as the same issue happens with it. |
In my case, both default profile and -l args must be specified, and userEnvProbe has no effect on the issue. "terminal.integrated.defaultProfile.linux": "bash",
"terminal.integrated.profiles.linux": {
"bash": {
"path": "bash",
"icon": "terminal-bash",
"args": ["-l"]
}
} Side note: this issue is 5 years old, I can't believe there is not at least a clear settings section to avoid users having to crawl a dozen of web pages before finding the actual fix. And I say "at least" because, in my point of view, opening an ssh session should by default behave the same way as on any other terminal client (I work with dozens of servers, and several OS platforms, they all behave as login screen when connecting terminal via ssh). This should never require tweaking anything else than vsocde itself (as suggested in some of the answers). And if vscode really doesn't want to comply to standards, it should display a big red message like "Warning, you are about to open an interactive session via ssh. For some obscure reasons, we chose to ignore you use an interactive terminal and behave as if it was not. If you want vscode to behave as any other ssh interactive client, update preferences manually in settings.json". |
Is there any consensus on this yet? It's a surprise to find that .profile isn't sourced when using a VS Code remote terminal. In particular, that's where Ubuntu puts the addition of ~/.local into the user's path. I see the various workarounds above but it feels odd to have to use them. Doesn't this feel sufficiently important, and obscure to new/less experienced users, to call out strongly in the docs? I agree with the comment above about following the principle of least surprise. |
Weird, that used to work perfectly for me, but stopped working now (I only notice today but can't say for how long it's been the case). Anyone else noticed it? Or did I potentially mess up something on my side? |
Update: after several hours of baging my head against the wall, and checking the man page of
Haven't heard back from IT yet why the |
@kevinrue Thanks a lot for posting your solution, that worked for me as well. |
For me the fix of the latest
|
I fixed that by adding --login to settings.json, under terminal.integrated.profiles.linux, |
I think bash_profile is actually the right place for this, but it seems to handle being re-invoked in a non-login shell, and this works around microsoft/vscode-remote-release#1671
Currently (vscode
1.38.1
), a remote bash terminal only sources.bashrc
, like an interactive shell that is not a login shell would do.This breaks existing conda installations on the remote system, which rely on code in
/etc/profile.d
. I'd like to have the possibility to start an interactive shell with the--login
option on the remote system. This way, profiles from/etc/profile
and.profile
would be sourced as well.Please see the bash man page for how different files are sourced on bash invocation.
See #83 for reference as well.
The text was updated successfully, but these errors were encountered: