通过iptables做端口映射
通过iptables做端口映射
Iptables是Linux内核集成的IP信息包过滤系统,不同版本的linux系统对于iptables的安装、配置也有所区别,本文以Centos7系统为例,通过对iptables策略进行修改配置,实现对于指定IP地址的端口映射及IP地址转换(NAT)。具体操作如下:
1.安装iptables——使用下面命令进行安装iptables服务:
yum -y install iptables-services
data:image/s3,"s3://crabby-images/8e5be/8e5bec7438c8f7ae8af6c1c68e7500e0f7db3de8" alt="通过iptables做端口映射-3160"
2.运行下列命令启动iptables服务:
systemctl start iptables
3.运行下列命令查看iptables服务运行状态,状态为“active”表示iptables服务已在运行:
service iptables status
data:image/s3,"s3://crabby-images/bf7df/bf7df8f13fd0409ad2cef3ac5221bf6faceed48a" alt="通过iptables做端口映射-3161"
4.设置iptables的开机自启动:
systemctl enable iptables
data:image/s3,"s3://crabby-images/79a07/79a074fb45b2e207d1c3e2f2d981a10fb1bdff18" alt="通过iptables做端口映射-3162"
5.echo net.ipv4.ip_forward=1>>/etc/sysctl.conf //开启系统路由模式功能
sysctl -p //使内核修改生效
data:image/s3,"s3://crabby-images/f24d3/f24d35a3b04e950ee6d6cb41beec5c6620da42cf" alt="通过iptables做端口映射-3163"
6.用DNAT做端口映射:
例如:
iptables -t nat -A PREROUTING -p tcp –m tcp --dport 12345 -j DNAT --to-destination 192.168.10.26:3389
//将访问本服务器TCP12345接口的流量映射到192.168.10.26的3389端口
7.用SNAT作源地址转换,以使回应包能正确返回:
例如:
iptables -t nat -A POSTROUTING -d 192.168.10.26/32 -p tcp –m tcp --dport 3389 -j SNAT --to 192.168.233.142 //主机192.168.10.26回应访问其3389端口的流量包,经192.168.233.142
向外映射
data:image/s3,"s3://crabby-images/8cf82/8cf82f6302e22c2e0edcbb596e3e59831eeae4b4" alt="通过iptables做端口映射-3164"
8.保存添加的规则:
iptables-save > /etc/sysconfig/iptables