您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關Linux和Windows中怎么實現端口映射,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
一、Windows下實現端口映射
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=[外網IP] listenport=[外網端口] connectaddress=[內網IP] connectport=[內網端口] 例: 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=[外網IP] listenport=[外網端口] 例: netsh interface portproxy delete v4tov4 listenaddress=2.2.2.2 listenport=8080
二、Linux下端口映射
1. 允許數據包轉發
echo 1 >/proc/sys/net/ipv4/ip_forward iptables -t nat -A POSTROUTING -j MASQUERADE iptables -A FORWARD -i [內網網卡名稱] -j ACCEPT iptables -t nat -A POSTROUTING -s [內網網段] -o [外網網卡名稱] -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 [外網端口] -j DNAT --to-destination [內網地址]:[內網端口] 例: iptables -t nat -A PREROUTING -p tcp -m tcp --dport 6080 -j DNAT --to-destination 10.0.0.100:6090
實驗:將部署在內網的服務映射到外網
實驗環境
鴻蒙官方戰略合作共建——HarmonyOS技術社區
VMWare Workstation Pro
5臺最小化安裝的centos 7虛擬機
實驗拓撲
內網和外網是相對Server4來說的。
Server1和Server2為內網環境的兩臺服務器;
Server3為外網環境下的一臺服務器;
Server4為一臺雙網卡主機,分別連接192.168.50.0/24和172.16.2.0/24兩個網絡。
配置實驗環境
1. Server1,2,3上搭建HTTP服務
用Python在Server1上搭建一個簡單的HTTP服務
cd ~ echo "server1" > index.html python -m SimpleHTTPServer 8080
Server2、Server3同理
對照實驗
在client上訪問Server1的資源
curl http://192.168.50.11:8080/index.html
在client上訪問Server2的資源
curl http://192.168.50.12:8080/index.htm
在client上訪問Server3的資源
curl http://172.16.2.11:8080/index.html
可以看到,外網的client是無法訪問內網Server1,Server2的資源的。
在Server4上配置端口映射
臨時配置
#允許數據包轉發 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
在client上訪問Server2的資源
curl http://172.16.2.100:8082/index.html
在client上訪問Server3的資源
curl http://172.16.2.11:8080/index.html
如果Server4為Windows,替換一下相應的命令即可
Windows的IP信息如下
網卡 | IP地址 | 子網掩碼 | 默認網關 | 備注 |
---|---|---|---|---|
Ethernet0 | 192.168.50.105 | 255.255.255.0 | - | 內網網卡 |
Ethernet1 | 172.16.2.105 | 255.255.255.0 | - | 外網網卡 |
配置并查看端口映射情況
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
檢查效果
在client節點上
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中怎么實現端口映射有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。