溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

docker-compose ports和expose的區(qū)別詳解

發(fā)布時(shí)間:2020-10-19 02:07:10 來源:腳本之家 閱讀:163 作者:Stinky_kiss 欄目:服務(wù)器

docker-compose中有兩種方式可以暴露容器的端口:ports和expose。

ports

ports暴露容器端口到主機(jī)的任意端口或指定端口,用法:

ports:
 
- "80:80" # 綁定容器的80端口到主機(jī)的80端口
 
- "9000:8080" # 綁定容器的8080端口到主機(jī)的9000端口
 
- "443" # 綁定容器的443端口到主機(jī)的任意端口,容器啟動時(shí)隨機(jī)分配綁定的主機(jī)端口號

不管是否指定主機(jī)端口,使用ports都會將端口暴露給主機(jī)。

容器中可以運(yùn)行一些網(wǎng)絡(luò)應(yīng)用,要讓外部也可以訪問這些應(yīng)用,可以通過 -P(大寫) 或 -p (小寫) 參數(shù)來指定端口映射。

(1) 當(dāng)使用-P標(biāo)記時(shí),Docker 會隨機(jī)映射一個(gè)49000~49900的端口到內(nèi)部容器開放的網(wǎng)絡(luò)端口。

使用docker ps可以看到,本地主機(jī)的 49155 被映射到了容器的 5000 端口。此時(shí)訪問本機(jī)的 49155 端口即可訪問容器內(nèi) web 應(yīng)用提供的界面。

$ 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命令來查看應(yīng)用的信息。

$ 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和端口,但是在一個(gè)指定端口上只可以綁定一個(gè)容器。支持的格式有 hostPort:containerPort、ip:hostPort:containerPort、ip::containerPort。

expose

expose暴露容器給link到當(dāng)前容器的容器,用法:

expose:
- "3000"
- "8000"

以上指令將當(dāng)前容器的端口3000和8000暴露給link到本容器的容器。

和ports的區(qū)別是,expose不會將端口暴露給主機(jī)。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI