Loading

iptables实现NAT转发

环境

服务器A:192.168.1.7
服务器B: 192.168.1.160

需求#

实现将本机(192.168.1.7:7410)端口流量转发给(192.168.1.160:9200)。

1. 内核允许IP转发#

# 1.1 会话
echo 1 > /proc/sys/net/ipv4/ip_forward

# 1.2 永久
vi /etc/sysctl.conf
添加如下代码:
    net.ipv4.ip_forward=1

重启network服务
 systemctl restart network

查看是否修改成功
 sysctl net.ipv4.ip_forward

2. 加载内核模块#

modprobe ip_conntrack

3. 设置filter表基础策略:允许入包/出包/转发(可进一步细化)#

iptables -P INPUT ACCEPT
iptables -P OUTPUT ACCEPT
iptables -P FORWARD ACCEPT

4. 设置基础会话规则#

iptables -A FORWARD -m state --state RELATED,ESTABLISHED -j ACCEPT

5. 端口转发流量#

iptables -t nat -A PREROUTING -d 192.168.1.7/32 -p tcp --dport 7410 -j DNAT --to-destination 192.168.1.160:9200;
iptables -t nat -A POSTROUTING -d 192.168.1.160/32 -p tcp --dport 9200 -j SNAT --to-source 192.168.1.7;

6.保存#

service iptables save
service iptables restart

7. 测试#

telnet 192.168.1.7:7410 

其他#

### 停止
service iptables stop
### 查看状态
service iptables status
### 备份
iptables-save > ables.bak
### 还原
iptables-restore < iptables.bak
posted @   Ellisonzhang  阅读(849)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示
主题色彩