• Jeena@piefed.jeena.net
    link
    fedilink
    English
    arrow-up
    61
    ·
    5 months ago

    I wanted to ask where the border of selfhosting is. Do I need to have the storage and computing at home?

    Is a cheap VPS on hetzner where I installed python, PieFed and it’s Postgres database but also nginx and letsencrpt manually by mydelf and pointed my domain to it, selfhosting?

    • smiletolerantly@awful.systems
      link
      fedilink
      English
      arrow-up
      72
      ·
      5 months ago

      I would say yes, it’s still self-hosting. It’s probably not “home labbing”, but it’s still you responsible for all the services you host yourself, it’s just the hardware which is managed by someone else.

      Also don’t let people discourage you from doing bare-metal.

      • Stefen Auris@pawb.social
        link
        fedilink
        English
        arrow-up
        12
        ·
        5 months ago

        That’s actually a good point, self hosting and home lab are similar things but don’t necessarily mean the same thing

      • grrgyle@slrpnk.net
        link
        fedilink
        English
        arrow-up
        3
        ·
        5 months ago

        Interesting distinction. I use a small managed vps, but didn’t consider that self-hosting, personally. I do aspire to switch to a homelab and figure out dynamic DNS and all that one day.

    • tripflag@lemmy.world
      link
      fedilink
      English
      arrow-up
      19
      ·
      edit-2
      5 months ago

      It depends who you ask (which we can already tell hehe), but I’d say YES, because you’re the one running the show – you’re free to grab all of your bits and pieces at any time, and move to a different provider. That flexibility of not being locked into one specific cloud service (which can suddenly take a bad turn) is what’s precious to me.

      And on a related note, I also make sure that this applies to my software-stack too – I’m not running anything that would be annoying to swap out if it turns bad.

    • Xanza@lemm.ee
      link
      fedilink
      English
      arrow-up
      11
      ·
      5 months ago

      I would say there’s no value in assigning such a tight definition on self-hosting–in saying that you must use your own hardware and have it on premise.

      I would define selfhost as setting up software/hardware to work for you, when turn-key solutions exist because of one reason or another.

      Netflix exists. But we selfhost Jellyfin. Doesn’t matter if its not on our hardware or not. What matters is that we’re not using Netflix.

    • irmadlad@lemmy.world
      link
      fedilink
      English
      arrow-up
      5
      ·
      5 months ago

      Is a cheap VPS on hetzner where I installed python, PieFed and it’s Postgres database but also nginx and letsencrpt manually by mydelf and pointed my domain to it, selfhosting?

      I don’t get hung up on the definitions and labels. I run a hybrid of 3 vps and one rack in the closet. I’m totally fine with you thinking that is not selfhosting or homelabbing. LOL I have a ton of fun doing it, and that’s the main reason why I do it; to learn and have fun. It’s like producing music, or creating bonsai, or any of the other many hobbies I have.

    • Luffy@lemmy.ml
      link
      fedilink
      English
      arrow-up
      5
      ·
      5 months ago

      Self hosting just means maintaining your own Instance of a web service instead of paying for someone else‘s

      As long as you dont pay hetzner for an explicit fully maintained Nextcloud server, it dosent matter if the OS you‘re running it on is a VM or a bare bones server

    • Avid Amoeba@lemmy.ca
      link
      fedilink
      English
      arrow-up
      2
      ·
      5 months ago

      I’d say you need storage. Once you get storage, use cases start popping up into view over time.

    • hperrin@lemmy.ca
      link
      fedilink
      English
      arrow-up
      7
      arrow-down
      6
      ·
      5 months ago

      Your stuff is still in the cloud, so I would say no. It’s better than using the big tech products, but I wouldn’t say it’s fully “self hosted”. Not that that really makes much of a difference. You’re still pretty much in control of everything, so you should be fine.

      • Jeena@piefed.jeena.net
        link
        fedilink
        English
        arrow-up
        8
        ·
        5 months ago

        Where is the tipping point though? If I have a server at my parents house, they live in Germany and I in Korea, does my dad host it then because he is paying for the electricity and the access to the internet and makes sure those things work?

        • hperrin@lemmy.ca
          link
          fedilink
          English
          arrow-up
          7
          arrow-down
          3
          ·
          5 months ago

          Your parents’ house isn’t the cloud, so yeah, it’s self hosted. The “tipping point” is whether you’re using a hosting provider.

          • smiletolerantly@awful.systems
            link
            fedilink
            English
            arrow-up
            10
            ·
            5 months ago

            They are using a hosting provider - their dad.

            “The cloud” is also just a bunch of machines in a basement. Lots of machines in lots of “basements”, but still.

            • Midnight Wolf@lemmy.world
              link
              fedilink
              English
              arrow-up
              3
              ·
              edit-2
              5 months ago

              “hosting provider” in this instance I think means “do you pay them (whoever has the hardware in their possession) a monthly/quarterly/yearly fee”

              otherwise you can also say “well ACTUALLY your isp is providing the ability to host on the wan so they are the real hosting provider” and such…

            • hperrin@lemmy.ca
              link
              fedilink
              English
              arrow-up
              3
              arrow-down
              1
              ·
              5 months ago

              Their dad is not a hosting provider. I mean, maybe he is, but that would be really weird.

          • Jeena@piefed.jeena.net
            link
            fedilink
            English
            arrow-up
            6
            ·
            5 months ago

            Isn’t my dad the hosting provider? I ordered the hardware, he connected it to his switch and his electricity and pressed the button to start it the first time. From there on I logged in to his VPN and set up the server like I would at Hetzner.

            But you’re right it doesn’t really make a difference. I feel the only difference it makes for me where I post my questions on Lemmy if it is in a !selfhosting community or a !linux community.

            From a feeling perspective, even if I use Hetzners cloud, I feel I self host my single user PieFed instance (and matrix, my other websites, mastodon, etc.) because I have to preform basically the same steps as for things I’m really hosting at home like open-webui, immich, peertube.

            • hperrin@lemmy.ca
              link
              fedilink
              English
              arrow-up
              2
              arrow-down
              2
              ·
              5 months ago

              A hosting provider is a business. If your dad is a business and you are buying hosting services from him, then yes, he is a hosting provider and you are not self hosting. But that’s not what you’re doing. You’re hosting on your own hardware on your family’s internet. That’s self hosting.

              When you host on Hetzner, you’re hosting on their hardware using their internet. That’s not self hosting. It’s similar, cause like you said, you have to do a lot of the same administration work, but it’s not self hosting.

              Where it gets a little murky is rack space providers. Then you’re hosting on your own hardware, but it’s not your own internet, and there’s staff there to help you… kinda iffy whether you’re self hosting, but I’d say yeah, since you own the hardware.

    • ifmu@lemmy.world
      link
      fedilink
      English
      arrow-up
      4
      arrow-down
      4
      ·
      5 months ago

      Personally, I’d say no. At that point you are administering it, not hosting it yourself.

    • Possibly linux@lemmy.zip
      link
      fedilink
      English
      arrow-up
      5
      arrow-down
      6
      ·
      edit-2
      5 months ago

      Why wouldn’t you just use Docker or Podman

      Manually installing stuff is actually harder in a lot of cases

      • smiletolerantly@awful.systems
        link
        fedilink
        English
        arrow-up
        12
        ·
        5 months ago

        Yeah why wouldn’t you want to know how things work!

        I obviously don’t know you, but to me it seems that a majority of Docker users know how to spin up a container, but have zero knowledge of how to fix issues within their containers, or to create their own for their custom needs.

        • FlexibleToast@lemmy.world
          link
          fedilink
          English
          arrow-up
          10
          ·
          5 months ago

          That’s half the point of the container… You let an expert set it up so you don’t have to know it on that level. You can manage fast more containers this way.

          • smiletolerantly@awful.systems
            link
            fedilink
            English
            arrow-up
            8
            ·
            5 months ago

            OK, but I’d rather be the expert.

            And I have no troubling spinning up new services, fast. Currently sitting at around ~30 Internet-facing services, 0 docker containers, and reproducing those installs from scratch + restoring backups would be a single command plus waiting 5 minutes.

            • Midnight Wolf@lemmy.world
              link
              fedilink
              English
              arrow-up
              6
              ·
              5 months ago

              I’d rather be the expert

              Fair, but others, unless they are getting paid for it, just want their shit to work. Same as people who take their cars to a mechanic instead of wrenching on it themselves, or calling a handyman when stuff breaks at home. There’s nothing wrong with that.

              • FlexibleToast@lemmy.world
                link
                fedilink
                English
                arrow-up
                4
                ·
                5 months ago

                I literally get paid to do this type of work and there is no way for me to be an expert in all the services that our platform runs. Again, that’s kind of the point. Let the person who writes the container be the expert. I’ll provide the platform, the maintenance, upgrades, etc… the developer can provide the expertise in their app.

                • notfromhere@lemmy.ml
                  link
                  fedilink
                  English
                  arrow-up
                  2
                  ·
                  5 months ago

                  A lot of times it is necessary to build the container oneself, e.g., to fix a bug, satisfy a security requirement, or because the container as-built just isn’t compatible with the environment. So in that case would you contract an expert to rebuild it, host it on a VM, look for a different solution, or something else?

                  • WhyJiffie@sh.itjust.works
                    link
                    fedilink
                    English
                    arrow-up
                    2
                    ·
                    5 months ago

                    It’s not like it’s so hard to rebuild a container for the occasional services that needs it. but it’s still much better than needing to do it with every single service

                  • FlexibleToast@lemmy.world
                    link
                    fedilink
                    English
                    arrow-up
                    1
                    ·
                    5 months ago

                    Containerfiles are super easy to write. For the most part if you can do it in a VM, you can do it in a container. This sort of thing is why you would move to containers. Instead of being the “expert” in all the apps you run, you can focus on the things that actually need your attention.

            • notfromhere@lemmy.ml
              link
              fedilink
              English
              arrow-up
              1
              ·
              edit-2
              5 months ago

              reproducing those installs from scratch + restoring backups would be a single command plus waiting 5 minutes.

              Is that with Ansible or your own tooling or something else?

                • notfromhere@lemmy.ml
                  link
                  fedilink
                  English
                  arrow-up
                  1
                  ·
                  5 months ago

                  I’ve been wanting to tinker with NixOS. I’ve stuck in the stone ages automating VM deployments on my Proxmox cluster using ansible. One line and about 30 minutes (cuda install is a beast) to build a reproducible VM running llama.cpp with llama-swap.

                  • smiletolerantly@awful.systems
                    link
                    fedilink
                    English
                    arrow-up
                    2
                    ·
                    5 months ago

                    Nice. My partner has a Proxmox setup, so we’ve adapted the Nix config to spin up new VMs of any machine with a single command.

            • FlexibleToast@lemmy.world
              link
              fedilink
              English
              arrow-up
              1
              arrow-down
              7
              ·
              5 months ago

              30, that’s cute. I currently have 70 containers running on my home server. That doesn’t include any lab I run or the stuff I use at work. Containers make life much easier. I also guarantee you don’t know those apps as well as you think you do either. Just being able to install and configure something doesn’t mean you know the inner workings of them. I used to do the same thing you do. Eventually, I would rather spend my time doing other things or learning certain things more in-depth and be okay with a working knowledge of others. It can be fun and rewarding to do things the hard way but don’t kid yourself and think you’re somehow superior for doing it that way.

              • smiletolerantly@awful.systems
                link
                fedilink
                English
                arrow-up
                6
                arrow-down
                1
                ·
                5 months ago

                Containers != services.

                I don’t think I am better than anyone. I jumped into these comments because docker was pushed as superior, unprompted.

                Installing and configuring does not an expert make, agreed; but that’s not what I said.

                I would say I’m pretty knowledgeable about the things I host though, seeing as I am a contributor and / or package maintainer for a number of them…

                • FlexibleToast@lemmy.world
                  link
                  fedilink
                  English
                  arrow-up
                  2
                  arrow-down
                  3
                  ·
                  5 months ago

                  Correct, not all containers are for services. I would never say that docker is superior. I would however say that containers are (I can be pedantic too). They’re version-controlled, they come with the correct dependencies, etc… There are many reasons why developing with containers is superior and I’m sure you’re aware of them already. Everyone is moving to do exactly that. There are always edge cases, but those are few and far between these days.

        • walden@sub.wetshaving.social
          link
          fedilink
          English
          arrow-up
          4
          arrow-down
          1
          ·
          5 months ago

          I use apps on my phone, but have no clue how to troubleshoot them. I have programs on my computer that I hardly know how to use, let alone know the inner workings of. How is running things in Docker any different? Why put down people who have an interest in running things themselves?

          I know you’re just trying to answer the above question of “why do it the hard way”, but it struck me as a little condescending. Sorry if I’m reading too much into it!

          • smiletolerantly@awful.systems
            link
            fedilink
            English
            arrow-up
            7
            ·
            5 months ago

            No, I actually think that is a good analogy. If you just want to have something up and running and use it, that’s obviously totally fine and valid, and a good use-case of Docker.

            What I take issue with is the attitude which the person I replied to exhibits, the “why would anyone not use docker”.

            I find that to be a very weird reaction to people doing bare metal. But also I am biased. ~30 Internet facing services, 0 docker in use 😄

            • MXX53@programming.dev
              link
              fedilink
              English
              arrow-up
              2
              ·
              5 months ago

              This is interesting to me. I run all of my services, custom and otherwise, in docker. For my day job, I am the sole maintainer of all of our docker environment and I build and deploy internal applications to custom docker containers and maintain all of the network routing and server architecture. After years of hosting on bare metal, I don’t know if I could go back to the occasional dependency hell that is hosting a ton of apps at the same time. It is just too nice not having to think about what version of X software I am on and to make sure there isn’t incompatibility. Just managing a CI/CD workflow on bare metal makes me shudder.

              Not to say that either way is wrong, if it works it works imo. But, it is just a viewpoint that counters my own biases.

              • smiletolerantly@awful.systems
                link
                fedilink
                English
                arrow-up
                2
                ·
                5 months ago

                Sorry, I should have mentioned: liking bare-metal does not mean disliking abstraction.

                I would absolutely go insane if I had to go back to installing and managing each and every services in their preferred way/config file/config language, and to diy backup solutions, and so on.

                I’m currently managing all of that through a single nix config, which doesn’t only take care of 90% of the overhead, it also contains all config in a single, self-documenting, language.

        • Possibly linux@lemmy.zip
          link
          fedilink
          English
          arrow-up
          2
          ·
          edit-2
          5 months ago

          You can customize or build custom containers with a Dockerfile

          Also, I want to know how containers work. That’s way more useful.

      • Jeena@piefed.jeena.net
        link
        fedilink
        English
        arrow-up
        7
        ·
        5 months ago

        I did that first but that always required much more resources than doing it yourself because every docker starts it’s own database and it’s own nginx/apache server in addition to the software itself.

        Now I have just one Postgresql database instance running with many users and databases on it. Also just one Nginx which does all the virtual host stuff in one central place. And both the things which I install with apt and manually are set up similarly.

        I use one docker setup for firefox-sync but only because doing it manually is not documented and even the docker way I had to research for quite some time.

        • FlexibleToast@lemmy.world
          link
          fedilink
          English
          arrow-up
          2
          ·
          5 months ago

          What? No it doesn’t… You could still have just one postgresql database if you wanted just one. It is a big antithetical to microservices, but there is no reason you can do it.

          • Jeena@piefed.jeena.net
            link
            fedilink
            English
            arrow-up
            7
            arrow-down
            1
            ·
            5 months ago

            But then you can’t just use the containers provided by the service developers and have to figure out how to redo their container which in the end is more work than just run it manually.

              • WhyJiffie@sh.itjust.works
                link
                fedilink
                English
                arrow-up
                1
                ·
                edit-2
                5 months ago

                all of these run the database in a separate container, not inside the app container. the latter would be hard to fix, but the first is just that way to make documentation easier, to be able to give you a single compose file that is also functional in itself. none of them use their own builds of the database server (though lemmy with its postgres variant may be a bit of an outlier), so they are relatively easy to configure for an existing db server.

                all I do in cases like this is look up the database initialization command (in the docker compose file), run that in my primary postgres container, create a new docker network and attach it to the postgres stack and the new app’s stack (stack: the container composition defindd by the docker compose file). and then I tell the app container, usually through envvars or command line parameters embedded in the compose file, that the database server is at xy hostname, and docker’s internal DNS server will know that for xy hostname it should return the IP address of the container that is named xy, through the appropriate docker network. and also the user and pass for connection. from then, from the app’s point of view, my database server in that other container is just like a dedicated physical postgres machine you put on the network with its own cable going to a switch.

                unless very special circumstances, where the app needs a custom build of postgres, they can share a single instance just fine. but in that case you would have to run 2 postgres instances even without docker, or migrate to the modified postgres, which is an option with docker too.

            • WhyJiffie@sh.itjust.works
              link
              fedilink
              English
              arrow-up
              2
              ·
              edit-2
              5 months ago

              I have very rarely ran into such issues. can you give an example of something that works like that? it sounds to be very half-assed by the developer. only pihole comes to mind right now (except for the db part, because I think it uses sqlite)

              edit: I now see your examples

            • FlexibleToast@lemmy.world
              link
              fedilink
              English
              arrow-up
              1
              ·
              5 months ago

              You absolutely can. It’s not like the developers of postgresql maintain a version of postgresql that only allows one db. You can connect to that db and add however many things you want to it.

            • notfromhere@lemmy.ml
              link
              fedilink
              English
              arrow-up
              1
              ·
              5 months ago

              Typically, the container image maintainer will provide environment variables which can override the database connection. This isn’t always the case but usually it’s as simple as updating those and ensuring network access between your containers.