New server for the family, Proxmox or TrueNAS, LXC or Docker?
from RedBauble@sh.itjust.works to selfhosted@lemmy.world on 04 Jun 11:02
https://sh.itjust.works/post/39436160

cross-posted from: sh.itjust.works/post/39436154

Hello everyone, I’m building a new server for the house, it will act as a NAS for everyone and host a few services like paperless, immich, baikal, jellyfin, syncthing probably navidrone, etc. The main reason I’m building a new one is that my current one is a HP prebuilt with a 3rd gen i5 and 8GB ram that is slowly beating the bucket, my 4TB HDD is completely full and there’s no more sata ports nor space in the case.

I am fully psychologically prepared to be 24/7 tech support, but after all I already am, and in this way I have to support services for which I know how they work (and that I trust!) and not some strange Big Tech service whose UI and inner workings changes every other day.

For reference my new build is:

  • CPU: Ryzen 5 PRO 4560G + stock cooler. Has integrated graphics, can use it for Jellyfin transcoding.
  • RAM: Corsair Vengeance 2x8GB (from my desktop before I upgraded to 64GB RAM. If needed in the future I will upgrade the capacity and probably switch to ECC, I’ve chosen the CPU since it has support for it)
  • SSD NVME (boot+VM storage): Verbatim VI3000 512GB
  • Storage (SATA): 4x12TB Seagate Enterprise (White label) to use ZFS and Raid Z1 + 1x512GB Samsung SSD as cache.

I’m planning on using proxmox on bare metal and spin up VM/containers as needed, for which I’m wondering:

  • I know proxmox can manage ZFS arrays, is it better to create the array via proxmox, then share it as needed via something like openmediavault in vm/container OR to create a TrueNAS VM and passthrough the SATA controller to it, then manage everything via TrueNAS? I’ve done the latter in the past on another server, it’s holding strong

  • I don’t know if exposing the server to the open internet is a good idea (of course with fail2ban and a firewall properly configured) or to just keep a VPN connection to the server always open. I think the latter would be more secure, but also less user-friendly for parts of the family. I’m using wireguard currently to remote into my server when needed, and sometimes networks like eduroam in my university block it completely.

    • Self signed SSL certificates might also be a problem in the latter case
  • Since I will experiment with this server a little bit, I was thinking of keeping:

    • One VM for services for the family (exposed to internet or VPN)
    • One VM for services I still want to expose (I currently expose a couple websites for friends with data archived in my NAS)
    • One VM for me to experiment with before going in “production” for the family

Each VM would host its services using Docker+Portainer. My question is: is this too convoluted? Should I just use proxmox’s LXC containers (which I have no experience with) and host services there?

I was also thinking of spinning up a pfsense/opnsense box and put the server into a separate VLAN from the domestic lan. But that will be a project for a second time. Unfortunately the way ethernet is wired in my house and for the physical space I have available prevent me from separating the networks by physically using another router.

Thanks!

#selfhosted

threaded - newest

truthfultemporarily@feddit.org on 04 Jun 11:19 next collapse

TrueNAS will remove VMs the next release. It still supports containers directly.

Edit: apparently I misremembered that and its untrue.

ClydapusGotwald@lemmy.world on 04 Jun 11:36 next collapse

Source?

wolre@lemmy.world on 04 Jun 11:50 next collapse

This is not true, TrueNAS will simply migrate vms to incus, along with also introducing LXC support. https://www.truenas.com/docs/scale/scaletutorials/instances/

rockyracoon@lemmy.world on 04 Jun 13:46 collapse

Do you have a source for that? I can’t find anything related to TrueNAS deprecating VMs.

webghost0101@sopuli.xyz on 04 Jun 11:39 next collapse

Proxmox all the way, cannot recommend it higher. I was very scared to try it in the beginning but its the best server choice i ever made.

You dont need to choose between lxc or docker. You can just run docker in lxc many helper scripts set you up like that by default.

Super technically they dont recommend doing so but i know others who do this and have never encountered a problem with it.

RedBauble@sh.itjust.works on 04 Jun 12:20 collapse

How is that different from a VM and using docker inside it? Any specific advantages/disadvantages to both approaches?

taxon@lemmy.world on 04 Jun 12:33 next collapse

Lower overhead

webghost0101@sopuli.xyz on 04 Jun 13:03 next collapse

What taxon said.

Most of my services have their own lxc with docker.

A few that need it are vms

It works so well i often forget how i set things up because its very leave and forget about it, Keeps working.

Auli@lemmy.ca on 05 Jun 11:47 collapse

So your running one lxc with one docker container in it?

webghost0101@sopuli.xyz on 05 Jun 12:31 collapse

I am running a few lxc which all run a docker container each.

CmdrShepard42@lemm.ee on 04 Jun 17:49 collapse

In Proxmox, LXCs allow you to easily share resources between containers like your iGPU can be shared with your Jellyfin container and a separate Immich container. From my understanding, VMs bind whatever resource to the VM which can’t easily be used with other VMs or containers.

RedBauble@sh.itjust.works on 04 Jun 21:24 collapse

This is really interesting, might be the way to go for me

roofuskit@lemmy.world on 04 Jun 11:49 next collapse

Proxmox is not an alternative to any of those other options.

Edit: to be clear you can use Proxmox AND all of those other options.

WeAreAllOne@lemmy.dbzer0.com on 04 Jun 11:54 next collapse

Have you given Synology any thoughts? It can run containers with bo issues. Regarding streaming media you might get a separate tv box (I use Nvidia tv sheild with lineageos) and you won’t have any transcoding issues!

BestBouclettes@jlai.lu on 04 Jun 11:59 next collapse

I’d not recommend Synology anymore, as they’re starting to implement vendor lock on their drives and NAS boxes. As in, you’ll have to use their drives for the Nas to work.

WeAreAllOne@lemmy.dbzer0.com on 04 Jun 22:00 collapse

I’ve seen this floating around. But is this solid info? I mean, a big percentage of users does not have Synology HDDs, what would happen if they implement this? Maybe this will be the case for business uses of some of their apps?

BestBouclettes@jlai.lu on 05 Jun 06:07 collapse

Yeah, it’s started to roll out on their new hardware:

theverge.com/…/synology-nas-third-party-hard-driv…

RedBauble@sh.itjust.works on 04 Jun 12:18 collapse

No, I wanted something that I could upgrade if I wanted in the future, especially for disks. I still have 4x 3.5’ slots available in the case and as for sata ports on the mobo I can always by a controller to plug in the pcie slots

Vinstaal0@feddit.nl on 04 Jun 11:58 next collapse

The recommended rate for RAM to TB of storage is one, so for every 1TB of data they recommend you need to have 1GB of ram. Not sure how relevant it actually is since I have a lot more ram than storage on the server, but just something to note.

Virtualising ZFS on top of ZFS is generally not supported and can cause issues. I run TrueNas baremetal and run a lot of docker services in TrueNas itself, you can also run VM’s on TrueNas. I know some people virtualise TrueNas in Proxmox, but the only use I see is to host something in a VM on proxmos that you cannot really run inside a TrueNas VM. The thing with TrueNas is that everything is either stored in the datasets or in the config file. The latter can be backupped pretty easily.

I have both a TrueNas server and a Proxmox box with OPnsense running, Proxmox is very nice I just don’t see a reason to run TrueNas inside Proxmox.

Kroxx@lemm.ee on 04 Jun 12:06 next collapse

To expose your services easily and securely look up tailscale it’s completely free and is setup per device, ex download on your moms phone and you can manage that phones access.

Tailscale uses wiregaurd and some weird ass NAT magic to make every device have direct connections to each other creating a “tailnet”

It’s a zero trust architecture so you have to whitelist every device on it. What that means practically is it’s very difficult to compromise and that’s by it’s nature. You don’t have to have a high technical level to be very secure using tailscale.

There is also twingate which I think is similar but I’m not as familiar with twingate

RedBauble@sh.itjust.works on 04 Jun 12:23 collapse

I had thought of that, I didn’t really like the idea of using a third party service to access my machines.

Also I didn’t mention in the post, but, while my ISP gives me a public IP, I only use port forwarding to wireguard into my home networks. My services are exposed via a vps hosted on oracle cloud free tier free, which forwards public traffic to my server via another wireguard connection

brygphilomena@lemmy.dbzer0.com on 04 Jun 13:24 collapse

Headscale is a locally hosted version. You can also just manually do wire guard. But tailscale is just a management tool for setting up an overlay network using wire guard.

Hotrod54chevy@lemmy.ml on 04 Jun 13:43 next collapse

My vote is for Proxmox because you can run all those other options (and many more) INSIDE Proxmox.

ruud@lemmy.world on 04 Jun 13:57 next collapse

I stopped self-hosting stuff that’s for the family. In case something happens to me, no way my wife is going to keep this stuff running. And the kids are too young. So they would lose everything.

Family stuff goes in managed solutions (like Proton). Personal and public stuff is selfhosted.

Just something to consider.

rockyracoon@lemmy.world on 04 Jun 14:20 next collapse

My setup is TrueNAS SCALE on bare metal with VMs for Proxmox and Jellyfin. I pass an Arc A380 to Jellyfin for transcoding and it works great. I also leverage LXC contains a lot for small services. I keep everything behind a VPN. It’s pretty easy to distribute Wireguard configs and import them on most OSes, but It’s been a mixed bag getting family members to use it though.

I’m a fan of having dedicated network hardware and VLANs on one router. I generally go for Mikrotik. I used to run pfsense on a VM and when the server when down so did everything else, which caused the house to erupt into chaos.

Also if you’re considering new hardware already I really recommend looking into surplus enterprise gear. I run my whole lab on an R730XD. It holds a ton of drives, has an IDRAC (I can’t live without it now), ECC for extra peace of mind during ZFS scrubs, and they hold an insane amount of inexpensive RAM. They’re fairly cheap on eBay or from refurbishment companies. Bring your own drives with warranties though, used drives are a headache. Servers like this can be really noisy though, I keep mine in the basement.

I’ll also suggest a second drive to mirror your boot drive. You can and should back up your configs but a mirror saves headache and down time if the boot ssd fails. Probably even more important if you’re planning on using this pool for VM storage.

Have fun! 😁

spiffpitt@lemmy.world on 04 Jun 14:49 next collapse

what do you use your virtualized proxmox for?

rockyracoon@lemmy.world on 05 Jun 02:07 collapse

Pretty much everything else virtualization. I have a few small LXC containers running Ad Guard and Unifi Controller, and VMs for a gitlab instance, gitlab runner, and some game servers. I could host all that in TrueNAS directly but I like proxmox’s UI.

RedBauble@sh.itjust.works on 04 Jun 21:27 collapse

Also if you’re considering new hardware already I really recommend looking into surplus enterprise gear. I run my whole lab on an R730XD. It holds a ton of drives, has an IDRAC (I can’t live without it now), ECC for extra peace of mind during ZFS scrubs, and they hold an insane amount of inexpensive RAM. They’re fairly cheap on eBay or from refurbishment companies. Bring your own drives with warranties though, used drives are a headache. Servers like this can be really noisy though, I keep mine in the basement.

I’ve briefly considered it but it is out of the question for me. Not enough space in the house and enterprise gear is way too noisy. This setup will probably sit next to the TV in the living room so it has to be as silent as possible.

rockyracoon@lemmy.world on 05 Jun 02:08 collapse

Oh ya makes sense. Anything in a rack form factor would be much too loud to live with. I think in that case you’ve made great choices in hardware!

JMorningstar@lemmy.world on 04 Jun 14:51 next collapse

Might want to check out unraid.

koala@programming.dev on 04 Jun 15:26 next collapse

IMHO, it really depends on the specific services you want to run. I guess you are most familiar with Docker and everything that you want to run has a first-class-citizen Docker container for it. It also depends on whether the services you want to run are suitable for Internet exposure or not (and how comfortable you are with the convenience tradeoff).

LXC is very different. Although you can run Docker nested within LXC, you gotta be careful because IIRC, there are setups that used to not work so well (maybe it works better now, but Docker nested within LXC on a ZFS file system used to be a problem).

I like that Proxmox + LXC + ZFS means that it’s all ZFS file systems, which gives you a ton of flexibility; if you have VMs and volumes, you need to assign sizes to them, resize if needed, etc.; with ZFS file systems you can set quotas, but changing them is much less fuss. But that would likely require much more effort for you. This is what I use, but I think it’s not for everyone.

Vendetta9076@sh.itjust.works on 04 Jun 16:51 next collapse

Hey breh. My setup us bare metal proxmox, a truenas VM and a couple Debian LXCs. Main LXC is running docker just fine with zero issues.

I’d honestly suggest skipping the truenas VM and just managing your disks in proxmox but my setup has been holding steady for about 5 years now.

Definitely don’t have to choose between lxc or docker.

SidewaysHighways@lemmy.world on 04 Jun 16:57 collapse

this is me. i originally had truenas core on bare metal but wanted to be able to do more, so truenas is a vm running the same exact pools as before.

proxmox is so goddamn slick!

lxcs for docker compose stacks,

another proxmox setup with backup truenas, rsync weekly!

lka1988@lemmy.dbzer0.com on 04 Jun 23:50 collapse

Why are we running Docker inside LXC? That’s not a wise decision, and is specifically stated as a big “no-no” by both Docker and Proxmox devs.

VMs don’t use as much resources as you realize. I’ve got multiple VMs full of Docker stacks (along with other VMs running various game servers, and several LXCs for various “not set up for Docker” services) spread across three i7-7700T servers; none of them are even close to being taxed.

non_burglar@lemmy.world on 04 Jun 17:31 next collapse

I used to run proxmox, but I wasn’t using most of its functions. I now have migrated to a couple of low power Debian machines on zfs with lxc. I use incus and ansible to manage everything, including backups.

Cyber@feddit.uk on 04 Jun 20:26 collapse

Aha! I was considering moving from proxmox to incus too, but incus seemed quite new and not much documentation (at the time)

How do you find it now?

non_burglar@lemmy.world on 05 Jun 13:36 collapse

Really great. Passing through hardware is a lot easier, settings can be defined in profiles (containers that should start with boot, which should have uid/gid mapping, privileged, etc), and overall system memory usage is way lower.

Cyber@feddit.uk on 05 Jun 21:37 collapse

Nice. I’ll go that way when I next brave the dust and cobwebs where the server’s currently located

non_burglar@lemmy.world on 05 Jun 22:29 collapse

It is a bit of a different approach than proxmox, but well worth the small learning curve.

WhyJiffie@sh.itjust.works on 04 Jun 18:50 next collapse

I run proxmox, and proxmox manages the zfs pool, there are VMs for important and convenience services, where important only hold things needed for the machine to work (so networking related) and metrics. I also have a desktop VM for the occasional use, and you can install opnsense later if you want an advanced firewall for VLANs and maybe internet too.
the storage is made accessible through virtiofs shares, but setup is quite hacky, and some things don’t like it (like it can’t store any kind of databases) because virtiofs works technically like a network filesystem, and does not support some consistency features (yet?). maybe ceph would be a solution, it is natively supported by proxmox.

if I were to build a new one, I would try out TrueNAS, it’s newer linux based version. I heard that can run VMs too if needed. I suspect that it can be more user friendly, but I haven’t used its web interface yet ever.

WhyJiffie@sh.itjust.works on 04 Jun 22:10 collapse

I have good news. I have just read the Proxmox 8.4 changelog, and they added support for using virtiofs with VMs, so now using it does not seem to require hacks anymore! But the limitation with databases probably still applies.

@RedBauble@sh.itjust.works unsure if you have read it already so tagging.

nomade420@lemm.ee on 04 Jun 19:47 next collapse

I know that it’s a different options from what OP wanted. But I’ve had the same battle in my mind, ended up with Fedora Server.

lka1988@lemmy.dbzer0.com on 04 Jun 23:43 next collapse

Proxmox w/VMs for Docker, per your original plan (don’t use Portainer, use “Dockge” instead). You can also use small LXCs for services that aren’t set up for Docker, and Proxmox offers turnkey LXC images to make it that much easier.

01189998819991197253@infosec.pub on 06 Jun 01:32 collapse

If all you’re building, and all you’ll ever use this for, is a NAS, the simplest route is TrueNAS.

Personally, I am not a fan of docker for prod, as one bad update or config can bring the entire forest down. Same for LXC.

If you want, plan, or think you might want, to use the baremetal host for other services, proxmox is the way to go. Think VMware, but not run by a greedy evil empire. With your planned hardware, you can run two full services comfortably, or up to 4 mini services. Increase ram to 32gb, and you open up your world to a some really cool possibilities.

Again, it all depends with where you want to go, not just where you are now.