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
  • Brite
  • 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. LAMP
  3. Allow custom ports

Allow custom ports

Scheduled Pinned Locked Moved Solved LAMP
19 Posts 3 Posters 4.2k Views 3 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.
  • nebulonN nebulon

    I understand if building an app image is only for devs and sysadmins, as it does require some terminal use and also docker running locally at least (the build services is not required at all). In fact all is required is the cloudron cli and a docker image id (which does not need to be built for Cloudron either).

    But to take a step back, it does sound like you are looking for a generic app package, which is like a vm runtime to run any process/script/... which is uploaded into /app/data/. So just like the lamp app only for other stacks with all possible addons enabled. LAMP is only here since it has such a long legacy in linux servers, but really for other stacks it makes so much more sense to write a CloudronManifest.json and a simple Dockerimage alongside to get all the benefits. I feel like there may be some options to streamline that flow instead of just trying to provide some generic and very hard to update/maintain app package from our side.

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

    @nebulon said in Allow custom ports:

    it does sound like you are looking for a generic app package, which is like a vm runtime to run any process/script/... which is uploaded into /app/data/.

    This could be interpreted very broadly, therefore that's not the ask, however that is the end goal if you'd rather solve for that and include the ask in the OP.

    Many ways to approach that, which we've covered previously with simple sysbox integration which enhances docker capabilities 10-fold with a single parameter on container launch, and a LEMP or even more generic stack container Cloudron app, all of which make the app backups import/export more functional and open up a new realm of not-yet-packaged app snapshots for more users.

    Conscious tech

    1 Reply Last reply
    0
    • robiR robi marked this topic as a question on
    • robiR Offline
      robiR Offline
      robi
      wrote on last edited by
      #11

      Further thoughts on how to make this happen? Use case clear?

      Conscious tech

      girishG 1 Reply Last reply
      0
      • robiR robi

        Further thoughts on how to make this happen? Use case clear?

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

        @robi Use case is clear. The manifest is currently quite static because the design goal is for pre-packaged apps where databases, ports, addons, dependencies, backups are known in advance. Having things optional and dynamic requires fundamental changes and it's a non-trivial change.

        Anything is possible of course, so if many want this, we have to look into it.

        robiR 1 Reply Last reply
        0
        • girishG girish

          @robi Use case is clear. The manifest is currently quite static because the design goal is for pre-packaged apps where databases, ports, addons, dependencies, backups are known in advance. Having things optional and dynamic requires fundamental changes and it's a non-trivial change.

          Anything is possible of course, so if many want this, we have to look into it.

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

          @girish This is not about the manifest or port config there.

          As stated in the OP, this is about the ability to modify the LAMP container based apache2 defined port in /etc/apache2, which is read-only and cannot be overridden with the config file in /app/data/apache.

          This should be a simple change with an update to the LAMP package.

          How do we do that?

          P.S. I can make a separate Feature Request, if you wish, for the ability to better control the Nginx proxy port config for Cloudron apps, which would be a larger platform change (which still would not impact the app manifest).

          Conscious tech

          girishG 1 Reply Last reply
          0
          • robiR robi

            @girish This is not about the manifest or port config there.

            As stated in the OP, this is about the ability to modify the LAMP container based apache2 defined port in /etc/apache2, which is read-only and cannot be overridden with the config file in /app/data/apache.

            This should be a simple change with an update to the LAMP package.

            How do we do that?

            P.S. I can make a separate Feature Request, if you wish, for the ability to better control the Nginx proxy port config for Cloudron apps, which would be a larger platform change (which still would not impact the app manifest).

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

            @robi said in Allow custom ports:

            This should be a simple change with an update to the LAMP package.

            It's not a simple change. The http port number that apache exposes is coded in the manifest. This requires the manifest to by dynamic.

            robiR 1 Reply Last reply
            0
            • girishG Offline
              girishG Offline
              girish
              Staff
              wrote on last edited by
              #15

              On a side note, you can also just configure apache to proxy_pass to your app's port.

              robiR 1 Reply Last reply
              0
              • girishG girish

                @robi said in Allow custom ports:

                This should be a simple change with an update to the LAMP package.

                It's not a simple change. The http port number that apache exposes is coded in the manifest. This requires the manifest to by dynamic.

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

                @girish said in Allow custom ports:

                The http port number that apache exposes is coded in the manifest. This requires the manifest to by dynamic.

                Isn't the manifest info for the Cloudron side of things? Container and proxy config, etc.

                Separate from the ability to manually reconfigure apache after the default install?

                Conscious tech

                girishG 1 Reply Last reply
                0
                • girishG girish

                  On a side note, you can also just configure apache to proxy_pass to your app's port.

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

                  @girish said in Allow custom ports:

                  On a side note, you can also just configure apache to proxy_pass to your app's port.

                  Hmm, a double proxy, good idea to test!

                  Conscious tech

                  girishG 1 Reply Last reply
                  0
                  • robiR robi

                    @girish said in Allow custom ports:

                    On a side note, you can also just configure apache to proxy_pass to your app's port.

                    Hmm, a double proxy, good idea to test!

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

                    @robi we use such a thing in some apps like espocrm - https://git.cloudron.io/cloudron/espocrm-app/-/blob/master/apache/espocrm.conf?ref_type=heads#L20 . Many apps have nginx doing proxy pass in the container as well (taiga, pixelfed, onlyoffice, immich, sogo, jitsi etc).

                    1 Reply Last reply
                    1
                    • robiR robi

                      @girish said in Allow custom ports:

                      The http port number that apache exposes is coded in the manifest. This requires the manifest to by dynamic.

                      Isn't the manifest info for the Cloudron side of things? Container and proxy config, etc.

                      Separate from the ability to manually reconfigure apache after the default install?

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

                      @robi said in Allow custom ports:

                      Separate from the ability to manually reconfigure apache after the default install?

                      The container exposes a port, 80 in this case. This 80 is hardcoded as httpPort in the manifest.

                      Thinking more, maybe what you mean is: disable apache altogether, I will run something else on port 80. If this is the case, you are right that manifest does not need to be changed.

                      I don't think we will support this though. It's not a normal flow to install LAMP and then disable apache as first step and run something else. This works for your specific situation only because you don't want a database or expose another port. What if I want postgres? Java? At this point, you will install everything into a data directory and run it from there. This is really not in the spirit of Cloudron.

                      1 Reply Last reply
                      1
                      • jamesJ james has marked this topic as solved on
                      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