💾 Archived View for tsqrl.xyz › gemlog › 2022-01-17_openbsd-vmm.gmi captured on 2023-06-16 at 16:16:53. Gemini links have been rewritten to link to archived content
⬅️ Previous capture (2022-04-28)
-=-=-=-=-=-=-
If you're not breaking things, you're not learning.
I've always treated my OpenBSD installs as somewhat precious; it's a wonderfully minimalist OS, and I'd prefer not to install a bunch of unnecessary packages. I also don't want to keep track of packages and configurations that might need uninstalling/undoing.
I very much wanted to try setting up a Vger instance for hosting a site on gemini, as described on Solène's capsule:
How to deploy Vger gemini server on OpenBSD
This is not the sort of thing I need running on my laptop, and I didn't want to do a separate install of OpenBSD just to run through the instructions.
The remedy is to conduct experiments like this one on a throwaway virtual machine using OpenBSD's `vmd` service. Think of it as a lightweight version of VirtualBox, not unlike LXC:
Unlike VirtualBox, vmd VMs are headless and you manage them using command line tooling (vmctl).
The up-front setup is minimal and straightforward. The FAQ and man pages are your friend:
After enabling `vmd` and configuring networking (so each VM gets its own IP address), I manually installed OpenBSD in a VM.
On this fresh install, I did the following:
I'll use this VM's hard drive image as the "base" for subsequent VMs; each new VM will start as a clone of the base image.
But, this means that changing the base image breaks all derived images. I made the base image read-only and vowed never boot from it again.
chmod -w openbsd-base.qcow
Then:
Useful commands:
# Creating a derived hard drive image vmctl create -b ./openbsd-base.qcow qcow2:openbsd-experiment1.qcow # Restart the vmd service and the VM named "experiment1" doas rcctl restart vmd vmctl start experiment1
So far, I've used this as the foundation for learning how to use:
And, I've installed/compiled the following browsers for trying out:
Remember that a VM in vmd is headless. To use the browsers, I use X11 forwarding with `ssh -Y`. This requires the following changes to the VM:
- Enabling the sshd service (and allowing root login, for convenience)
- Enabling X11 forwarding over ssh (in `/etc/ssh/sshd_config`) and doing `rcctl restart sshd`