设为首页 收藏本站
查看: 1087|回复: 0

[经验分享] Linux下配置NAT服务器共享上网

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-5-31 12:26:20 | 显示全部楼层 |阅读模式
content:
    0. 本次配置的网络的拓扑结构:
    1. 配置IP地址
    .   1.1 正确配置学校分配的IP使能正常上网
    .   1.2 新增eth0别名设备eth0:0
    .   1.3 配置后 查看一下是否配置成功:
    2. 配置路由
    3. 配置NAT
    4. 大功告成
    5. 配置客户机(可以是windows或linux等其它系统)


0. 本次配置的网络的拓扑结构:
#
#             |
#             |
#     ========+===============
#             |10.3.10.0/24
#             |
#             |
#             |10.3.10.19
#        +----+----+            +-------+        +-------+
#        |         |            |       |        |       |
#        | linux   |            | win1  |        | win2  |
#        | (NAT)   |            |       |        |       |
#        +----+----+            +---+---+        +---+---+
#             |192.168.50.1         |192.168.50.2    |192.168.50.3
#             |                     |                |
#             |                     |                |
#             |                     |                |
#   ==========+=====================+================+============
#                    192.168.50.0/24
#
#


1. 配置IP地址
1.1 正确配置学校分配的IP使能正常上网
1)  按学校分配的IP地址配置好Linux主机
[~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0
| DEVICE=eth0              |
| BOOTPROTO=none           |
| HWADDR=00:1E:90:13:E0:25 |
| IPADDR=10.3.10.19        |
| NETMASK=255.255.255.0    |
| GATEWAY=10.3.10.254      |
| ONBOOT=yes               |
| TYPE=Ethernet            |
| DNS1=211.64.120.2        |
| DEFROUTE=yes             |
| DOMAIN=168.96.1.1        |

2)  重起网卡
[~]# servie network restart

note: 经过以上的配置, Linux主机应该能够正常上网了!

1.2 新增eth0别名设备eth0:0
[~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0:0
| # eth0:0 必须要用''括起来: 'eth0:0' |
| DEVICE='eth0:0'                            |
| ONBOOT=yes                                 |
| BOOTPROTO=static                           |
| IPADDR=192.168.50.1                        |
| NETMASK=255.255.255.0                      |
| USERCTL=no                                 |



1.3 配置后 查看一下是否配置成功:
[~]# ifconfig
| eth0      Link encap:Ethernet  HWaddr 00:1E:90:13:E0:25                     |
|           inet addr:10.3.10.19  Bcast:10.3.10.255  Mask:255.255.255.0       |
|           inet6 addr: fe80::21e:90ff:fe13:e025/64 Scope:Link                |
|           UP BROADCAST RUNNING PROMISC MULTICAST  MTU:1500  Metric:1        |
|           RX packets:187685 errors:0 dropped:0 overruns:0 frame:0           |
|           TX packets:137327 errors:0 dropped:0 overruns:0 carrier:0         |
|           collisions:0 txqueuelen:1000                                      |
|           RX bytes:134816893 (128.5 MiB)  TX bytes:56066393 (53.4 MiB)      |
|           Interrupt:27 Base address:0xa000                                  |

| eth0:0    Link encap:Ethernet  HWaddr 00:1E:90:13:E0:25                     |
|           inet addr:192.168.50.1   Bcast:192.168.50.255  Mask:255.255.255.0 |
|           UP BROADCAST RUNNING PROMISC MULTICAST  MTU:1500  Metric:1        |
|           Interrupt:27 Base address:0xa000                                  |

2. 配置路由
由于在配置网卡接口时, 已自动配置一定的路由, 所以我们只需查看一下其信息, 验证其
是否已经被正确配置:
[root ~]$ route
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
192.168.50.0    *               255.255.255.0   U     0      0        0 eth0
10.3.10.0       *               255.255.255.0   U     1      0        0 eth0
link-local      *               255.255.0.0     U     1002   0        0 eth0
default         10.3.10.254     0.0.0.0         UG    0      0        0 eth0


3. 配置NAT
1)  新建nat.sh脚本文件并保存在 /usr/local/nat/ 目录下:
[~]# cat /usr/local/nat/nat.sh
| #!/bin/bash                                                           |

| # 0. 设定你的参数值                                            |
| EXIF='eth0'           # 这个是对外的网卡接口, 可能是'ppp0'等     |
| EXNET='192.168.50.0/24'       # 这个是对内的网段                    |

| # 底下如无需要, 请不要改动了!                             |
| # 1. 启动routing等                                                 |
| echo 1 > /proc/sys/net/ipv4/ip_forward                              |
| /sbin/iptables -F                                                     |
| /sbin/iptables -X                                                     |
| /sbin/iptables -Z                                                     |
| /sbin/iptables -F -t nat                                              |
| /sbin/iptables -X -t nat                                              |
| /sbin/iptables -Z -t nat                                              |
| /sbin/iptables -P INPUT   ACCEPT                                      |
| /sbin/iptables -P OUTPUT  ACCEPT                                      |
| /sbin/iptables -P FORWARD ACCEPT                                      |
| /sbin/iptables -t nat -P PREROUTING   ACCEPT                            |
| /sbin/iptables -t nat -P POSTROUTING  ACCEPT                           |
| /sbin/iptables -t nat -P OUTPUT       ACCEPT                                |

| # 2. 载入模组                                                     |
| /sbin/modprobe ip_tables 2> /dev/null                                 |
| /sbin/modprobe ip_nat_ftp 2> /dev/null                                |
| /sbin/modprobe ip_nat_irc 2> /dev/null                                |
| /sbin/modprobe ip_conntrack 2> /dev/null                              |
| /sbin/modprobe ip_conntrack_ftp 2> /dev/null                          |
| /sbin/modprobe ip_conntrack_irc 2> /dev/null                          |

| # 3. 启动ip伪装                                                   |
| /sbin/iptables -t nat -A POSTROUTING -o $EXIF -s $EXNET -j MASQUERADE |

2)  增加可执行权限
[~]# chmod +x /usr/local/nat/nat.sh

4. 大功告成
1)  Linux主机配置完成, 现在只需重新启动一下刚才的配置:
[~]# servie network restart
[~]# /usr/local/nat/nat.sh

2)  为了使得开机即可运行, 可在 /etc/rc.d/rc.local 文件加入相应的命令:
[~]# echo "/usr/local/nat/nat.sh" >> /etc/rc.d/rc.local

5. 配置客户机(可以是windows或linux等其它系统)
    1. network 设定需要为:  192.168.50.0

    2. broadcast 设定需要为:  192.168.50.255

    3. netmask 设定需要为 255.255.255.0

    4. IP 设定需要为 192.168.50.1 ~ 192.168.50.254 之一, 且『不能重复』

    5. Gateway 或者要设定为你的 Linux 的对内 IP , 以我的例子来说, 就是
    192.168.50.1

    6. DNS 的设定: 这个最容易出错了, 你的 DNS 设定需要是你的 ISP 给你的 DNS
    IP, 如果你不知道的话, 可以填入 168.95.1.1 这一个中华电信的 DNS 或者是
    139.175.10.20 这一个 SeedNet 的 DNS 即可!千万不要设定为 192.168.1.2 呦!会
    连不出去!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-224457-1-1.html 上篇帖子: Linux的时间同步到时间服务器 下篇帖子: CentOS安装python包安装管理工具pip 共享上网 服务器 Linux
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表