this post was submitted on 02 Apr 2026
106 points (99.1% liked)

Selfhosted

56957 readers
903 users here now

A place to share alternatives to popular online services that can be self-hosted without giving up privacy or locking you into a service you don't control.

Rules:

  1. Be civil: we're here to support and learn from one another. Insults won't be tolerated. Flame wars are frowned upon.

  2. No spam posting.

  3. Posts have to be centered around self-hosting. There are other communities for discussing hardware or home computing. If it's not obvious why your post topic revolves around selfhosting, please include details to make it clear.

  4. Don't duplicate the full text of your blog or github here. Just post the link for folks to click.

  5. Submission headline should match the article title (don’t cherry-pick information from the title to fit your agenda).

  6. No trolling.

  7. No low-effort posts. This is subjective and will largely be determined by the community member reports.

Resources:

Any issues on the community? Report it using the report flag.

Questions? DM the mods!

founded 2 years ago
MODERATORS
 

Like soup-to-nuts. I know I need to document what I'm doing and I've started several times, but then I never go back and make updates. I don't know if it's just the ADHD or if I'm just going about it or thinking about it in the wrong way.

So I'm curious about:

  • what you use for your documentation
  • how you organize it
  • what information you include
  • how you work documentation into your changes/tinkering flow

Edit: Dang, folks! You all have given me a lot to read through, think about, and explore. Thank you!

top 50 comments
sorted by: hot top controversial new old
[–] xcjs@programming.dev 1 points 4 hours ago

Ansible.

Infrastructure as code is the best documentation.

[–] SreudianFlip@sh.itjust.works 1 points 1 day ago (1 children)

ADHD: functional notes in abbreviated version on fat strips of painter's tape on server case or shelf. Passwords go on page dedicated to that server or service in a little black notebook, then eventually in a password manager.

Readme file if my brain lets me, usually 3 months later after hyperfocus on troubleshooting.

[–] BruisedMoose@piefed.social 2 points 1 day ago

Honestly, the tape idea is one of the most practical ones in the thread!

[–] MajinBlayze@lemmy.world 133 points 3 days ago (2 children)

That's the neat part, I don't.

[–] undefinedTruth@lemmy.zip 42 points 3 days ago (5 children)

"I don't need to, I have it stored all in my head."

Famous last words.

[–] MajinBlayze@lemmy.world 12 points 3 days ago

It's not like anyone needs to support it when I'm gone.

[–] frongt@lemmy.zip 6 points 3 days ago

"I can remember that" is my cue to write it down, because I won't.

load more comments (3 replies)
[–] Buck@jlai.lu 12 points 3 days ago (1 children)

The theory is I use Docmost. The reality is I don’t, and I hope my backups are solid.

[–] MajinBlayze@lemmy.world 15 points 3 days ago* (last edited 3 days ago) (2 children)

I have an obsidian document where I write changes I want to do in the future that I never look at; does that count?

[–] foggy@lemmy.world 5 points 3 days ago

I just found my todo list and half of it is irrelevant and half of it is done.

I even had a work todo list for my old job lol.

load more comments (1 replies)
[–] lka1988@lemmy.dbzer0.com 7 points 2 days ago
[–] avidamoeba@lemmy.ca 62 points 3 days ago* (last edited 3 days ago) (2 children)
[–] Evil_Shrubbery@thelemmy.club 14 points 3 days ago (2 children)

I just think I do that, but absolutely don't.

[–] Agent641@lemmy.world 8 points 2 days ago

write-only memory.

no read, only write!

[–] avidamoeba@lemmy.ca 5 points 3 days ago

Yeah I also use config-as-code along with wiki but I used to remember things 10 years ago when the setup was simpler and the brain was newer. 😅

[–] Scrath@lemmy.dbzer0.com 3 points 3 days ago (1 children)

I read the title and this was literally the first thing that popped in my head

load more comments (1 replies)
[–] atzanteol@sh.itjust.works 48 points 3 days ago (5 children)

The fun thing about infrastructure as code is that the terraform, ansible and k8s manifests are documentation.

I only really need to document some bootstrap things in case of emergency and maybe some "architectural" things. I use joplin for that (and many other things).

[–] AliasVortex@lemmy.world 3 points 3 days ago

That's the direction I'm moving my lab in. Plus a bit of supplemental markdown to keep track of which guides I'm referencing (and which parts can be ignored because I baked it into the terrafom). It's really nice to know that as long as I tweak the terraform for changes, I don't have to worry about forgetting what I changed.

load more comments (4 replies)
[–] synapse1278@lemmy.world 31 points 3 days ago (1 children)
  • what you use for your documentation

Markdown files

  • how you organize it

What ?

  • what information you include

The commands that worked and the stuff that didn't work and the links to the source of information

  • how you work documentation into your changes

I write as I go. I keep it as part of a git repository when relevant

[–] D_Air1@lemmy.ml 2 points 2 days ago

Had to scroll down this far just to get to markdown files. Although I write with a bit of a delay. Once I get something working. Then I document what worked and what didn't. Alternative methods and issues I had with the alternatives.

[–] Nibodhika@lemmy.world 6 points 2 days ago

The moment you think you might possibly need documentation is the moment you should seriously consider using Ansible or similar to orchestra things. Sure, it's annoying for a single server, but it is the best form of documentation there is.

[–] dogs0n@sh.itjust.works 3 points 2 days ago

I just create a README.md file wherever I setup services with docker compose which keeps top level docs so I know how and why certain things work.

Other than that, if comments are supported inside configuration files, also document stuff in there too.

That's been good enough for me.

[–] uenticx@lemmy.world 13 points 3 days ago* (last edited 3 days ago) (1 children)
[–] Goodlucksil@lemmy.dbzer0.com 4 points 3 days ago

README_I_AAM_VERY_IMPORTANT.md

[–] shrek_is_love@lemmy.ml 14 points 3 days ago (1 children)

All my computers (including servers) share the same NixOS Flake. So my documentation consists of:

  1. The Nix code itself
  2. The commit messages for each change I make
  3. Inline comments in the Nix code
  4. A few readme.md files to explain the contents of certain directories
[–] captcha_incorrect@lemmy.world 1 points 2 days ago (1 children)

In only have one server with NixOS. I don’t use flakes, just plain nix files. It still works great as documentation.

The only thing it is missing is why something is setup in a certain way.

[–] shrek_is_love@lemmy.ml 1 points 2 days ago

Do you use git? That basically forces you to do some documentation as you go. Multi-line commit messages are often helpful too. (When I first learned git, I only committed using git commit -m which is a bit restrictive in terms of how much you can fit in commit messages)

[–] lightnsfw@reddthat.com 8 points 3 days ago

When I set something up I write all the steps I'm doing in obsidian as I do it. The pages get tagged so they're searchable in the future.

[–] northernlights@lemmy.today 8 points 3 days ago* (last edited 3 days ago)

draw.io in my nextcloud

network diagram on nextcloud

And leantime to keep track of what I want to do with notes and such

leantime kanban screenshot

And a mess of notes in Joplin.

[–] Shimitar@downonthestreet.eu 12 points 3 days ago (5 children)

Dokuwiki

https://wiki.gardiol.org/

For me for future memory and for others who might need it

[–] irmadlad@lemmy.world 6 points 3 days ago (1 children)

https://wiki.gardiol.org/

BTW, this gent's wiki is worth a bookmark. Stumbled on it before I knew the originator.

[–] Shimitar@downonthestreet.eu 3 points 3 days ago

Thanks you, it means a lot. Just to be clear for whomever didn't go there: there is zero monetization, no ads, no profiling.

[–] eli@lemmy.world 1 points 2 days ago

Using Mediawiki here.

I have obsidian and tried using it, but my personal workflow for my homelab just doesn't...work with it? Idk, it's just easier to throw it into a private wiki.

I still use obsidian but for personal life stuff.

load more comments (3 replies)
[–] Agent641@lemmy.world 10 points 3 days ago (1 children)

Why do you have to be like that? Drop the innocent questions and just come right out and call me a piece of shit directly.

load more comments (1 replies)
[–] death916@piefed.death916.xyz 10 points 3 days ago

I used to try and do it all in obsidian but I'd forget a lot. Now I use nix and it's all done for me basically

[–] irmadlad@lemmy.world 10 points 3 days ago
  • I use Obsidian
  • Usually, what I do is write the documentation as I am engaged with the project at hand. Then clean everything up, and transfer to Obsidian.
  • I include everything. I don't leave anything for my mind to wonder about. If I didn't write it down, it didn't happen.
  • Date any addenda or changes (4-2-26: Firewall rules review)
[–] tobz619@lemmy.world 9 points 3 days ago

NixOS because it's declarative kind of does it all for me.

The .nix files serve as their own documentation and if I need to do anything outside them I add a comment to the .nix file.

[–] mrh@mander.xyz 5 points 3 days ago
[–] Scrath@lemmy.dbzer0.com 6 points 3 days ago

I have a bare minimum of documentation as markdown files which I take care to keep in an accessible lovation, aka not on my server.

If my server does ever go down, I might really want to access the (admittedly limited) documentation for it

Mostly just quick notes in Obsidian, if I do anything complex or 'unusual' to set something up I'll save the history that I ran.

[–] Mobile@leminal.space 3 points 2 days ago

Man I'm as basic as it comes. I have a .txt file that I update with today's date and write what I'm working on. I try to write as much as needed on what I'm working on. I write commands down and save links to reading material.

It's not the best but it's better than nothing.

[–] otacon239@lemmy.world 5 points 3 days ago

At work, since I’m the sole IT, I’ve been putting everything into MkDocs and it’s been working out great for the team. Only complaint is that I can’t seem to figure out how to update anything without just relaunching the Docker container every time. They mention that you can live reload, but not how.

I'm just rewriting everything in Ansible and I think is worth the effort, it's self-documented and as an added bonus I won't have to keep backups of the whole VMs, just the ZFS pool with the data/databases.

[–] DetachablePianist@lemmy.ml 4 points 3 days ago

I run Adguard Home containers (the primary auto-syncs to the secondary) and use redirect filters to assign hostnames to each of my containers. I have a "services" folder of bookmarks for each container host so I don't have to remember each service's port number. I use KeePassXC to track all my passwords and certificates so authentication is a breeze (someday I'll get around to setting up an SSO solution). I also keep a .txt file with my basic network info that doesn't always translate well to dns hostname redirects in adguard. I occassionally remember to update my hosts listed in the file. My individual config files aren't backed up beyond my automated container backups, but so far none of my services have been that complicated I couldn't just rebuild from scratch.

It's not perfect, but combined with my automated backups I have barely enough to rebuild if/when my hardware fails.

[–] VexLogic@feddit.online 3 points 3 days ago (1 children)

I'm actually in the middle of rebuilding my entire setup right now and one of my major goals is to actually document my processes this time.

I use Obsidian which is a Markdown editor and I have a couple plugins alongside that for QoL stuff and extra features.

I document processes, problems and fixes I encounter, list of active services alongside where/how to access them, and plans for future additions/changes.

As far as working documentation into your flow, realistically that is just a matter of discipline. It is explicitly up to you to stay on top of documentation.

Hope that helps, and good luck with your endeavor! 😁

load more comments (1 replies)
[–] foster@lemmy.hangdaan.com 4 points 3 days ago

Use declarative systems and software, where the configurations files themselves are the documentation. For example, I use Guix and Podman. The entire OS is described in a Scheme file and all the services are described in a YAML file. I just need those two files to get an overview of the entire setup.

[–] communism@lemmy.ml 4 points 3 days ago* (last edited 3 days ago)

Notesnook notebook with whatever info I need to be able to administrate the system. e.g. what different ports are used for and why the firewall policies are what they are, sometimes write-ups after a troubleshooting session, etc.

The Notesnook instance is self-hosted too, but if the server goes down, the notebook will still be available locally.

[–] magic_smoke@lemmy.blahaj.zone 3 points 3 days ago

I'm surprised no one else has answered mediawiki. Love my mediawiki instance.

[–] pineapple@lemmy.ml 1 points 2 days ago

I use obsidian, I dont really have a self hosted setup yet but thats what I use to document desktop config and what I will use for my server when I get it running.

load more comments
view more: next ›