Cloudron makes it easy to run web apps like WordPress, Nextcloud, GitLab on your server. Find out more or install now.


Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Bookmarks
  • Search
Skins
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Brand Logo

Cloudron Forum

Apps | Demo | Docs | Install
  1. Cloudron Forum
  2. Feature Requests
  3. Storage limits per-app

Storage limits per-app

Scheduled Pinned Locked Moved Feature Requests
24 Posts 8 Posters 3.8k Views 8 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • girishG girish

    If anyone knows how this can be done on linux, I am open to investigating this. As in how does mount a storage directory into a docker container that has a specific size? I can only think of some (sparse) file based loopback filesystem. I don't like that approach and would prefer some other alternative. I haven't looked into recent developments in linux quota system.

    M Offline
    M Offline
    msbt
    App Dev
    wrote on last edited by
    #8

    @girish what about https://docs.docker.com/engine/reference/commandline/run/#set-storage-driver-options-per-container (from https://stackoverflow.com/questions/38542426/docker-container-specific-disk-quota)

    girishG 1 Reply Last reply
    1
    • robiR Offline
      robiR Offline
      robi
      wrote on last edited by
      #9

      If storage for Apps was integrated with container attached storage from MayaData.com, this would be an easier option.

      This will also help Apps be more distributed and clustered, among other benefits.

      Conscious tech

      MooCloud_MattM 1 Reply Last reply
      0
      • girishG girish

        If anyone knows how this can be done on linux, I am open to investigating this. As in how does mount a storage directory into a docker container that has a specific size? I can only think of some (sparse) file based loopback filesystem. I don't like that approach and would prefer some other alternative. I haven't looked into recent developments in linux quota system.

        MooCloud_MattM Offline
        MooCloud_MattM Offline
        MooCloud_Matt
        wrote on last edited by
        #10

        @girish
        it can be done with LVM, btrfs or ZFS.
        And their relative Docker driver, can be an option with an installation on ubuntu + one of those FS.

        Matteo. R.
        Founder and Tech-Support Manager.
        MooCloud MSP
        Swiss Managed Service Provider

        1 Reply Last reply
        0
        • robiR robi

          If storage for Apps was integrated with container attached storage from MayaData.com, this would be an easier option.

          This will also help Apps be more distributed and clustered, among other benefits.

          MooCloud_MattM Offline
          MooCloud_MattM Offline
          MooCloud_Matt
          wrote on last edited by
          #11

          @robi said in Storage limits per-app:

          MayaData.com

          I think they use OpenEBS, and as all the distributed storage solutions are complicated to set up, we use Ceph and need a dedicated port on the cluster server for the sync job, not as a requirement but as a need for reasonable performance to be able to use there features.

          Matteo. R.
          Founder and Tech-Support Manager.
          MooCloud MSP
          Swiss Managed Service Provider

          robiR 1 Reply Last reply
          0
          • M msbt

            @girish what about https://docs.docker.com/engine/reference/commandline/run/#set-storage-driver-options-per-container (from https://stackoverflow.com/questions/38542426/docker-container-specific-disk-quota)

            girishG Offline
            girishG Offline
            girish
            Staff
            wrote on last edited by
            #12

            @msbt Interesting link, thanks. I wonder if it works for volumes also. It says it depends on the "volume plugin". Have to investigate. On Cloudron, the data directory is just a normal volume and doesn't use any plugin and it's unclear if that standard thing supports storage-opt.

            1 Reply Last reply
            0
            • MooCloud_MattM MooCloud_Matt

              @robi said in Storage limits per-app:

              MayaData.com

              I think they use OpenEBS, and as all the distributed storage solutions are complicated to set up, we use Ceph and need a dedicated port on the cluster server for the sync job, not as a requirement but as a need for reasonable performance to be able to use there features.

              robiR Offline
              robiR Offline
              robi
              wrote on last edited by
              #13

              @moocloud_matt said in Storage limits per-app:

              OpenEBS

              Yes, but there is a more advanced version at MayaData.

              @staff and I have spoken with them before.

              Conscious tech

              robiR 1 Reply Last reply
              0
              • robiR robi referenced this topic on
              • girishG girish referenced this topic on
              • AizatA Offline
                AizatA Offline
                Aizat
                wrote on last edited by
                #14

                Any news about this? This is very useful especially if we're giving access to our clients who may overuse the storage in some of the apps on Cloudron.

                girishG 1 Reply Last reply
                3
                • AizatA Aizat

                  Any news about this? This is very useful especially if we're giving access to our clients who may overuse the storage in some of the apps on Cloudron.

                  girishG Offline
                  girishG Offline
                  girish
                  Staff
                  wrote on last edited by
                  #15

                  @Aizat Still looking for suggestions to my comment https://forum.cloudron.io/topic/5103/storage-limits-per-app/7

                  1 Reply Last reply
                  0
                  • girishG girish referenced this topic on
                  • girishG Offline
                    girishG Offline
                    girish
                    Staff
                    wrote on last edited by
                    #16

                    Maybe we have use usrquota - https://www.digitalocean.com/community/tutorials/how-to-set-filesystem-quotas-on-ubuntu-18-04 . I guess this involves creating a user per app.

                    XFS has pquota - https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/8/html/managing_file_systems/assembly_limiting-storage-space-usage-on-xfs-with-quotas_managing-file-systems . EXT4 has prjquota - https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/8/html/managing_file_systems/assembly_limiting-storage-space-usage-on-ext4-with-quotas_managing-file-systems

                    Also, found that there is a --storage-size when using XFS in Docker - https://docs.docker.com/engine/reference/commandline/run/#set-storage-driver-options-per-container

                    1 Reply Last reply
                    1
                    • robiR robi

                      @moocloud_matt said in Storage limits per-app:

                      OpenEBS

                      Yes, but there is a more advanced version at MayaData.

                      @staff and I have spoken with them before.

                      robiR Offline
                      robiR Offline
                      robi
                      wrote on last edited by
                      #17

                      This was also addressed in OpenEBS - https://github.com/openebs/dynamic-localpv-provisioner/issues/13

                      Conscious tech

                      girishG 1 Reply Last reply
                      0
                      • robiR robi

                        This was also addressed in OpenEBS - https://github.com/openebs/dynamic-localpv-provisioner/issues/13

                        girishG Offline
                        girishG Offline
                        girish
                        Staff
                        wrote on last edited by
                        #18

                        @robi Nice find, looks like they implemented this as XFS only. Most VPS providers use EXT4 by default afaik.

                        robiR 1 Reply Last reply
                        0
                        • girishG girish

                          @robi Nice find, looks like they implemented this as XFS only. Most VPS providers use EXT4 by default afaik.

                          robiR Offline
                          robiR Offline
                          robi
                          wrote on last edited by
                          #19

                          @girish It does not matter that VPS providers use as you control what happens inside containers.

                          If you choose to attach container volumes they can be XFS layers with all the nice tools XFS comes with, which EXT4 lacks.

                          Similarly for attaching external volumes of additional space apart from the default FS the OS is installed on.

                          Conscious tech

                          girishG 1 Reply Last reply
                          0
                          • robiR robi

                            @girish It does not matter that VPS providers use as you control what happens inside containers.

                            If you choose to attach container volumes they can be XFS layers with all the nice tools XFS comes with, which EXT4 lacks.

                            Similarly for attaching external volumes of additional space apart from the default FS the OS is installed on.

                            girishG Offline
                            girishG Offline
                            girish
                            Staff
                            wrote on last edited by
                            #20

                            @robi the volumes can be XFS, but it requires a backing device. On a standard VPS, this means that we have to create a (big enough) file on EXT4 file system and then format it as XFS. This setup has the usual issues of loopback devices - what size this initial file should be, how to resize it live to increase/decrease storage etc. Not sure how well this performs either.

                            robiR AizatA 2 Replies Last reply
                            0
                            • girishG girish

                              @robi the volumes can be XFS, but it requires a backing device. On a standard VPS, this means that we have to create a (big enough) file on EXT4 file system and then format it as XFS. This setup has the usual issues of loopback devices - what size this initial file should be, how to resize it live to increase/decrease storage etc. Not sure how well this performs either.

                              robiR Offline
                              robiR Offline
                              robi
                              wrote on last edited by
                              #21

                              @girish yep, or do a little parted scripting first to have a device backed partition avoiding loopback issues for a more static setup..

                              wanna make changes? restore from remote backup.

                              For a more dynamic setup integrate OpenEBS/MayaData so you can keep attaching additional extent layers or do virtual migrations to different sized container attached storage mounts.

                              Conscious tech

                              1 Reply Last reply
                              0
                              • girishG girish referenced this topic on
                              • girishG girish referenced this topic on
                              • girishG girish

                                @robi the volumes can be XFS, but it requires a backing device. On a standard VPS, this means that we have to create a (big enough) file on EXT4 file system and then format it as XFS. This setup has the usual issues of loopback devices - what size this initial file should be, how to resize it live to increase/decrease storage etc. Not sure how well this performs either.

                                AizatA Offline
                                AizatA Offline
                                Aizat
                                wrote on last edited by
                                #22

                                @girish Hi, is there any news about the storage limits per-app implementation?

                                girishG 1 Reply Last reply
                                0
                                • AizatA Aizat

                                  @girish Hi, is there any news about the storage limits per-app implementation?

                                  girishG Offline
                                  girishG Offline
                                  girish
                                  Staff
                                  wrote on last edited by
                                  #23

                                  @Aizat No plans yet. But as a workaround, you can always do this:

                                  • Setup a block storage of appropriate size
                                  • Then, add it as Cloudron Volume
                                  • Move app's data directory into the Volume

                                  That way, the app cannot use more data than the volume itself. This does not cover databasize size which is stored outside the volume.

                                  1 Reply Last reply
                                  1
                                  • girishG Offline
                                    girishG Offline
                                    girish
                                    Staff
                                    wrote on last edited by
                                    #24

                                    Atleast, postgres does not have a way to limit db size - https://stackoverflow.com/questions/37822195/restrict-database-size

                                    1 Reply Last reply
                                    1
                                    Reply
                                    • Reply as topic
                                    Log in to reply
                                    • Oldest to Newest
                                    • Newest to Oldest
                                    • Most Votes


                                    • Login

                                    • Don't have an account? Register

                                    • Login or register to search.
                                    • First post
                                      Last post
                                    0
                                    • Categories
                                    • Recent
                                    • Tags
                                    • Popular
                                    • Bookmarks
                                    • Search