您好,登錄后才能下訂單哦!
這篇文章主要介紹“dockercompose ports和expose的區別是什么”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“dockercompose ports和expose的區別是什么”文章能幫助大家解決問題。
docker-compose中有兩種方式可以暴露容器的端口:ports和expose。
ports
ports暴露容器端口到主機的任意端口或指定端口,用法:
ports: - "80:80" # 綁定容器的80端口到主機的80端口 - "9000:8080" # 綁定容器的8080端口到主機的9000端口 - "443" # 綁定容器的443端口到主機的任意端口,容器啟動時隨機分配綁定的主機端口號
不管是否指定主機端口,使用ports都會將端口暴露給主機。
容器中可以運行一些網絡應用,要讓外部也可以訪問這些應用,可以通過 -p(大寫) 或 -p (小寫) 參數來指定端口映射。
(1) 當使用-p標記時,docker 會隨機映射一個49000~49900的端口到內部容器開放的網絡端口。
使用docker ps可以看到,本地主機的 49155 被映射到了容器的 5000 端口。此時訪問本機的 49155 端口即可訪問容器內 web 應用提供的界面。
$ sudo docker run -d -p training/webapp python app.py $ sudo docker ps -l container id image command created status ports names bc533791f3f5 training/webapp:latest python app.py 5 seconds ago up 2 seconds 0.0.0.0:49155->5000/tcp nostalgic_morse
同樣的,可以通過docker logs命令來查看應用的信息。
$ sudo docker logs -f nostalgic_morse * running on http://0.0.0.0:5000/ 10.0.2.2 - - [23/may/2014 20:16:31] "get / http/1.1" 200 - 10.0.2.2 - - [23/may/2014 20:16:31] "get /favicon.ico http/1.1" 404 -
(2) -p(小寫)則可以指定要映射的ip和端口,但是在一個指定端口上只可以綁定一個容器。支持的格式有 hostport:containerport、ip:hostport:containerport、ip::containerport。
expose
expose暴露容器給link到當前容器的容器,用法:
expose: - "3000" - "8000"
以上指令將當前容器的端口3000和8000暴露給link到本容器的容器。
和ports的區別是,expose不會將端口暴露給主機。
關于“dockercompose ports和expose的區別是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。