前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linux 上用 IP转发使内部网络连接到互联网

Linux 上用 IP转发使内部网络连接到互联网

原创
作者头像
用户4988085
修改2021-09-14 10:55:24
2K0
修改2021-09-14 10:55:24
举报
文章被收录于专栏:建站知识

本篇文章主要为大家分享一下Linux系统中如何用 iptables 实现从一个网络接口到另一个接口的IP转发(数据包转发),有需要的小伙伴可以参考一下。

 Linux 上用 IP转发使内部网络连接到互联网
Linux 上用 IP转发使内部网络连接到互联网

1. 启用 IPv4 转发

首先,我们需要在我们的 Linux 操作系统上启用 IPv4 转发。要做到这点,我们需要用 sudo 模式在 shell 或终端下执行下面的命令。

代码语言:javascript
复制
 $ sudo -s# echo 1 > /proc/sys/net/ipv4/ip_forward
0?wx_fmt=png&tp=webp&wxfrom=5
0?wx_fmt=png&tp=webp&wxfrom=5

注意:上面的命令能马上启用ip转发,但只是临时的,直到下一次重启。要永久启用,我们需要使用我们惯用的文本编辑器打开 /etc/sysctl.conf 文件。

代码语言:javascript
复制
 # nano /etc/sysctl.conf

然后,增加 net.ipv4.ip_forward = 1 到文件中,或者删除那行的注释,保存并退出文件。

代码语言:javascript
复制
 net.ipv4.ip_forward = 1
0?wx_fmt=png&tp=webp&wxfrom=5
0?wx_fmt=png&tp=webp&wxfrom=5

运行下面的命令启用更改。

代码语言:javascript
复制
 # sysctl -p /etc/sysctl.conf
0?wx_fmt=png&tp=webp&wxfrom=5
0?wx_fmt=png&tp=webp&wxfrom=5

2. 配置 Iptables 防火墙

我们需要允许特定的(或者所有的)数据包通过我们的路由器。在这之前,我们要知道连接我们 Linux 的网络设备的接口名称。我们可以通过在终端或者 shell 运行以下命令获得接口名称。

代码语言:javascript
复制
 # ifconfig -a
0?wx_fmt=png&tp=webp&wxfrom=5
0?wx_fmt=png&tp=webp&wxfrom=5

这里,在我们的机器中, eth2 是连接到互联网或者网络的网卡接口, wlan2 是我们要使用 iptables 从 eth2 转发数据包的接口。要实现转发,我们需要运行以下命令。

代码语言:javascript
复制
 # iptables -A FORWARD -i wlan2 -o eth2 -j ACCEPT

注意:请用你 Linux 机器中的可用设备名称替换 wlan2 和 eth2。

现在,由于netfilter/iptables是一个无状态的防火墙,我们需要让 iptables 允许已建立的连接通过。要做到这点,我们要运行下面的命令。

代码语言:javascript
复制
 # iptables -A FORWARD -i eth2 -o wlan2 -m state --state ESTABLISHED,RELATED  -j ACCEPT
0?wx_fmt=png&tp=webp&wxfrom=5
0?wx_fmt=png&tp=webp&wxfrom=5

3. 配置 NAT

然后,最后我们需要通过执行下面的命令修改发送到互联网的数据包的源地址为 eth2。

代码语言:javascript
复制
 # iptables -t nat -A POSTROUTING -o eth2 -j MASQUERADE
0?wx_fmt=png&tp=webp&wxfrom=5
0?wx_fmt=png&tp=webp&wxfrom=5

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 启用 IPv4 转发
  • 2. 配置 Iptables 防火墙
  • 3. 配置 NAT
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档