溫馨提示×

溫馨提示×

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

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

Linux和Windows中怎么實現(xiàn)端口映射

發(fā)布時間:2021-08-09 15:20:47 來源:億速云 閱讀:303 作者:Leah 欄目:系統(tǒng)運維

今天就跟大家聊聊有關Linux和Windows中怎么實現(xiàn)端口映射,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

一、Windows下實現(xiàn)端口映射

1.  查詢端口映射情況

netsh interface portproxy show v4tov4

2. 查詢某一個IP的所有端口映射情況

netsh interface portproxy show v4tov4 | find "[IP]"  例:  netsh interface portproxy show v4tov4 | find "192.168.1.1"

3. 增加一個端口映射

netsh interface portproxy add v4tov4 listenaddress=[外網(wǎng)IP] listenport=[外網(wǎng)端口] connectaddress=[內(nèi)網(wǎng)IP] connectport=[內(nèi)網(wǎng)端口]  例:  netsh interface portproxy add v4tov4 listenaddress=2.2.2.2 listenport=8080 connectaddress=192.168.1.50 connectport=80

4. 刪除一個端口映射

netsh interface portproxy delete v4tov4 listenaddress=[外網(wǎng)IP] listenport=[外網(wǎng)端口]  例:  netsh interface portproxy delete v4tov4 listenaddress=2.2.2.2 listenport=8080

二、Linux下端口映射

1. 允許數(shù)據(jù)包轉發(fā)

echo 1 >/proc/sys/net/ipv4/ip_forward  iptables -t nat -A POSTROUTING -j MASQUERADE  iptables -A FORWARD -i [內(nèi)網(wǎng)網(wǎng)卡名稱] -j ACCEPT  iptables -t nat -A POSTROUTING -s [內(nèi)網(wǎng)網(wǎng)段] -o [外網(wǎng)網(wǎng)卡名稱] -j MASQUERADE  例:  echo 1 >/proc/sys/net/ipv4/ip_forward  iptables -t nat -A POSTROUTING -j MASQUERADE  iptables -A FORWARD -i ens33 -j ACCEPT  iptables -t nat -A POSTROUTING -s 192.168.50.0/24 -o ens37 -j MASQUERADE

2. 設置端口映射

iptables -t nat -A PREROUTING -p tcp -m tcp --dport [外網(wǎng)端口] -j DNAT --to-destination [內(nèi)網(wǎng)地址]:[內(nèi)網(wǎng)端口]  例: iptables -t nat -A PREROUTING -p tcp -m tcp --dport 6080 -j DNAT --to-destination 10.0.0.100:6090

實驗:將部署在內(nèi)網(wǎng)的服務映射到外網(wǎng)

實驗環(huán)境

  1. 鴻蒙官方戰(zhàn)略合作共建——HarmonyOS技術社區(qū)

  2.  VMWare Workstation Pro

  3.  5臺最小化安裝的centos 7虛擬機

實驗拓撲

Linux和Windows中怎么實現(xiàn)端口映射

內(nèi)網(wǎng)和外網(wǎng)是相對Server4來說的。

Server1和Server2為內(nèi)網(wǎng)環(huán)境的兩臺服務器;

Server3為外網(wǎng)環(huán)境下的一臺服務器;

Server4為一臺雙網(wǎng)卡主機,分別連接192.168.50.0/24和172.16.2.0/24兩個網(wǎng)絡。

配置實驗環(huán)境

1. Server1,2,3上搭建HTTP服務

用Python在Server1上搭建一個簡單的HTTP服務

cd ~  echo "server1" > index.html  python -m SimpleHTTPServer 8080

Linux和Windows中怎么實現(xiàn)端口映射

Server2、Server3同理

對照實驗

在client上訪問Server1的資源

curl http://192.168.50.11:8080/index.html

Linux和Windows中怎么實現(xiàn)端口映射

在client上訪問Server2的資源

curl http://192.168.50.12:8080/index.htm

Linux和Windows中怎么實現(xiàn)端口映射

在client上訪問Server3的資源

curl http://172.16.2.11:8080/index.html

Linux和Windows中怎么實現(xiàn)端口映射

可以看到,外網(wǎng)的client是無法訪問內(nèi)網(wǎng)Server1,Server2的資源的。

在Server4上配置端口映射

臨時配置

#允許數(shù)據(jù)包轉發(fā)  echo 1 >/proc/sys/net/ipv4/ip_forward  iptables -t nat -A POSTROUTING -j MASQUERADE  iptables -A FORWARD -i ens33 -j ACCEPT  iptables -t nat -A POSTROUTING -s 192.168.50.0/24 -o ens37 -j MASQUERADE  #設置端口映射  iptables -t nat -A PREROUTING -p tcp -m tcp --dport 8081 -j DNAT --to-destination 192.168.50.11:8080  iptables -t nat -A PREROUTING -p tcp -m tcp --dport 8082 -j DNAT --to-destination 192.168.50.12:8080

永久配置

如果需要永久配置,則將以上命令追加到/etc/rc.local文件。

檢查效果

在client上訪問Server1的資源

curl http://172.16.2.100:8081/index.html

Linux和Windows中怎么實現(xiàn)端口映射

在client上訪問Server2的資源

curl http://172.16.2.100:8082/index.html

Linux和Windows中怎么實現(xiàn)端口映射

在client上訪問Server3的資源

curl http://172.16.2.11:8080/index.html

Linux和Windows中怎么實現(xiàn)端口映射

如果Server4為Windows,替換一下相應的命令即可

Windows的IP信息如下

網(wǎng)卡IP地址子網(wǎng)掩碼默認網(wǎng)關備注
Ethernet0192.168.50.105255.255.255.0-內(nèi)網(wǎng)網(wǎng)卡
Ethernet1172.16.2.105255.255.255.0-外網(wǎng)網(wǎng)卡


Linux和Windows中怎么實現(xiàn)端口映射

配置并查看端口映射情況

netsh interface portproxy add v4tov4 listenaddress=172.16.2.105 listenport=8081 connectaddress=192.168.50.11 connectport=8080  netsh interface portproxy add v4tov4 listenaddress=172.16.2.105 listenport=8082 connectaddress=192.168.50.12 connectport=8080  netsh interface portproxy show v4tov4

Linux和Windows中怎么實現(xiàn)端口映射

檢查效果

在client節(jié)點上

curl http://172.16.2.105:8081/index.html  curl http://172.16.2.105:8082/index.html  curl http://172.16.2.11:8080/index.html

Linux和Windows中怎么實現(xiàn)端口映射

看完上述內(nèi)容,你們對Linux和Windows中怎么實現(xiàn)端口映射有進一步的了解嗎?如果還想了解更多知識或者相關內(nèi)容,請關注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細節(jié)

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

AI