您好,登錄后才能下訂單哦!
Docker運(yùn)行容器之后卻發(fā)現(xiàn)沒(méi)IP,沒(méi)端口,那要如何訪問(wèn)容器呢?
下面我來(lái)介紹下docker通過(guò)端口映射來(lái)實(shí)現(xiàn)網(wǎng)絡(luò)訪問(wèn)
一、從外部訪問(wèn)容器應(yīng)用
在啟動(dòng)容器的時(shí)候,如果不指定對(duì)應(yīng)參數(shù),在容器外部是無(wú)法通過(guò)網(wǎng)絡(luò)來(lái)訪問(wèn)容器內(nèi)的網(wǎng)絡(luò)應(yīng)用和服務(wù)的。
當(dāng)容器中運(yùn)行一些網(wǎng)絡(luò)應(yīng)用,要讓外部訪問(wèn)這些應(yīng)用時(shí),可以通過(guò)-P或-p參數(shù)指定端口映射。
先來(lái)說(shuō)說(shuō)p和P吧
先申明一下,我這邊
client ip address 為192.168.0.225
registry ip address 為192.168.0.216:5000
docker run -d -it --name nginx -P 192.168.0.216:5000/nginx docker ps -a #查看容器是否在運(yùn)行 docker logs nginx #查看nginx容器的log
端口映射支持的格式有:
ip:hostport:containerport #指定ip、指定主機(jī)port、指定容器port ip::containerport #指定ip、未指定主機(jī)port、指定容器port hostport:container #未指定ip port、指定主機(jī)port、指定容器port
二、映射所有接口ip
下列命令查看到0.0.0.0監(jiān)聽(tīng)5000端口
docker run -d -it -p 5000:5000 --name registry 192.168.0.216:5000/registry docker ps -a | grep 5000
多次使用-p標(biāo)記可以綁定多個(gè)端口
docker run -d -it -p 800:80 -p 8088:8080 --name tomcat 192.168.0.216:5000/tomcat docker ps -a | egrep "(80|8080)"
三、映射到指定地址的指定端口
將容器的80 port映射到192.168.0.225:800
docker run -d -it -p 192.168.0.225:800:80 --name web_server 192.168.0.216:5000/nginx curl 192.168.0.225:800 #驗(yàn)證是否可以訪問(wèn)默認(rèn)首頁(yè)
四、映射到指定地址的udp端口
這里且不說(shuō)能不能訪問(wèn),只是一種映射方式。大家別見(jiàn)怪
docker run -d -it -p 192.168.0.225:300:3000/udp --name unknown 192.168.0.216:5000/nginx netstat -anpu |grep udp udp 0 0 192.168.0.225:300 0.0.0.0:* 24588/docker-proxy
五、查看映射端口配置
通過(guò)docker port container_ID 可以查看到容器映射了哪些端口及協(xié)議
[root@docker ~]#docker port tomcat 8080/tcp -> 192.168.0.225:32769 [root@docker ~]#docker port unknown 3000/udp -> 192.168.0.225:300
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。