I normally SSH in and do what I need or scp a script or whatever over .
Linux
From Wikipedia, the free encyclopedia
Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).
Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.
Rules
- Posts must be relevant to operating systems running the Linux kernel. GNU/Linux or otherwise.
- No misinformation
- No NSFW content
- No hate speech, bigotry, etc
Related Communities
Community icon by Alpár-Etele Méder, licensed under CC BY 3.0
If you have ssh/SCP you can use sshfs to mount the remote host as a fuse filesystem. That would let you edit files on your workstation, but more or less all other commands would still need to happen on the remote system.
I edit everything in my local copy of the repository and then push the changes to my devices with ansible.
Same, but I’ve got Ansible (or Puppet) powered off of a git repo. So I make my changes, commit/push to fit and then Ansible takes it from there.
There isn't usually much to do on an embedded router other than use its own commands to change settings or manage packages. And if it has enough juice to run more advanced stuff it probably has bash available too.
Anyway, there's NFS for mounting filesystems remotely. It's not very complicated, the catch is that the same UIDs and GUIDs on the host must exist on the guest, because it doesn't do any uid translation. On an embedded system most stuff is owned by root, meaning you'd have to use root on guest too, which may not be a great idea.
Secondly, you can't run commands over NFS, just manipulate files and I'm not sure that's something you really need to do a lot of on a router.
This is probably not a solution you would want, but I will mention it anyway...
Emacs has a built-in app called "TRAMP mode", what it does is it works as back-end for all of Emacs's own built-in text editing and file browsing commands, then it uses ordinary SSH and POSIX shell commands on a remote host as the primitive APIs for this back-end. You could say it uses SSH and a POSIX shell as a RPC mechanism.
What this means is you can use the ordinary Emacs editor with the entirety of your usual Emacs configuration, but all filesystem changes (including editing files, directories, and running shell processes) occur on the remote host via SSH. In order to activate it, you just use Emacs's special TRAMP URL scheme as the file path you want to edit, and it works seamlessly, (especially if you setup your SSH agent so you don't need a password). An example of such a URL would be /ssh:user@remote-host:/etc/hosts
.
Cries in vim
We're gonna get through this
Vim has it's own way to edit/brows remote files. Checkout netrw:
There are Vim emulator apps for Emacs, and you can use them with TRAMP mode for remote file editing as well. Doom Emacs and Spacemacs both provide extremely good Vim emulation that work consistently throughout all Emacs modes, including TRAMP mode.
I've discovered this not long ago and it makes my work way easier. Also, using the dired mode on the remote is useful.
People with PhDs in Vim will laugh at this, but I sometimes connect to remote systems through VS Code SSH connections when I'm working on a project with multiple files on a remote system.
I've used mirror.vim for this. Pretty much similar UX as remote workspaces. Forone off editing, you can do vim ssh://remote/
Sometimes, VS Code-ium is piss poor especially over bad connections but otherwise the remote management is quite awesome
And ofc, there's emacs with TRAMP mode
I am not quite yet st the level where I have a ton of user scripts I'd be lost without, so SSHing into a box is hardly a speed bump for me.
I don't recommend using the shell on routers for day-to-day management. Instead, consider using a network configuration management system like rconfig. I've used RANCID in the past, but I suspect something more modern like rconfig will be useful to you.
You can use something like Nix + home-manager
& take your environment with you.
i open vscode on the server through the ssh tunnel