您好,登錄后才能下訂單哦!
怎么在docker中進(jìn)行端口映射?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。
docker容器內(nèi)提供服務(wù)并監(jiān)聽(tīng)8888端口,要使外部能夠訪問(wèn),需要做端口映射。
docker run -it --rm -p 8888:8888 server:v1
此時(shí)出現(xiàn)問(wèn)題,在虛機(jī)A上部署后,在A內(nèi)能夠訪問(wèn)8888端口服務(wù),但是在B卻不能訪問(wèn)。
這應(yīng)該是由于請(qǐng)求被攔截。
如果輸出的是“not running”則FirewallD沒(méi)有在運(yùn)行,且所有的防護(hù)策略都沒(méi)有啟動(dòng),那么可以排除防火墻阻斷連接的情況了。
如果輸出的是“running”,表示當(dāng)前FirewallD正在運(yùn)行,需要再輸入下面的命令查看現(xiàn)在開(kāi)放了哪些端口和服務(wù):
firewall-cmd --list-ports firewall-cmd --list-services
解決方案有兩種:
1.關(guān)閉FirewallD服務(wù):
如果您不需要防火墻,那直接關(guān)掉FirewallD服務(wù)就好了
systemctl stop firewalld.service
2.添加策略對(duì)外打開(kāi)指定的端口:
比如我們現(xiàn)在要打開(kāi)對(duì)外5000/tcp端口,可以使用下面的命令:
firewall-cmd --add-port=5000/tcp --permanent firewall-cmd --reload
如果只是臨時(shí)打開(kāi)端口,去掉第一行命令中的“--permanent”參數(shù),那么當(dāng)再次重啟FirewallD服務(wù)時(shí),本策略將失效。
sysctl net.ipv4.ip_forward
顯示net.ipv4.ip_forward=0則表示未打開(kāi)。
可關(guān)閉service iptables
service iptables stop
若docker run時(shí)出現(xiàn)錯(cuò)誤:
iptables: No chain/target/match by that name.
則只需重啟docker服務(wù)即可
service docker restart
或者:
#設(shè)置iptables防火墻為開(kāi)機(jī)啟動(dòng)項(xiàng) systemctl enable iptables.service #啟動(dòng)防火墻使配置文件生效 systemctl start iptables.service #停止防火墻 systemctl stop iptables.service #重啟防火墻使配置文件生效 systemctl restart iptables.service
最終版本:
啟動(dòng)docker并進(jìn)行端口映射后,docker會(huì)在iptables中添加DNAT規(guī)則,將收到的對(duì)應(yīng)端口的包轉(zhuǎn)換ip并進(jìn)行轉(zhuǎn)發(fā),同時(shí)添加規(guī)則將所有來(lái)自docker網(wǎng)域的ip進(jìn)行轉(zhuǎn)換。
但是在Centos7上出現(xiàn)docker可以正常訪問(wèn)外網(wǎng),但是外網(wǎng)發(fā)出的請(qǐng)求在經(jīng)過(guò)eth2接收轉(zhuǎn)發(fā)后送達(dá)不到docker0,或者送到卻出現(xiàn)(oui Unknown)的狀況。暫時(shí)不清楚這到底是為什么經(jīng)過(guò)DNAT后無(wú)法送達(dá)docker0.
最終解決辦法是在啟動(dòng)docker后,重啟iptables
service iptables restart
清空docker添加的所有規(guī)則,而后添加規(guī)則
iptables -t nat -A POSTROUTING -s 172.17.0.0/16 ! -o docker0 -j MASQUERADE
將所有來(lái)自docker的包172.17.0.0/16的ip替換為本機(jī)ip并發(fā)送,以達(dá)到docker訪問(wèn)外網(wǎng)的目的。
關(guān)于怎么在docker中進(jìn)行端口映射問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
免責(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)容。