- 论坛徽章:
- 0
|
由于我们实验室本科生来作毕业设计,ip地址不够用,我的suse10就暂时做了一阵子router。
eth0原来的配置如下:
IP: 211.71.6.144
MASK: 255.255.255.192
ROUTER: 211.71.6.192
DNS: 211.71.6.33
DNS: 202.112.128.51
为了使用nat必须给eth0在配置另外一个ip,192.168.3.1/255.255.255.0
在suse10下,使用命令yast2 lan来添加另外一个ip
改写/etc/dhcpd.conf文件如下:
option domain-name "mydhcp";
option domain-name-servers 211.71.6.33, 202.112.128.51;
option routers 192.168.3.1;
ddns-update-style none;
default-lease-time 14400;
subnet 192.168.3.0 netmask 255.255.255.0 {
option broadcast-address 192.168.3.255;
option routers 192.168.3.1;
range 192.168.3.2 192.168.3.254;
default-lease-time 14400;
max-lease-time 172800;
}
启动dhcpd服务(别忘了打开防火墙),然后编写一个脚本nat,内容如下:
!/bin/bash
IPTABLES='/usr/sbin/iptables'
EXTERNAL='eth0'
EXTERNIP='211.71.6.144'
INTERNAL='eth0'
INTERNIP='192.168.3.0/24'
# reset the three default ipchains
$IPTABLES -P INPUT ACCEPT
$IPTABLES -P OUTPUT ACCEPT
$IPTABLES -P FORWARD ACCEPT
# reset the nat talbe
$IPTABLES -t nat -P PREROUTING ACCEPT
$IPTABLES -t nat -P POSTROUTING ACCEPT
$IPTABLES -t nat -P OUTPUT ACCEPT
# flush the ipchains and nat table
$IPTABLES -F
$IPTABLES -F -t nat
# delete non-default rules of ipchains and nat table
$IPTABLES -X
$IPTABLES -t nat -X
#reset zero
$IPTABLES -Z -t nat
$IPTABLES -t nat -Z
#load necessary modules
echo "Starting modprobe necessary modules for iptables"
modprobe ip_tables 1> /dev/null
modprobe ip_nat_ftp 2> /dev/null
modprobe ip_nat_irc 2> /dev/null
modprobe ip_conntrack 2> /dev/null
modprobe ip_conntrack_ftp 2> /dev/null
modprobe ip_conntrack_irc 2> /dev/null
#enable ICMP packet (ping)
$IPTABLES -A INPUT -p icmp -j ACCEPT
#enable communication inside local domain
$IPTABLES -A INPUT -i $INTERNAL -s $INTERNIP -j ACCEPT
$IPTABLES -A OUTPUT -o $INTERNAL -d $INTERNIP -j ACCEPT
#enable ip masquerade
echo "1" >/proc/sys/net/ipv4/ip_forward
$IPTABLES -t nat -A POSTROUTING -o $EXTERNAL -s $INTERNIP -j MASQUERADE
运行该脚本后,配置其他的主机,配置可以参考如下配置:
IP: 192.168.3.2
MASK: 255.255.255.0
ROUTER: 192.168.3.1
DNS: 211.71.6.33
DNS: 202.112.128.51
本文参考了一篇利用vmware共享主机上网的文章和另外一篇利用双网卡配置nat的文章。 |
|