在Linux中,可以使用iptables工具来实现端口转发。以下是将本地80端口的请求转发到8080端口的命令:
-
首先,确保iptables已经安装在你的系统上。如果没有安装,可以使用以下命令安装:
对于Debian/Ubuntu系统:
sudo apt-get install iptables
对于CentOS/RHEL系统:
sudo yum install iptables
-
使用以下命令配置iptables进行端口转发:
sudo iptables -t nat -A PREROUTING -p tcp --dport 80 -j DNAT --to-destination 192.168.16.1:8080 sudo iptables -t nat -A POSTROUTING -p tcp -d 192.168.16.1 --dport 8080 -j MASQUERADE
这些命令的解释如下:
-t nat
:指定操作的是网络地址转换(NAT)表。-A PREROUTING
:在PREROUTING链中添加一条规则。-p tcp
:指定协议为TCP。--dport 80
:指定目标端口为80。-j DNAT
:指定动作为DNAT(目标网络地址转换)。--to-destination 192.168.16.1:8080
:将目标地址和端口转换为192.168.16.1:8080。-A POSTROUTING
:在POSTROUTING链中添加一条规则。-p tcp
:指定协议为TCP。-d 192.168.16.1
:指定目标IP地址为192.168.16.1。--dport 8080
:指定目标端口为8080。-j MASQUERADE
:指定动作为MASQUERADE,用于伪装源地址。
-
保存iptables规则,以便在系统重启后仍然生效:
对于Debian/Ubuntu系统:
sudo sh -c 'iptables-save > /etc/iptables/rules.v4'
对于CentOS/RHEL系统:
sudo service iptables save
综上所述,所有发送到本地80端口的请求都会被转发到192.168.16.1的8080端口。
标签:iptables,8080,16.1,端口,192.168,网卡,本地,80 From: https://www.cnblogs.com/huangjiabobk/p/18295910