Allow to specify custom port mapping even Docker image does not expose it
If EXPOSE variable is not specified in Dockerfile, if it not possible to specify it in container settings
The Docker extension now supports launching a Portainer container. Portainer is container management software that makes it easier to manage Docker containers. It allows you to specify custom port mapping even if the Dockefile does not expose it. We would love to hear your feedback on our forum at https://talk.plesk.com.
— AY
-
Anonymous commented
Bump
Please implement this - It should be a reasonably simple change to the plesk UI due to the option to add custom storage mappings already being there.
-
TP commented
Use the Docker command line, there you can specify more than via Plesk GUI.
-
Rene Griessl commented
Currently trying to configure the eclipse mosquitto container. Would be very helpfull if I could switch the set non ssl port 1883 to the ssl port 8883 manually. But I'm not allowed to either edit 1883 in Manual Portmapping nor add an additional port there.
-
tsmokie commented
A better approach would be to show the advertised ports as we currently do in the manual configuration page, but allow the user to customize them
-
Craig Lawson commented
This is actually not sufficient - you should make this possible regardless of what is set in the EXPOSE meta data.
This is not an either or - its both options are required. EXPOSE is not a contract - its presence does not mean the only way you can use the image is as described.
EXPOSE is an advisory to say this docker image is going to "expose" a service on these ports.
There may be other ports open, the author may have got this wrong or not specified it at all. Often the containers have a multitude of other ports active and documented.
You should certainly list the exposed ports - but the choice of what port should not be fixed to those specified.
The problem with the current approach means that you end up having to republish repositories with the ports you need EXPOSEd in the docker file, which inevitably means that I’ll have to setup a CI to republish this if it does work every time the upstream packages are updated so does add a dependancy into the chain that is also undesirable.
Furthermore the docker container lookup does seem to take a long time to list your images the first time (certainly did for me).
To confirm - from Dockers documentation -
"The EXPOSE instruction does not actually publish the port. It functions as a type of documentation between the person who builds the image and the person who runs the container, about which ports are intended to be published"
Therefore this is not concrete - its advisory - very helpful that Plesk reads this but it should not be taken for granted as the only way in which a container may be used.