this post was submitted on 26 Oct 2023
52 points (94.8% liked)

Selfhosted

40383 readers
471 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.

Resources:

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

Questions? DM the mods!

founded 2 years ago
MODERATORS
 

I want to make a server for hosting media through Jellyfin, and maybe some Nextcloud functionality. I prefer to use containers, but something like TrueNAS' extensions/plugins sound good as well. This is my first server, so I don't know what to choose. My possible options are:

  • Debian
  • Ubuntu
  • Fedora
  • TrueNAS Scale Which one should I choose? I am fine with using either Docker or Podman. (Edit: The server will be running on an old laptop with a single drive slot.)
top 50 comments
sorted by: hot top controversial new old
[–] gravity@infosec.pub 37 points 1 year ago (1 children)
[–] otter@lemmy.ca 4 points 1 year ago (4 children)

As someone who doesn't know as much about the differences, why?

Say debian vs ubuntu

[–] lemmyvore@feddit.nl 11 points 1 year ago

There's no reason to use Ubuntu for this scenario. Debian will be cleaner, simpler and easier to support long term. Ubuntu complicates things and there are no benefits to compensate that for OP's use case.

[–] astrsk@artemis.camp 6 points 1 year ago

Debian is (rightfully) known for being lightweight and very stable. Particularly with older hardware, while still being quite compatible with newer hardware. Their long-running release cycles tend to not break whenever updates do roll out. Ubuntu is Debian based as well, its focus however is on user friendliness and usability, especially on the GUI front. Ubuntu server is perfectly fine, but it’s heavy handed compared to a minimal Debian installation with just a handful of packages selected purposefully by the user for the task it is intended for. There have also been more vocal complaints about whatever Canonical is trying to do with snaps/snap store.

Most beginners with Linux I would more encourage to try Debian for its stability and speed because it’s a great platform to learn Linux on as well as experiment with whatever goal they have by way of packages and projects available all over the open source side of the web.

[–] Jerry1098@sh.itjust.works 3 points 1 year ago

Honestly, I would say because you just have less struggle. I had just a lot more problems when I was using Ubuntu instead of Debian. But I thinks it's mostly personal preference

[–] gravity@infosec.pub 2 points 1 year ago

I agree w what others have said. Just some personal background: started with Ubuntu (well technically I started with Suse, then then Ubuntu). But I found on the server, Ubuntu required a lot of manual upkeep. Debian was just always worked, never had to think twice about it.

[–] jcdenton@lemy.lol 30 points 1 year ago
[–] mypasswordis1234@lemmy.world 19 points 1 year ago
[–] Telodzrum@lemmy.world 16 points 1 year ago
  1. What's the hardware?
  2. Debian, imho
[–] funkajunk@lemm.ee 15 points 1 year ago

I love how every answer so far is Debian.

Debian is the correct answer.

[–] Appoxo@lemmy.dbzer0.com 12 points 1 year ago (1 children)

Using a debian base (OMV6) with docker. Container is maintained by linuxserver.io
No issues so far beyond myself botching permissions but anyone competent should be able to do it.

[–] thirdBreakfast@lemmy.world 2 points 1 year ago

Same, but with the jellyfin/jellyfin image. Been solid for me, less dramas than raw on the OS. Two cores and 8GB for the VM (in Proxmox), media on a NAS, metadata on local SSD.

[–] Atemu@lemmy.ml 12 points 1 year ago (1 children)

Based on that generic request, you're just going to get everyone's personal favourite server OS here. You'll need to give more details to get something tailored to your needs.

[–] lemming741@lemmy.world 8 points 1 year ago (1 children)

True, but everyone's favorite so far is debian

[–] dan@upvote.au 4 points 1 year ago

As it should be.

[–] mr47@kbin.social 10 points 1 year ago (2 children)

Everybody is so quick to suggest Debian (and it's a fine choice), but Alpine is great for such things, as well. It's blazing fast, frequently updated, has most packages you could ever want in a server environment (not that it matters if you're planning on using containers). I've been using Alpine for years as my docker host, and not once have I thought "man, I wish it was debian instead".

[–] yamdwich@kbin.social 3 points 1 year ago

I've been using Debian as my main server OS for a long time, but yeah I've started using Alpine for lightweight hosts for a single app/docker lately. Especially on proxmox with the pve-helper-scripts you can spin up an Alpine container or VM with Docker in a few seconds.

[–] vegetaaaaaaa@lemmy.world 3 points 1 year ago* (last edited 1 year ago) (1 children)

frequently updated

Not something I'd want on my server :) Partly joking, their lifecycle makes sense if you stay on the major.minor release. Though I find 2 years security support is a bit short - Debian LTS is usually around 5 years, not an excuse to wait for the last moment to upgrade but I find it more comfortable than just 2 years.

One thing to watch for is that alpine uses musl as it libc, and many programs expect glibc so you might run into obscure bugs. I find it good as base image for OCI images (again there are edge cases), but wouldn't use it for a general purpose server.

[–] mr47@kbin.social 1 points 1 year ago

I upgrade as soon as new versions come out, I like living on the edge :) if something goes wrong, there are backups.

As for musl, I haven't mentioned it since OP wants to run containers - and in that case, musl doesn't matter. And for running programs natively, many are available as packages (with any musl incompatibilities already resolved). But yeah, if you venture outside these limits, you can definitely run into issues with musl.

[–] Coud@lemmy.world 8 points 1 year ago (2 children)

I would like to recommend an Ubuntu Server LTS which is almost as solid as Debian in my opinion but with many useful features like nonfree drivers accessible right away and newer packages.

[–] BitPirate@feddit.de 12 points 1 year ago

nonfree drivers accessible right away

Non-free firmware is included in the Debian installer since Bookworm.

[–] lemmyvore@feddit.nl 4 points 1 year ago

I've recently switched from Ubuntu Server LTS to Debian stable because Ubuntu started adding snaps to Server too, and the LTS support was restricted behind machine registration which doesn't smell good to me.

I haven't had to deal with any unusual driver support on Debian, probably because I use Intel CPU+GPU for transcoding not Nvidia.

The only external thing I've installed was adding the official Docker repo to have the latest Docker, docker-compose-plugin, containerd etc. straight from the source.

[–] unwillingsomnambulist@midwest.social 6 points 1 year ago* (last edited 1 year ago)

Debian’s great for this.

I’m also running NextCloud (the official AIO Docker image) on Debian. Great for that too.

[–] possiblylinux127@lemmy.zip 6 points 1 year ago

Probably Debian or Ubuntu

[–] dinckelman@lemmy.world 5 points 1 year ago

It doesn't matter what your host os is, if you're using docker. Choose whichever one you like more

[–] TheHobbyist@lemmy.zip 5 points 1 year ago* (last edited 1 year ago)

I tried truenas and was at first enamored but felt quite limited when it came to using docker compose. There are no official ways for using it. Additionally because it uses kubernetes under the hood it's not as easy to go under the hood to make it work, as it requires knowledge of that in addition to docker. There is an unofficial docker compose package but there is almost no documentation that I could find and it seems to be largely unmaintained nowadays.

The other OS are good candidates, though through my research, if you are after reliability, people seem to prefer Debian with its more robust validation of updates.

I'm here mostly because I'm setting up my own homelab and I'm preparing for making use of Alpine Linux, which has no desktop environment which makes it particularly fast to boot. Additionally it is very robust, has decent documentation and allows for quite some customization but requires to learn a bit about how to make it work. With its barebone structure, it is more secure as it has a smaller attack surface and you only install what you need. Perhaps an alternative for you to consider?

Edit: to keep some sanity while needing to manage your homelab, make sure to put some weight on an os you are familiar with. I have juggled for months between OSs to find what does what I want but it has been a long battle of learning everything from scratch every time. Having tried proxmox, truenas, xcpng, and now hopefully settling with Alpine and zfs. Go the more sane way, any of those first three will work just fine.

[–] bigdog_00@lemmy.world 5 points 1 year ago (2 children)

Proxmox. I've been using it and deployed jellyfin in a container, they have a bunch of one-click deployments and it's great. Or you can just use a VM to group Docker containers together. Having a beautiful web interface is huge, Plus being able to access that interface from anywhere via WireGuard/Tailscale is great.

If you do choose to go down this route, there is a "no-nag proxmox" script somewhere, and it will disable some warnings and give you deeper customization options. Well worth a look!

[–] jkjustjoshing@lemmy.world 3 points 1 year ago (2 children)

I've never used Proxmox, but have a Docker setup on Ubuntu Server with Jellyfin, Nextcloud, Immich, and a bunch of other smaller things. I still don't understand why use Proxmox over Docker. What does it give you that Docker doesn't?

[–] bear@slrpnk.net 5 points 1 year ago

Proxmox is completely different from Docker. Proxmox is focused on VMs, and to a lesser extent LXC containers. If you think you will have a need to run VMs (for example, a Windows VM for a game server that doesn't support Linux) Proxmox is great for that.

I run Docker on a dedicated VM inside Proxmox, and then I spin up other specialized VMs on the same system when needed. The Docker VM only does Docker and nothing else at all.

[–] Lem453@lemmy.ca 3 points 1 year ago

I run proxmox, then an alpine VM which has all my docker containers.

I do this so that I have the flexibility to run more vms if needed

[–] dan@upvote.au 2 points 1 year ago

Proxmox isn't an OS. It runs on top of Debian.

[–] Decronym@lemmy.decronym.xyz 5 points 1 year ago* (last edited 1 year ago)

Acronyms, initialisms, abbreviations, contractions, and other phrases which expand to something larger, that I've seen in this thread:

Fewer Letters More Letters
LTS Long Term Support software version
LXC Linux Containers
NAS Network-Attached Storage
SSD Solid State Drive mass storage
VPN Virtual Private Network

[Thread #243 for this sub, first seen 26th Oct 2023, 10:25] [FAQ] [Full list] [Contact] [Source code]

[–] dan@upvote.au 4 points 1 year ago

For a home server, I personally prefer Unraid (which is built on top of Slackware). It has a pretty good UI for managing Docker containers, and also supports KVM (built-in) and LXC (via a plugin).

[–] 2xsaiko@discuss.tchncs.de 4 points 1 year ago (1 children)

Never not going to mention NixOS. :)

You just need to set services.jellyfin.enable = true; in your system configuration and that's it. It's not containers, but it's better than containers.

[–] ninekeysdown@lemmy.world 3 points 1 year ago

I haven't had the time to look into NixOS... but damn that's just fucking magical...

[–] kekvrose@sh.itjust.works 4 points 1 year ago* (last edited 1 year ago) (2 children)

Debian, Ubuntu and Fedora should be good (in that order); I'm not very aware on truenas to give an opinion, but it seems it will work just as well from other comments.

I personally use Fedora, and it's been a solid experience too, with the only gripe bring SELinux. I required a fix for SELinux, but it has worked flawlessly since.

However SELinux might make it annoying to work with containers, so you could consider either switching it off, using another distro or using appropriate configurations to work with it correctly.

load more comments (2 replies)
[–] darkan15@lemmy.world 3 points 1 year ago

I'm using Debian, with Docker and running Jellyfin, Nextcloud, Navidrome and Wireguard on Containers on my old laptop. So that would be my suggestion.

You could install CasaOS and/or Portainer, on top of Debian if you want an easier way to manage your server and containers.

[–] mlg@lemmy.world 3 points 1 year ago* (last edited 1 year ago)

Debian or Fedora

Debian if you want something easy and stable, Fedora if you want latest updates and are comfortable with occasional SELinux settings, TrueNAS if you don't want to spend any time at all setting up disks

Ubuntu if you want infinite dependency hell and 5 minute boot times

[–] d13@programming.dev 3 points 1 year ago

I use Ubuntu with no complaints, but Debian is probably better, like others are saying. I wouldn't use Fedora for this.

[–] warmaster@lemmy.world 3 points 1 year ago

I'm running Fedora Server + Cosmos Cloud. Freaking awesome. Fedora Server comes bundled with Cockpit, which makes admin work much easier, and Cosmos Cloud makes Docker very easy, and automates your security.

[–] diffuselight@lemmy.world 2 points 1 year ago

Been running the docker on unraid for years in a HP slimline. Rock solid.

[–] ErwinLottemann@feddit.de 2 points 1 year ago (1 children)

in the end it doesn't realy matter because you plan on running the services in containers. that beeing said, have you thought about arch?

[–] funkajunk@lemm.ee 3 points 1 year ago

My motto is "Debian for servers, Arch for workstations".

[–] 8tomat8@lemmy.world 2 points 1 year ago* (last edited 1 year ago)

From your list, I would go with Debian. Fedora is amazing but doesn't have LTS, so you'll need to update it manually quite often. You can use a script for automatic updates, but I rarely had it working smoothly. Ubuntu is just a joke with repository hell. I wouldn't recommend it to anyone but grandma or a child for the desktop, because of its simplicity. TrueNAS never tried...🤷

I would also look into Alpine and some Arch-based distros.

And yes, use containers, this will save you time eventually.

The only real requirement you have for the Jellyfin server is ffmpeg... But this thing runs everywhere

[–] 12bitmisfit@sh.itjust.works 2 points 1 year ago (1 children)

Whatever you're most comfortable with. It's a simple enough ask that you can do it in Ubuntu server or Debian quite easily.

I would recommend at least using docker but you don't have to.

Truenas isn't very forgiving with drive configuration. I really like it but it isn't great for randomly adding drives here and there. Unraid might be a better choice for home usage. I have never had good luck with their built in app stuff but I've also never really tried past it not doing what I want.

I run truenas with a ubuntu server vm and docker some stuff in that. I also run proxmox on another server and a dev server running Ubuntu server that I docker things on.

load more comments
view more: next ›