From Linux to NetBSD, with SSH Only

jaypatelani | 221 points

Hi, author of the article here.

After reading all the comments, I believe I must precise, that I am aware of most of the mentioned alternative techniques.

Most of these only work as long as remote screen/keyboard control access is possible throughout a cloud panel (VNC).

My goal with this article was to avoid any third party control and making it to works even on a remote linux desktop pc used as a server.

Thanks for all the feedbacks, I appreciate it.

naguam | a month ago

Similarly, I've used a project called nixos-infect(1) to install NixOS on cloud providers that don't natively offer it. It's worked well on the handful of boxes I've ran it on.

(1): https://github.com/elitak/nixos-infect

DocChi77 | 2 months ago

This will come in very handy, since many providers don't natively provide NetBSD.

I've played similar tricks mounting a ramdisk, copying things in to it, starting daemons from it, then force-remounting rootfs read-only, then doing things you can't normally do. This takes things quite a bit further, and I like it.

I've never quite understood the details of Linux boot methods. This article is wonderful because it doesn't just say what to do, but explains what's going on, and in detail. Can't wait to try!

johnklos | a month ago

I’d like to note that there are a lot of cheap, reliable providers that support BSD, either with KVM templates already, installation with an available ISO, or many have custom ISO where you can upload or give the URI to any iso you wish to use. Obviously this will usually be KVM virtualization.

Some providers off the top of my head:

prgmr.com (now tornado vps apparently) - long-standing provider - they used to have netbsd dom0’s but now it’s all Linux based it looks like so appears you have to netinstall netbsd in your vm now)

buyvm.net - reasonable pricing and have bsd available to install (can’t remember if template or iso ready to mount/install)

https://www.netcup.eu/vserver/ - excellent value / been around forever (they offer custom iso)

I will add more here as I think of them..

indigodaddy | a month ago

I've installed Debian (on ZFS with debootstrap and chroot) from inside a CentOS install over SSH before, but this is different.

doubled112 | 2 months ago

Cute and scary. Reminds me of a time where i manually converted a remote Linux box to full disk encryption via SSH about 15 years ago. It worked, despite bugs in the debian start scripts. But it was, once again, very scary.

Tepix | 2 months ago

One of the things I've done in the past that is quick and easy is to use grub to chainload another bootable volume. Scp an iso or other disk image over, chainload to that, run the installer inside it as though it had just been pxebooted or booted from a flash drive. If you can netinstall from there, then you're good to go with the OS of your choice.

There's lots of ways if you have access to common cloud primatives (replacement root volume, etc) and have some creativity.

I did appreciate this post though because it's for a way I haven't used before.

darkhelmet | a month ago

Compliments to the author for clearly explaining all of the steps involved. I've never gone this deep, although I have previously converted remote headless Linux servers to full disk encryption using similar techniques. Thanks for sharing!

xolox | a month ago

This reminds me some other interesting things (but from Linux to FreeBSD) around 15-20 years ago:

* https://www.daemonology.net/depenguinator/

gslin | a month ago

Im watching the asciinema and wondering whats that first `ls` move? is that expanding files with `ls` somehow?

lagniappe | 2 months ago
[deleted]
| a month ago

Offtopic:

OpenBSD has an installation ramdisk. Just boot that.

See https://raby.sh/installing-openbsd-on-ovhs-vps-2016-kvm-mach...

I've also seen "dd if=path/to/install/ramdisk /dev/sd0" and reboot; depends on being classic BIOS not uefi. Can't find the link tho.

j_not_j | a month ago