Random Bits of Information About My Self-Hosted Servers

2023-09-03 23:08:24Z (last updated 2023-10-16 08:55:03Z)

laptop-server

I have a server. It's a laptop. I have said that many times, and it's true. It's just a random laptop that I had laying around, and decided it would be a good idea to run some stuff on it.

I use Fedora Linux. The package manager dnf has dnf history, which lists the history of your package management all the way back to when you installed. My server was first installed on 2021-09-04T12:37:26Z and it took

8 minutes to install the distro. It's even got logs of what happened during the install!

However, that's a feature of dnf, and not really much other package managers.

It's almost been 2 years of running now. After stumbling upon many issues, I have brought the server into stability with a lot of work (and shell scripts).

I upgraded the internal drive from a hard drive (spinning rust) to a solid state drive (electrons of something). Highly suggested unless you like slow performance. Like pretty slow.

The laptop-server has a very limited amount of RAM. I also run probably too many things on that too. Also, nginx config reloads take like 10 seconds, which is a significant of time.

It also hosts my website.

imac

Self explanatory. It's an iMac.

=> The iMac that I use

Currently, it runs Alpine Linux. It's kind of an experimental box to do experimental thingies.

Both laptop-server and imac run Prometheus. They also federate with each other, to share data and to make alerting non-functioning things easier.

=> Prometheus

It also runs a Tor bridge. No, I am not going to make details about it available.

History about imac

This is specific to my machine, not iMacs in general.

First, it started running with Debian.

With 4 gigabytes of RAM, I did... something. I'm not sure, maybe running an IPFS node (to have my website on IPFS when I still did that).

Then some disk fuckery happened and the install got destroyed or something. Then I abandon it.

Probably later, I try to get some stuff off of it, then I try again with Debian again. Later, I would distrohop to Alpine Linux and now I'm on Alpine Linux for imac.

Alerting and monitoring

Previously, I used Uptime Kuma.

Running a giant nodejs app didn't really seem like a good idea for reliability, so I started using Prometheus, inspired by whatever sourcehut was doing (using Prometheus).

=> Uptime Kuma

Over time, I shifted everything to Prometheus. That included the blackbox prober, which is running on imac (for package management reasons), federates with the laptop-server's Prometheus, and the laptop-server Prometheus sends alerts of when things are wrong or something.

Now onto the alerts. Example of alerts I setup:

And also, for good measure:

Alerts just go to Alertmanager. If it's "interesting" or "important", it goes through ntfy (with a bridge). If it's "urgent", it goes through both ntfy and email, just in case.

=> Alertmanager => https://ntfy.sh/ ntfy => https://hub.xenrox.net/~xenrox/ntfy-alertmanager/ ntfy bridge

I do not have Alertmanager redundancy. Both imac and laptop-server are in the same room, and connect to the same power and internet, so if either power or internet goes down, there's not really a way to alert me.

I rarely get any alerts if any. My aim for alerts is when something is probably about to go wrong, or something has went wrong. If it's fine, doesn't really matter.

Status pages, and maintaining them

I have a status page! Although, I rarely update it, only when some unplanned outage happens and not when I upgrade a piece of software (at least, not anymore).

=> Status page

I rarely update it because... well, it's a hassle. I tried to make it not a hassle (filling in potential details), but I just don't use it unless something has gone terribly wrong where it is really obvious that "something has gone wrong". That's usually downtime from external factors, or downtime that lasts a noticeably long time (5-10 minutes is roughly the threshold).

Backups

My backups are a bit messy. It goes back and forth with laptop-server and imac, and with my other devices as well.

Backups of laptop-server and imac are made with borg backup. Backups are encrypted, compressed, and deduplicated. Backups are then stored at the following places:

=> Borg backup

That is a lot of different places. For backing up to my phone and main computer, I use Syncthing.

=> Syncthing

My backups take the easy route: Backup the entire root filesystem (and the boot filesystem too). Partial backups are a hassle, and you could get holes which could be fatal to your restore process. An easier/lazier backup method is an easier restore process. Also test your entire backups by doing a test restore.

Currently, I have no off-site backup. I only have on-site backups, and that's about it. I know of one provider and I'll take my time to do nothing about considering it.

I have used my backups multiple times. It includes that one time that I accidentally deleted the configuration for Mastodon with git clean. Restored that file by using the backups to restore that specific file.

Overall

I would say my setup is a bit complicated. It is only me doing this after all, and it doesn't really matter to anyone else because it's just for me and nobody else.

=> public inbox (comments and discussions) | public inbox archives | (mailing list etiquette for public inbox)

Proxy Information
Original URL
gemini://jacksonchen666.com/posts/2023-09-03/23-08-24/index.gmi
Status Code
Success (20)
Meta
text/gemini;lang=en
Capsule Response Time
156.964978 milliseconds
Gemini-to-HTML Time
1.496709 milliseconds

This content has been proxied by September (ba2dc).