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

Add support for "remote development" #5347

Closed
imron opened this issue Jun 23, 2022 · 103 comments
Closed

Add support for "remote development" #5347

imron opened this issue Jun 23, 2022 · 103 comments
Labels
design [core label] enhancement [core label] priority request A request from a stakeholder or influential user remote dev Feedback for remote development servers

Comments

@imron
Copy link

imron commented Jun 23, 2022

Visual Studio Code has a killer feature, "Remote Development", which allows you to remote in to another machine or a docker container, and develop on the remote machine/container as if the entire directory structure and dev environment (including terminal shell) was local.

It would be great to eventually see this feature in Zed, and even if Zed doesn't support this in version 1, it's a compelling enough feature that it would be worth laying to groundwork early on to support it, especially while you're still figuring out the internal api for the editor and how pieces fit together.

For some anecdotal feedback on the usefulness of this feature, in my current role (C++ dev at a large enterprise), for various business reasons our choice of IDEs is more or less limited to VSCode or CLion.

Since I joined and started showing people how the Remote Dev feature of VSCode works, I have seen about a dozen diehard CLion fans switch to VSCode (despite CLion being a better IDE for C++ development) simply because the Remote Development feature works so well and our development process involves a lot of remote development - we have company issued windows laptops, but the software we develop is linux-based and development happens in a mix of docker containers, virtual machines, wsl2 and remote linux instances.

VSCode with the Remote Development extension makes this really easy to deal with and devs will put up with reduced capability on the C++ IDE side of things, for the superior remote development support.

This feature is so useful that Jetbrains recently revamped their entire approach to remote development with Jetbrains Gateway to have something similar.

Anyway, just wanted to put this out there as something to consider, because I guess it will be easier to make architectural changes needed to support something like this earlier rather than later.

@imron imron added enhancement [core label] triage Maintainer needs to classify the issue labels Jun 23, 2022
@JosephTLyons JosephTLyons removed the triage Maintainer needs to classify the issue label Jun 23, 2022
@JosephTLyons
Copy link
Collaborator

JosephTLyons commented Jun 23, 2022

This is a feature I'd love to see built into Zed. It even think it would be be neat if you could remote into some server and do the same collaborative editing there as well, although I don't know how often that would be used - maybe in the context of "fighting fires."

This feature is so useful that Jetbrains recently revamped their entire approach to remote development with Jetbrains Gateway to have something similar.

OT, but I wonder if this has improved significantly since I tried it last - it was super clunky and heavy handed when I first tried it. I much prefer how VS Code's works, it is a lot more simple.

@imron
Copy link
Author

imron commented Jun 23, 2022

OT

I don't think it's off-topic - in fact having this work smoothly and seamlessly is a major part of this feature.

I haven't used Gateway, but their previous remote development solution (which involved rsyncing files between machines) was also super clunky (especially when the host was Windows and symbolic links were involved).

VSCode really knocked it out of the park with the remote developer extension and it should be the standard to aim for and improve upon.

@imron
Copy link
Author

imron commented Jun 23, 2022

It even think it would be be neat if you could remote into some server and do the same collaborative editing there as well, although I don't know how often that would be used - maybe in the context of "fighting fires."

I imagine good collaboration tools would be really useful in this space (I've previously had to collaboratively fight fires over a mix of slack and zoom and other tools), however there are also potential security concerns as anyone connecting to Zed for collaboration would have the same access to the host as the user that ran the Zed process (which may not be themselves).

You don't want people connecting to Zed 'server' that is running as sudo (to fight fires on a file that requires admin priv to edit), and then have connecting users be able to open a shell in the remote terminal as root and do things.

@fdionisi
Copy link
Contributor

fdionisi commented Jun 23, 2022

I was holding back on this feature, but now that it is out here, I'll also jump in. 😅

At the time of the Xray experiment, one mind-blowing feature was the ability to spin up the editor in headless mode. If I recall correctly, this mechanism was the backbone of the editor's web version. Reading through Discord, using the editor from the browser (i.e. the web version) is on the roadmap, so I hope to see this capability resurface. 😀

But I also agree with @imron; such a feature should be paired with (granular) users' permission management. Not sure if this goes outside of Zed scope's, though.
Xray allowed access only to files loaded in the workspace, but this becomes more complex when the terminal is integrated within Zed. But then again, the permissions story could be somehow managed via user and user groups provided at the OS level? I'm not an expert, so I'll leave it to the team.

@voltrevo
Copy link

voltrevo commented Jun 28, 2022

I'd also love to see this.

Btw this format in the CLI would be fantastic:

zed user@host:path/to/project

vs code's format is very strange by comparison:

code --remote ssh-remote+workspace

I can understanding adding a flag though, esp if e.g. you don't specify user@ (which btw vs code somehow forgot to support specifying a user (in any format)):

zed host # yeah not enough context
zed user@host # probably ok if you don't mind the inconsistency of conditionally allowing --ssh to be omitted
zed --ssh host # 💪
zed --ssh host:path/to/project # 💪
zed --ssh user@host:path/to/project # 💪 (totally understandable to require the --ssh flag)

@mikayla-maki mikayla-maki added the design [core label] label Aug 5, 2022
@thiagomajesk
Copy link

thiagomajesk commented Sep 16, 2022

+1 to this, it's definitely a must for me because of WSL2 - which is currently the only way to have a decent development environment on Windows for non-MS stuff.

@etep
Copy link

etep commented Oct 12, 2022

The discussion seems focused on launching zed from the local machine to edit a remote file. As a user of rmate, then rsub, then ratom (well, maybe I renamed it ratom), I have the following:

Would like to suggest adding a feature that is equivalent to rmate/rsub for zed, i.e. the ability to trigger a local zed from a remote machine to edit a remote file.

@hronro
Copy link

hronro commented Oct 14, 2022

I believe "remote development" is not only about editing files of a remote machine but also connecting to an LSP server running on the remote machine. As far as I know, very few LSP servers allow clients to connect to them via TCP, so maybe an additional forwarder program is required to be installed in the remote machine.

As a person who comes from the NeoVim world, there are already something like distant and distant.nvim. Since distant is a general library and is written in Rust, I guess it might be easy for Zed to integrate with.

@andreujuanc
Copy link

Most important for me would be to remote into a container from a local Dockerfile or docker-compose. Same functionality as with vscode's dev containers. IMHO this is much better than simple SSH.

@derekparker
Copy link

Adding a +1 vote to this but with a little context.

I have a workstation that I do most of my actual programming on, which I access from various different machines as a "frontend" to that workstation. I've always really enjoyed VSCodes support for this exact scenario and how seamless and easy to setup it is. Would love to see this implemented in this editor. One thing to note however is that the workstation is Linux based and most of the machines I use as "frontends" to that workstation are macOS based, so this might involve making the editor work on Linux as well.

@halink0803
Copy link

I use this feature everyday with VSCode as I am having my source in a remote computer, then when I tried Zed and it lack of this feature, I cannot experiment any further. Please adding this feature as it is very useful.

@xpader
Copy link

xpader commented Apr 24, 2023

I love this feature in vscode, because it is a pain to unify your own development environment on different computers, by remote development, I can start development on any new machine by install a vscode, even on some computers with extremely low configuration.

@msdrigg
Copy link

msdrigg commented Apr 29, 2023

This is a blocker to me regularly using zed. I almost always use vscode remote developing from my laptop to my desktop at home, so it would be disruptive to change this workflow to use zed.

If this feature was supported, then I would definitely switch to use zed as a primary editor when using my low end MacBook Air.

@JesseFarebro
Copy link

JesseFarebro commented Apr 29, 2023

I'll also chime in with some additional context around this feature.

For my use case (and others who work with HPC) almost none of our development is done locally. VSCode is the de facto standard due to the remote development tools. I know that JetBrains also has some remote development tools although I'm not too familiar with them.

It would be great to see another editor that could support this use case and it seems Zed might be uniquely positioned to pull off an amazing user experience given the infrastructure built around collaborative editing. Excited to see what can come from this!

@zlpkhr
Copy link

zlpkhr commented May 11, 2023

+1 for remote lsp connection, I really like docker dev environments for keeping host machine clean

@loujr
Copy link

loujr commented May 15, 2023

Remote connection is also a big blocker for me using zed. Keep up the great work!

@alexghirelli
Copy link

+1, I use remote env everyday. It could be amazing to have this feature in Zed.

@ossfellow
Copy link

Supporting devcontainers will open up a lot of possibilities, including easy integration with developer tools, like newly launched DevPod, which supports launching development environments locally or on the cloud platform of your choice.

@jansol
Copy link
Contributor

jansol commented May 24, 2023

Launching a whole headless zed on the remote sounds like a good solution - it would trivially allow for remote language servers without them having to support TCP. And remote language servers etc integrations in the correct target environment would make life way, way easier than trying to approximate something similar locally with SSHFS. I occasionally write code where some dependencies are simply not available on mac, so every file that uses those upsets the language server.

@pbiggar
Copy link

pbiggar commented May 27, 2023

Sadly can't use zed in its current state because our entire development is done via VSCode devcontainer.

@iamvoidcoder
Copy link

+1. Please please please make the remote development feature happen.

@0xGodson
Copy link

+1 for remote connection

@tk103331
Copy link

lapce support SSH and WSL remote development
https://docs.lapce.dev/get-started/remote-development

@iamvoidcoder
Copy link

iamvoidcoder commented Jun 26, 2023

The remote dev in Lapce looking interesting but the editor itself is really in its early days. Even the basic core editing features aren't there (find & replace, bookmarks etc), no way to use as a daily driver.

Though Zed is not far ahead in this department either :( Wish the devs first implemented basic editing before taking on the fancy complex colab features.

@mosenturm
Copy link

mosenturm commented Jul 22, 2024

I'm not sure with regard to the sign in but VSCode does also download a copy of itself on remote machines for SSH, it just doesn't have as much attention drawn to it. It's located at ~/.vscode-server(-insiders) for Linux remotes.

vscode simply (simply) puts all required files in the users home directory. Zed installs crap everywhere [...]

Zed puts all required file in the user home directory too. No crap everywhere.

@iamnbutler
Copy link
Member

@tinyaustralia Disagreeing or providing critical feedback are both fine, but the way you are saying things is not. This is your one formal warning of being in breach of our Code of Conduct.

@abhibeckert
Copy link

@tinyaustralia Disagreeing or providing critical feedback are both fine, but the way you are saying things is not.

Sure, but he makes an important point. This feature has nothing to do with collaboration. In VSCode I almost exclusively use it to connect to localhost (in a container or virtual machine).

Also - when I do want actual remotes shared, I’ll use 1Password or KeePass for that. Something with E2E encryption and robust security.

@mathroc
Copy link

mathroc commented Jul 22, 2024

sure, and no one has issues with that part, if you read the release notes, it links to https://zed.dev/docs/remote-development and there it says:

Currently the two instances connect via Zed's servers, but we intend to build peer to peer communication before the feature is fully released.

So it's likely a shortcut they took to get the feature working, and they are planning to make it work without going through Zed servers

@tinyaustralia

This comment was marked as abuse.

@psychedelicious
Copy link

@tinyaustralia

The feature itself is in beta and, as described on the docs page, the intention is to have no sign-in requirement for the full release. It's very clear. You don't have to use it before this is implemented.

The words you used (which, btw, are not removed - you can click your comment to show it) are not kind, empathetic or respectful. Whether or not you directed them at the product or project or individuals is immaterial. The simple fact is that humans are building zed, and that kind of language makes its way back to those humans.

Nobody is threatening you and nobody is going to hold it against you if you apologize and move on.

Anyways, I agree with your point. I cannot use zed for anything real until the remote dev feature uses direct peer-to-peer communication.

I'm pleasantly surprised at how fast the zed team has gotten linux and remote dev up and running, great work!

@tinyaustralia

This comment was marked as abuse.

@maan2003
Copy link
Contributor

maan2003 commented Jul 24, 2024

zed user@host:path/to/project

zed ssh://user@host:1234/path/to/project is clearer and extensible :)

@codegod100
Copy link

What still needs to be done before this is closed? Is there a kanban somewhere?

@rome-user
Copy link

I have used the remote development feature for a week. I'll start with the positive feedback, since I like this feature as-is.

  • Never crashed

  • Internet connection was lost due to laptop sleeping, but Zed was able to reconnect and not lose data

  • It works well in a mid-sized TypeScript project

As for negative feedback,

  • LSP feels slower than VS Code's remote

  • Each terminal tab requires authentication

  • Inline assist works, but Assistant Panel doesn't

Overall, I agree with the other comments. The feature request seems satisfied. I haven't felt the need to use VS Code this week.

@kevin-leptons
Copy link

I look forward to using a peer-to-peer connection between the editor and remote machines 👍 .

@MrCroxx
Copy link

MrCroxx commented Aug 26, 2024

I look forward to using a peer-to-peer connection between the editor and remote machines 👍 .

+1 Is p2p remote mode under development? 🥰

@brunoscota
Copy link

I look forward to using a peer-to-peer connection between the editor and remote machines 👍 .

+1 Is p2p remote mode under development? 🥰

Sorry my understanding but what is peer to peer remote mode?

@nrclark
Copy link

nrclark commented Aug 26, 2024

I look forward to using a peer-to-peer connection between the editor and remote machines 👍 .

+1 Is p2p remote mode under development? 🥰

Sorry my understanding but what is peer to peer remote mode?

The current implementation relies on connections to Zed's servers, meaning that it can't be used on remote machines that don't have access to the internet.

@lattice0
Copy link

lattice0 commented Aug 26, 2024 via email

@gintsmurans
Copy link

+1 for working inside docker containers. We use Dev containers extension to work inside docker machines, this way we are having the same environment on every dev instance and very much the same in prod. This also speeds up file change observers quite a lot.

@nicolalandro
Copy link

I have a question, why the remote development need the login on linux?

@arifzeeshan
Copy link

How do we forward port, as it's such an essential feature for remote development.

@lucaspar
Copy link

lucaspar commented Oct 24, 2024

@arifzeeshan until we have port forwarding integrated, you can run from the command line.

if you have a web app at your_ssh_host:8000 like:

python3 -m http.server 8000
# this is running in your_ssh_host

you can forward that port with:

ssh -N -L 9000:localhost:8000 your_ssh_host
# this runs in your local machine

Then open your local browser at localhost:9000. Naturally, you can use the same port in both if it's available.

You can pass -f to run the port forwarding in the background.

@almereyda
Copy link

Integration with DevPod could be favourable to get out of the Microsoft core of the devcontainers ecosystem.

Did someone already have a shot at sketching how such an integration could look like, implementation-wise?

@pascalbreuninger
Copy link

@almereyda I'm a maintainer of DevPod and opened up #15070 a while ago to integrate zed into DevPod. There's actually not much that's missing, just a way to reliably let Zed know about which SSH connection to use

@ConradIrwin
Copy link
Member

This shipped in v0.159.5 that just hit stable.

Thanks for your encouragement on building this, and we will continue to refine things as needed – please file new issues if you encounter bugs!

@mcmah309
Copy link

@ConradIrwin I don't see a mention of containers like in this issue. Are containers supported as well?

@ssttevee
Copy link

containers are being discussed in a separate issue #11473

@sebbZA
Copy link

sebbZA commented Nov 4, 2024

Hi,

I can't seem to find any extension or support for simply connecting to a server via FTP or SFTP. Is support for these protocols still being added or is there an extension out there that I am not aware of that someone could suggest? Any assistance would be appreciated, thank you.

@imron
Copy link
Author

imron commented Nov 4, 2024

This shipped in v0.159.5 that just hit stable.

Fantastic news! I remember creating this ticket back when Zed was still in invite-only beta and it's great to see it finally come to fruition. Thanks everyone who contributed for all your hard work.

Great blog post linked in the release notes too.

@pascalbreuninger
Copy link

@almereyda Quick update on DevPod support: We've just released v0.6.0 which adds Zed as an IDE

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
design [core label] enhancement [core label] priority request A request from a stakeholder or influential user remote dev Feedback for remote development servers
Projects
None yet
Development

No branches or pull requests