This Post We will cover how to connect Visual studio code on server remote folders via ssh for code editing. Microsoft Visual Studio Code is One of the best Text Editor / IDE for Code writing, supports text highlighting working on MAC, Linux, and windows. Extension theme support and open source.
See My configuration settings on the VS Code. https://anishmandal.in/2017/11/my-visual-studio-code-settings/
My Extension was created for Code-igniter for VS Code. https://anishmandal.in/2017/11/ci-snippets2-for-visual-studio-code/
Requirements
- Visual studio code installed on a system
- Operating System Mac, Linux or Windows will work the same.
- VSCode extension “Remote SSH” by Microsoft. https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.remote-ssh
In Windows Open SSH required to follow my this post for installation
https://anishmandal.in/2019/11/how-to-use-public-private-key-on-windows-using-putty-or-git-bash/
Installation of Remote SSH Extension
Install remote ssh by visiting extension pane (Windows/Linux = Ctrl+Shift+x) (MacOS Command+Shift+x) search “Remote-SSH” click install
data:image/s3,"s3://crabby-images/d2949/d294945d4d1f94c77044a66d46a816e9f5c2fb04" alt="Remote -SSH Extension installation in VS Code"
Adding SSH Host
Open Command Palette from View menu or by using Keyboard shortcut
#Windows/Linux
Ctrl+Shift+x
#MacOS
Command+Shift+x
Type “ssh-” will show all available options for remote ssh extension
Select Add New SSH HOST.
data:image/s3,"s3://crabby-images/2c096/2c0964deea7ca67e31ac4b24335a5dca8114f2df" alt="Adding New SSH Host in VS Code"
The command prompt will ask to enter the ssh username@ip or hostname.
For this demo to secure IP I have added the IP address in my host file pointing “myremote.local” and trying to connect as “root” user so the command will be
ssh [email protected]
data:image/s3,"s3://crabby-images/c6daf/c6daf99895f85764eb15ef9064aa0bfca1961448" alt="Connect SSH Host via command"
Next command asking where the config file needs to save.
The best option is to save in the User home folder. So we can edit or update files and keys easily.
On windows its shows full path “C:\Users\UserName\.ssh\config”
On Mac/Linux “/home/UserName/.ssh/config” or “~/.ssh/config”
.ssh is hidden folder and config is the file where all ssh connections details will be stored for easy access.
data:image/s3,"s3://crabby-images/42535/42535056271b86a2cd68cd6b9fa90c7d2dab39d7" alt="VS Code Remote SSH Config File Location"
After Successfully adding host details right side of bottom the prompt shows to connect click.
data:image/s3,"s3://crabby-images/2d283/2d283ba67e6eb8a89b8073a68e37f19da3e80140" alt="VS Code Connect added SSH Host"
The default ssh connection behavior will ask to enter the password of the user type password.
data:image/s3,"s3://crabby-images/342de/342de22c8962596b53375070bee3ab122425e640" alt="Remote SSH Extension entering Password"
The first time connection will show ECDSA key fingerprint select “continue”
data:image/s3,"s3://crabby-images/6b090/6b090df2d238f1d6a091eb5954037cee015b689b" alt="Remote SSH Adding Host EDSA Confermation"
It will ask to enter the password again.
data:image/s3,"s3://crabby-images/97d84/97d84fff37b09a402ed8698adc9351db8eb8a8c3" alt="Remote SSH Extension entering Password for VS setting installation"
After a successful connection, Left Pane will show Massage “Connected to SSH:”.
data:image/s3,"s3://crabby-images/a0d02/a0d02aea21d31a23ac7961733f46e28d4ae846e0" alt="Connected SSH Server Via Remote SSH Extension"
To open remote folders click on the open folder it will open command where we can browse the directory of a remote server and select folder after selecting folder click on OK
data:image/s3,"s3://crabby-images/2bdbe/2bdbe61977deaa945e3df1137e3f8c27f95877ab" alt="Remote SSH Browsing Folder to Open in VS Code"
Once its connected any file from that folder can be opened for edition same in the left corner we can see it show status.
data:image/s3,"s3://crabby-images/327d3/327d30e061d0c6a0d51ef7e16fe747f4fe6c1b66" alt="Opening Files and Checking Status in VScode over SSH"
As an, there is second way also to add a host from “Remote explorer”
Reconnecting added SSH Hosts.
On Left Pane side we can select “Remote Explorer” by opening it we can see all added SSH host in List
data:image/s3,"s3://crabby-images/31499/3149928df6a8ac13d5172c069978249cd2e54202" alt="Managing SSH Host from Remote SSH Extension"
Right-Clicking on Folder or Host we can click to connect I will prompt password and connect the Host.
Password Less SSH Access.
As default security, the password is complex and long 16 to 20 digit or the server is configured for keyless authentication. Which is sometimes hard to remember or not convenient to type every time.
To simplify the re-connection or password typing we can add Public-Private key-based authentication.
To follow along with windows Please refer to the Adding ssh post mentioned in Requirements to generate Keys. The same command “ssh-keygen” can be used in Mac or Linux to generate Key Pair once it’s completed follow along.
Copy public key to the remote server by using a command
ssh-copy-id username@IPAddressorHostName
It will prompt user password one time to update the authentication file in the remote host and prompt back the key was added successfully.
data:image/s3,"s3://crabby-images/145d1/145d105e17b098c5f92113bcdfe8b9905d8b1489" alt="Adding Public Key on Remote Server via SSH"
Before making any changes in the VS Code config file it is better to verify the connection is working without a password. by connection to the server using ssh command. It should not ask a password as shown below.
data:image/s3,"s3://crabby-images/d6e29/d6e29cff55a81086f2b8aab09d22a5e0466d96cb" alt="KeyLess Authentication vis SSH"
The default behavior of Mac / Linux saves Private Key as “id_rsa” in the .ssh folder. Windows sometimes we need to copy the Private Key and create file example created privatekey file in the same .ssh folder.
data:image/s3,"s3://crabby-images/2d5e3/2d5e338964f07a870a08c9bdc52dcf2afa33ad17" alt="Windows Private Key Location for Testing"
Now in the “Remote Explorer” select setting, it will open that config file in host all just need to add the “IdentityFile” command with File Location.
#Windows
IdentityFile C:\Users\UserName\.ssh\privatekey
#Mac / Linux
IdentityFile ~/.ssh/id_rsa
data:image/s3,"s3://crabby-images/81fa6/81fa6b6e9f5ab3379eb36a79e0c1d0ef854e2857" alt=""
Now when Open The folder by right-clicking it will not ask for a password.
data:image/s3,"s3://crabby-images/9ee0a/9ee0a2ee6ae5a0eaa7af26e31f5019ddf6daa70d" alt="Opning Server SSH Connected Host from Remote Explorer on VS Code"
The connection will be established in a folder.
data:image/s3,"s3://crabby-images/13ad8/13ad89e4a9982713afac0b49c6330a3b29fc7f2f" alt="Connected SSH Folder Via Remote SSH Extension in VS Code"