Hi, I’m just getting started with Docker, so apologies in advance if this seems silly.

I used to self-host multiple services (RSS reader, invoicing software, personal wiki) directly on a VPS using nginx and mariadb. I messed it up recently and am starting again, but this time I took the docker route.

So I’ve set up the invoicing software (InvoiceNinja), and everything is working as I want.

Now that I want to add the other services (ttrss and dokuwiki), should I set up new containers? It feels wasteful.

Instead, if I add additional configs to the existing servers that the InvoiceNinja docker-compose generated (nginx and mysql), I’m worried that an update to Invoiceninja would have a chance of messing up the other setups as well.

It shouldn’t, from my understanding of how docker containers work, but I’m not 100% sure. What would be the best way to proceed?

    • mudeth@lemmy.caOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      9 months ago

      That would be ideal, per my understanding of the architecture.

      So will docker then minimize the system footprint for me? If I run two mysql containers, it won’t necessarily take twice the resources of a single mysql container? I’m seeing that the existing mysql process in top is using 15% of my VPS’s RAM, I don’t want to spin up another one if it’s going to scale linearly.

      • bjorney@lemmy.ca
        link
        fedilink
        English
        arrow-up
        0
        ·
        9 months ago

        it won’t necessarily take twice the resources of a single mysql container

        It will as far as runtime resources

        You can (and should) just use the one MySQL container for all your applications. Set up a different database/schema for each container

        • mudeth@lemmy.caOP
          link
          fedilink
          English
          arrow-up
          0
          ·
          9 months ago

          I’m getting conflicting replies, so I’ll try running separate containers (which was the point of going the docker way anyway - to avoid version dependency problems).

          If it doesn’t scale well I may just switch back to non-container hosting.

      • moonpiedumplings@programming.dev
        link
        fedilink
        English
        arrow-up
        0
        ·
        edit-2
        9 months ago

        If I run two mysql containers, it won’t necessarily take twice the resources of a single mysql containers

        It’s complicated, but essentially, no.

        Docker images, are built in layers. Each layer is a step in the build process. Layers that are identical, are shared between containers to the point of it taking up the ram of only running the layer once.

        Although, it should be noted that docker doesn’t load the whole container into memory, like a normal linux os. Unused stuff will just sit on your disk, just like normal. So rather, binaries or libraries loaded twice via two docker containers will only use up the ram of one instance. This is similar to how shared libraries reduce ram usage.

        Docker only has these features, deduplication, if you are using overlayfs or aufs, but I think overlayfs is the default.

        https://moonpiedumplings.github.io/projects/setting-up-kasm/#turns-out-memory-deduplication-is-on-by-default-for-docker-containers

        Should you run more than one database container? Well I dunno how mysql scales. If there is performance benefit from having only one mysqld instance, then it’s probably worth it. Like, if mysql uses up that much ram regardless of what databases you have loaded in a way that can’t be deduplicated, then you’d definitely see a benefit from a single container.

        What if your services need different database versions, or even software? Then different database containers is probably better.

      • scorpionix@feddit.de
        link
        fedilink
        English
        arrow-up
        0
        ·
        9 months ago

        AFAIK it won’t and should you still get a bottleneck you can limit the maximum resources a service may use.