How to assign different port to container replicas in docker swarm

非 Y 不嫁゛ 提交于 2019-12-02 09:22:19

问题


We are deploying storm supervisor with docker container in docker swarm mode with replica 3. Now we want to access supervisor logs on through browser.

We have exposed port 8080 on which we can access storm UI. This is working fine. Now storm also exposes their log files on port 8000. As we have only one nimbus and 3 supervisor, accessing nimbus logs through port 8000 was pretty easy.

The problem we faced on supervisor which is deployed using docker swarm service. And in docker swarm service we cannot pass different port for different container.

currently docker swarm service exposes same port on all the container. What we really want is like

port    container
8011    supervisor1:8000
8012    supervisor2:8000
8013    supervisor3:8000

How can we achieve this.

Thanks in advance.


回答1:


Ideally, tasks in a Swarm service should not be unique or contain unique data from one another. I know there are a few ways around this but it always feels non-ideal or hackish, especially when you're dealing with persistent data volumes that need a 1-to-1 match to a task.

I'd recommend you split the three replicas out into three separate services. I know it sounds like more work, but in a single stack file, it'll give you the flexibility to deal with individual ports and volumes on them since they are unique containers.



来源:https://stackoverflow.com/questions/48906127/how-to-assign-different-port-to-container-replicas-in-docker-swarm

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!