I recently became interessted in learning about static site generators. So I decided to start a little 11ty blog, in which I teach people, who are new to self-hosting, how to securely set up their own server with Ubuntu and Docker.

For now, I’ve got my Beginners Guide series as well as a more detailed introduction to SSH and its features. I plan to eventually write down all I’ve learned about self-hosting in the past 20 years.

Hope it ends up being helpful for some of you.

  • Vegafjord eo@lemmy.ml
    link
    fedilink
    English
    arrow-up
    3
    ·
    2 days ago

    I have wanted to self host ever since I joined the fediverse 5 years ago. Always ends up with one or another error message that I cant get through. But I might give this a chance.

    One thing I wish I knew earlier is the “man” command to display the documentation of a command.

  • sonofearth@lemmy.world
    link
    fedilink
    English
    arrow-up
    5
    arrow-down
    1
    ·
    2 days ago

    freeing yourself from your dependance on big corporations

    Setting up a VPS with Ubuntu Server

    This shouldn’t exist in the same article lol. You will just end up paying in subscriptions anyways while at the same time maintaining all the stacks — that too on Ubuntu where some articles will become useless after a few updates. Even 10$ a month will result in $120 every year — which can buy you a half decent second hand PC or a new Mini PC. You won’t even own your data when you rent a VPS.

    You will end up saving a lot more by self hosting on your own hardware with vanilla Debian and be more independent at the same time. You will only need a VPS if you want to self-host your own reverse tunnel like Pangolin or FRP.

    • gibdos@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      5
      arrow-down
      2
      ·
      2 days ago

      The amount of baseless Ubuntu Server hate in this sub is pretty sad. I’ve used Ubuntu Server, without any problems, for more than a decade. And at no point where there any significant changes to the way things are done. So I really think your comment about articles becoming useless has no basis in reality.

      As for using your own hardware. Nothing in this guide necessarily requires a VPS. And you seem to completely ignore the upkeep and electricity costs of having your own hardware at home.

      Not to mention the convenience of a public IP, which is something not every ISP around the world offers. And yes, you can use a dynamic DNS provider to get around that, but then you publish your private IP onto the entire internet.

      The guide was focused on being as simple and convenient as possible, with the target audience being absolute beginners to self-hosting. If it doesn’t speak to you, feel free to write your own.

      • sonofearth@lemmy.world
        link
        fedilink
        English
        arrow-up
        2
        ·
        2 days ago

        I’ve used Ubuntu Server, without any problems

        If it works for you then great. But it doesn’t stand with your goal of Corporate Independence and Willingness to Learn — Given that it is slightly easier to setup than Vanilla Debian. But at the end of the day it is just Corporate Debian with more up-to date packages but overall less stable than Vanilla Debian.

        upkeep and electricity costs of having your own hardware at home

        It really won’t be much unless you’re gonna go for extremely beefy hardware like for Jellyfin hosting hundreds of newer codec 4k files with HDR and shit with dozens of users or some LLM — which anyways still would be cheaper than renting a VPS. Otherwise even a Raspberry Pi can do a decent job or even a mini pc (with something like Intel N100) which draws less power than a Mobile Phone charger. It also aligns with the idea of beginner friendly setup than using a VPS which half the people will even skip reading the Terms & Conditions and Privacy Policies. So hosting something like Immich or Nextcloud, which is not encrypted at rest, is pretty much available for the VPS provider at instant.

        convenience of a public IP

        You don’t need a public IP to self-host. A beginner should start with private at first, learn from there and gain and grow otherwise it can lead to security risks — e.g you have mentioned to self-host Immich which doesn’t have any native 2FA. The self-hoster then will have to know about SSO based logins to secure instances like these.

        use a dynamic DNS provider to get around

        You also have Cloudflare Tunnel, Tailscale. Or you can use a 5$/month VPS in this instance to self-host Pangolin with Crowdsec for public access and block malicious or suspicious IPs. All of these options will mask your real public IP.

        The guide was focused on being as simple and convenient as possible, with the target audience being absolute beginners

        Ok but this asks for a lot of upfront investment. You don’t need to buy a domain or a VPS as a beginner (or even a mini PC as I mentioned). Just start with a PC or a Laptop you already own. Host the service and access it via private IPs instead of handholding them to copy and paste commands, configs and compose files from the internet (although you do have mentioned official documentation so kudos for that) just for the convenience of public access. A lot of people don’t know the 3-2-1 backup rule. One error might wipe off their entire Immich Library, Password Vaults or important documents in Nextcloud.

  • nupo@quokk.au
    link
    fedilink
    English
    arrow-up
    59
    arrow-down
    1
    ·
    3 days ago

    Personally I strongly recommend Debian over Ubuntu.

    • DaTingGoBrrr@lemmy.world
      link
      fedilink
      English
      arrow-up
      8
      ·
      3 days ago

      Personally I would recommend Proxmox. It’s a debian based distro for hosting containers and virtual machines

      • madjo@feddit.nl
        link
        fedilink
        English
        arrow-up
        2
        ·
        2 days ago

        +1 for ProxMox.

        I have that running and it’s pretty easy to work with

        • DaTingGoBrrr@lemmy.world
          link
          fedilink
          English
          arrow-up
          3
          ·
          2 days ago

          Yes, as I said it’s a debian base. But Proxmox is built for servers and using it to host and share containers or virtual machines is super simple. Especially with the community helper scripts that can set up different self-hosting projects within minutes with minimal tinkering.

    • sem@lemmy.blahaj.zone
      link
      fedilink
      English
      arrow-up
      9
      arrow-down
      1
      ·
      3 days ago

      Why is that, if I may ask? I’ve used both for years and personally I find Ubuntu has fewer footguns for a new user, and an easisr upgrade process.

      • nupo@quokk.au
        link
        fedilink
        English
        arrow-up
        18
        arrow-down
        1
        ·
        3 days ago

        I prefer Debian’s community-driven governance model, the higher degree of freedom over the system and lack of preinstalled software that I neither need nor want, and the quiet stability that Debian offers.

        I also have just not liked Ubuntu’s decisions over the years. Little things that piled up like the Unity stuff a few years back (or I guess almost a decade at this point), the forced inclusion of snapd, that time they said they wouldn’t offer 32-bit libraries, the little message advertising Ubuntu Pro in the shell.

        I’ve always felt like Debian is happy to just get out of the way and let you use it how you want to use it. That control is what I look for in a distro. What you call “footguns” are to me just more options for control.

        • sem@lemmy.blahaj.zone
          link
          fedilink
          English
          arrow-up
          2
          ·
          2 days ago

          For me the footguns in debian have been an unintuitive upgrade process that lets you break things, and configurations/software that don’t work well out of the box without user knowledge and intervention. But for my server, Debian has been very nice and lightweight.

          Even though Ubuntu is not always pure good the way that Debian is (remember when they had Amazon advertisements and search integrated into the desktop), and minor annoyances like the apt advert are annoying, but they offer an amount of stability and ease of use that I think earns the nickname “preconfigured Debian”

          • shrugs@lemmy.world
            link
            fedilink
            English
            arrow-up
            1
            ·
            edit-2
            6 hours ago

            I call bullshit. Debian stable just works, Ubuntu LTS releases use netplan instead of ifconfig, send your searches to Amazon, show advertising in the shell and push snaps down my throat. I used Ubuntu from 6.06 up until 10.04. Debian is just better with less corporate profit bogaloo

      • non_burglar@lemmy.world
        link
        fedilink
        English
        arrow-up
        3
        ·
        3 days ago

        Debian’s footguns are better documented and are generally there for good reason. Ubuntu’s footguns are there because “fuck the user”.

      • dalekcaan@feddit.nl
        link
        fedilink
        English
        arrow-up
        3
        arrow-down
        2
        ·
        3 days ago

        Yeah, I don’t know anything about self-hosting, but I’ve recently been working on switching from Windows 10 to Linux and I’ve been really enjoying Kubuntu so far.

    • gibdos@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      2
      arrow-down
      1
      ·
      3 days ago

      Whille I agree, when it comes to the Ubuntu Desktop, their Server OS has been a stable, reliable and well supported system for me.

  • mlg@lemmy.world
    link
    fedilink
    English
    arrow-up
    8
    arrow-down
    1
    ·
    3 days ago

    Ubuntu and Docker.

    Really? Netplan alone disqualifies Ubuntu as a “friendly stable starter distro”, and I can guarantee you that your guide will somehow become outdated with a single new Ubuntu release, or some poor soul who accidentally selected an LTS release.

    Docker doesn’t matter as much, but there’s a reason beyond just FOSS licensing why podman exists.

    Would highly recommend Debian instead.

    I started on Ubuntu similar to this many years ago and both the server and desktop experience was not fun at all.

    • InFerNo@lemmy.ml
      link
      fedilink
      English
      arrow-up
      5
      ·
      3 days ago

      As someone who manages a mail server, new debian releases have the same effect.

      If you want to avoid this, use a rolling release distro.

      • Appoxo@lemmy.dbzer0.com
        link
        fedilink
        English
        arrow-up
        3
        arrow-down
        1
        ·
        edit-2
        2 days ago

        Netplan alone disqualifies Ubuntu as a “friendly stable starter distro”

        OP didnt mention anything about stability. Just ease of use.

        • Zeoic@lemmy.world
          link
          fedilink
          English
          arrow-up
          1
          arrow-down
          1
          ·
          2 days ago

          Whats wrong with netplan? Has worked great in my experience.

          Neither did I? Yaml defined networking is incredibly easy to use.

          • Appoxo@lemmy.dbzer0.com
            link
            fedilink
            English
            arrow-up
            3
            arrow-down
            1
            ·
            2 days ago

            Has worked great in my experience.

            I read your comment as implication as either hard to use or unstable.

            • Zeoic@lemmy.world
              link
              fedilink
              English
              arrow-up
              1
              ·
              2 days ago

              Honestly, I’m not sure how you get “hard to use” from “worked great”

    • gibdos@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      3
      ·
      3 days ago

      I think you are conflating desktop Ubuntu with Ubuntu Server. On a server, you absolutly want a stable, long supported LTS version.

      I’ve been hosting on Ubuntu Server for over 10 years now, and at no point were any packages required to keep it up to date and running outdated.

        • gibdos@lemmy.worldOP
          link
          fedilink
          English
          arrow-up
          2
          ·
          edit-2
          3 days ago

          You mean from one LTS to the next? It’s been a while, but as far as I remember, it worked fine on my last server (22.04 to 24.04).

          And even if something doesn’t work, I can have all my stuff spun up on a new server in less than an hour. But that, of course, depends on the amount of data you host.

    • Matt The Horwood@lemmy.horwood.cloud
      link
      fedilink
      English
      arrow-up
      2
      ·
      3 days ago

      That makes me very odd, I started with mandrake. Got very frustrated with the hand holding and moved to Debian, I’m not touching Ubuntu with a 10 foot clown pole.

      Who in their right mind uses yaml for network config?

    • Possibly linux@lemmy.zip
      link
      fedilink
      English
      arrow-up
      2
      arrow-down
      1
      ·
      3 days ago

      I’d say that docker is still more user friendly than podman

      In the future that may change but right now podman is still green

    • gibdos@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      5
      ·
      3 days ago

      Thanks, glad you liked it.

      Yeah, I know that the images are borked. But it’s pretty late here and I was too lazy to fix it. I’ll fix it tomorrow.

      • ki9@lemmy.gf4.pw
        link
        fedilink
        English
        arrow-up
        1
        ·
        3 days ago

        You should check out the official 11ty images plugin if you haven’t already. Itll generate multiple sizes for your output. Its the best feature imo.

        • gibdos@lemmy.worldOP
          link
          fedilink
          English
          arrow-up
          1
          ·
          3 days ago

          Took me an embarrassing amount of time to realize my mistake. I forgot to actually use the npx @11ty/eleventy build command instead of always relying on npx @11ty/eleventy --serve. Now the images are properly linked and transformed / optimized.

  • lando55@lemmy.zip
    link
    fedilink
    English
    arrow-up
    7
    arrow-down
    4
    ·
    3 days ago

    I wrestled with whether or not I should be that guy, but self-hosting by definition generally means everything down to the bare metal, i.e. not a VPS.

    I can understand how the term could apply to the broader definition of running your own services on managed infrastructure, but it seems odd not to make that distinction in a beginners guide.

    • exu@feditown.com
      link
      fedilink
      English
      arrow-up
      6
      arrow-down
      1
      ·
      3 days ago

      Making the term self hosting exclusive to running stuff at home feels unnecessarily elitist. Not everyone has the space, bandwidth or family approval to run stuff at home.
      You can have the term homelab if you want

      • Two9A@lemmy.world
        link
        fedilink
        English
        arrow-up
        3
        ·
        3 days ago

        Right, I self-host email and have done for ten years or more, but I don’t do it out of a server at home. Does my Postfix not count as selfhosting any more?

        • shiftymccool@programming.dev
          link
          fedilink
          English
          arrow-up
          4
          ·
          3 days ago

          Hmmm, definitely a grey area in my mind especially with the definition of “host”. The host is where the software lives and that isn’t yours. Maybe self-managed?

      • lando55@lemmy.zip
        link
        fedilink
        English
        arrow-up
        2
        ·
        3 days ago

        I’m ambivalent as to who uses the term and how, but a deviation from the general consensus of its definition might cause confusion for newcomers to the field who can’t make the distinction. That said, I enjoyed OPs post and appreciate the time they put into it.

        Homelab on the other hand is not synonymous with self-hosted infrastructure and services, as its intended use is not for production workloads.

    • gibdos@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      5
      ·
      3 days ago

      I see your point. But to me, self-hosting just means being responsible for the server and services and not necessarily having my own hardware server at home. And just calling it hosting is too broad a definition for me. And at the end of the day, the guide works just as well for your own hardware or a VM, as it does for a VPS.

  • kif@lemmy.nz
    link
    fedilink
    English
    arrow-up
    2
    ·
    3 days ago

    Hell yeah. Looking forward to more to pass on to future self-hosters!

  • monogram@feddit.nl
    link
    fedilink
    English
    arrow-up
    3
    arrow-down
    9
    ·
    2 days ago

    Hahahaha what a joke!!

    Talks about Selfhosting - Run blog on Netlify aka AWS SaaS

    Practice what you preach.

    • gibdos@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      2
      ·
      2 days ago

      Thank you for your very helpful and friendly criticism. I temporarily used Netlify, because I haven’t gotten around to program a proper deploy script for my Forgejo git repo.

      • monogram@feddit.nl
        link
        fedilink
        English
        arrow-up
        2
        arrow-down
        3
        ·
        2 days ago

        You could just rsync it over and let apache/caddy/nginx handle it. We developers make everything complicated before it’s necessary.

        What was your thought process on publishing a blog post abut local hosting on your aws website? 🤡

        Practice what you preach.

  • dis_honestfamiliar@lemmy.sdf.org
    link
    fedilink
    English
    arrow-up
    2
    ·
    3 days ago

    This 11ty sounds like a nice off the shelf solution to getting a blog started, which I want to do, but how to allow comments? I guess I’m asking what’s everyone around here solution for comments

      • dis_honestfamiliar@lemmy.sdf.org
        link
        fedilink
        English
        arrow-up
        2
        ·
        1 day ago

        I think I want to do a coding / dev blog and hope that some comments help me explore other ways to write code that’s why I’m thinking of allowing comments. Thoughts on this? Also, discus might work. Thank!

    • gibdos@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      2
      ·
      3 days ago

      Can’t really help you there, since comments were never a consideration for me. They would add an unneeded amount of moderation, and potential threat, to my blog.

      • dis_honestfamiliar@lemmy.sdf.org
        link
        fedilink
        English
        arrow-up
        1
        ·
        1 day ago

        I think I want to do a coding / dev blog and hope that some comments help me explore other ways to write code that’s why I’m thinking of allowing comments. Thoughts?

    • gibdos@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      3 days ago

      Yeah, took me a while to get the hang with Nunjucks, which I had never heard of or used before. But once I got it all properly set up, it was super simple and easy. I’ll definetly write a guide to it too, eventually.

  • foggy@lemmy.world
    link
    fedilink
    English
    arrow-up
    2
    ·
    3 days ago

    For getting your stuff available over the internet, y I recommend a secure tunnel with wire guard between your vps and servers running the services.

    Make your vps an authentication portal using stuff like Authelia and Fail2ban.

    If you’re really needing out, get ELK stood up for free and get agents on your containers/services to keep visibility into any potential… Anything

    • gibdos@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      3 days ago

      I’ve personally never found the need to do that. If you follow basic security guidelines and keep your server os and the docker service up-to-date, there really isn’t any real threat.

      Though I have heard of Authelia before and was interested in reading up on SSO, one of these days.