Linux之命令改ip

从8.10开始,系统配置ip就比较复杂。原因是有个network-manager 管理软件来管理ip,虽使ip配置简单化了,但不是有效的配置。来自底层的配置才是王道。

   

首先需要删除network-manager

sudo apt-get remove network-manager

 

其次   

下面用命令配置ip。

首先,必须弄清楚,我们设置的ip,都是存储在一个文件里。DNS,存储在另一个文件里。

ip存储在/etc/network/interfaces 里,就是interfaces 文件中记录着ip地址和网卡信息。

DNS存储在/etc/resolv.conf里,resolv.conf记录着DNS信息。

第一步,打开ip存储文件interfaces

下面打开终端输入

sudo gedit /etc/network/interfaces 

会弹出如下对话框

显示内容(#后面是添加的注释)如下:

auto lo   #lo接口在系统启动时自动配置

iface lo inet loopback  #lo接口设置为本地环路地##址   相当于127.0.0.1

iface eth0 inet static #使用第一块网卡,静态ip

address 172.31.65.110  #这是ip 地址

netmask 255.255.0.0   #掩码

gateway 172.31.65.1   #网关

auto eth0   #eth0接口在系统启动时自动配置

第二步,在终端中输入

gedit /etc/resolv.conf

弹出对话框

显示内容

### BEGIN INFO

#

# Modified_by:  NetworkManager

# Process:      /usr/bin/NetworkManager

# Process_id:   5045

#

### END INFO

search private

nameserver 202.102.154.3   #DNS

nameserver 202.102.128.68  #DNS

第三步,重启网卡驱动

sudo /etc/init.d/networking restart

参考网址:

http://forum.ubuntu.org.cn/viewtopic.php?f=116&t=189121

http://bbs.51cto.com/archiver/tid-364220.html

http://study.qqcf.com/web/109/13022.htm

http://blog.chinaunix.net/u3/111961/showart_2190115.html

这样就没有问题了

 

 

如果你之前没有删除NetworkManager网络管理的话,重启后/etc/resolv.conf里面的配置文件又会被修改为

# Generated by NetworkManager

        导致又是使用DHCP动态分配IP地址的。

 

 

上面讲解了配置ip和dns。有兴趣的,可以阅读下面的内容。

1,关于配置interfaces

话说Debian系的网卡配置跟Redhat系很不一样,Redhat是放在/etc/sysconfig/network-scripts目录下 面的一大堆文件里面,要修改?你一个一个文件来过吧。Debian系的则是存在/etc/network/interfaces文件里面,无论有多少块网 卡,统统扔在这个文件里。下面就来看一下这个文件的内容。

首先,一个基本的配置大概是下面这个样子:

  1 auto lo

  2 iface lo inet loopback

  3 

  4 # The primary network interface

  5 auto eth0

  6 iface eth0 inet static

  7      address 192.168.0.42

  8      network 192.168.0.0

  9      netmask 255.255.255.0

 10      broadcast 192.168.0.255

 11      gateway 192.168.0.1

上面的配置中,

1行跟第5行说明lo接口跟eth0接口会在系统启动时被自动配置;

2行将lo接口设置为一个本地回环(loopback)地址;

6行指出eth0接口具有一个静态的(staticIP配置;

7-11行分别设置eth0接口的ip、网络号、掩码、广播地址和网关。

再来看一个更复杂点的:

 12 auto eth0

 13 iface eth0 inet static

 14     address 192.168.1.42

 15     network 192.168.1.0

 17     netmask 255.255.255.128

 18     broadcast 192.168.1.0

 19     up route add -net 192.168.1.128 netmask 255.255.255.128 gw 192.168.1.2

 20     up route add default gw 192.168.1.200

 21     down route del default gw 192.168.1.200

 22     down route del -net 192.168.1.128 netmask 255.255.255.128 gw 192.168.1.2

这次,有了一个复杂一些的掩码,和一个比较奇怪的广播地址。还有就是增加的接口启用、禁用时的路由设置;

19行和20行配置的左右是在接口启用的时候,添加一条静态路由和一个缺省路由;

21行和22行会在接口禁用的时候,删掉这两条路由配置。

至于配置路由的写法,仔细看,它就是route命令嘛。

继续,下面是一个物理网卡上多个接口的配置方法:

 23 auto eth0 eth0:1

 24 iface eth0 inet static

 25     address 192.168.0.100

 26     network 192.168.0.0

 27     netmask 255.255.255.0

 28     broadcast 192.168.0.255

 29     gateway 192.168.0.1

 30 iface eth0:1 inet static

 31     address 192.168.0.200

 32     network 192.168.0.0

 33     netmask 255.255.255.0

30行到33行在eth0上配置了另外一个地址,这种配置方法在配置一块网卡多个地址的时候很常见:有几个地址就配置几个接口。冒号后面的数字可以随便写的,只要几个配置的名字不重复就可以。

下面是pre-uppost-down命令时间。这是一组命令(pre-upuppost-uppre-downdownpost-down),分别定义在对应的时刻需要执行的命令。

 34 auto eth0

 35 iface eth0 inet dhcp

 36     pre-up [ -f /etc/network/local-network-ok ]

36行会在激活eth0之前检查/etc/network/local-network-ok文件是否存在,如果不存在,则不会激活eth0

再更进一步的例子:

 37 auto eth0 eth1

 38 iface eth0 inet static

 39     address 192.168.42.1

 40     netmask 255.255.255.0

 41     pre-up /path/to/check-mac-address.sh eth0 11:22:33:44:55:66

 42     pre-up /usr/local/sbin/enable-masq

 43 iface eth1 inet dhcp

 44     pre-up /path/to/check-mac-address.sh eth1 AA:BB:CC:DD:EE:FF

 45     pre-up /usr/local/sbin/firewall

41行和第44行中,check-mac-address.sh放在/usr/share/doc/ifupdown/examples/目录 中,使用的时候需要给它加上可执行权限。这两行命令会检测两块网卡的MAC地址是否为11:22:33:44:55:66和 AA:BB:CC:DD:EE:FF,如果正确,则启用网卡。如果MAC地址错误,就不会启用这两块网卡。

42行和第45行是假定在这两块网卡上分别执行的命令,你可以把它们替换成你想要的任何玩意 :)

手册上说,这种方法主要是用来检测两块网卡的MAC地址交换(If their MAC addresses get swapped),其实就是两块网卡名互换了,这种情况在debian系统上再常见不过了,主要是因为内核识别网卡的顺序发生了变化。这个问题可以用下面 的这种方法来避免。

46 auto eth0 eth1

47 mapping eth0 eth1

48     script /path/to/get-mac-address.sh

49     map 11:22:33:44:55:66 lan

50     map AA:BB:CC:DD:EE:FF internet

51 iface lan inet static

52     address 192.168.42.1

53     netmask 255.255.255.0

54     pre-up /usr/local/sbin/enable-masq $IFACE

55 iface internet inet dhcp

56     pre-up /usr/local/sbin/firewall $IFACE

48行中的get-mac-address.sh也在/usr/share/doc/ifupdown/examples/目录里,也同样要加可执行权限。这个脚本的作用,就是获得每块网卡的MAC地址。

这段配置首先配置了两个逻辑接口(这个名词的定义请参见debian参考手册laninternet,然后根据网卡的MAC地址,将逻辑接口映射(mapped)到物理接口上去。

再来看下面这段配置:

57 auto eth0 58 iface eth0 inet manual 59  up ifconfig $IFACE 0.0.0.0 up 60  up /usr/local/bin/myconfigscript 61  down ifconfig $IFACE down 

这段配置只是启用一个网卡,但是ifupdown不对这个网卡设置任何ip,而是由外部程序来设置ip

最后一段配置,这段配置启用了网卡的混杂模式,用来当监听接口。

177 auto eth0

178 iface eth0 inet manual

179     up ifconfig $IFACE 0.0.0.0 up

180       up ip link set $IFACE promisc on

181       down ip link set $IFACE promisc off

182       down ifconfig $IFACE down

文章源自:

http://gfrog.net/2008/01/config-file-in-debian-interfaces-1/

因为Ubuntu系统基于Debian内核,所以配置方法与debian相似,感兴趣可以看:

有关ip配置文件(interfaces)

http://www.gz-benet.com.cn/study/HTML/study_13845.html

http://www.lslnet.com/linux/dosc1/46/linux-316793.htm

http://debian.banma.com/news/20070921/7830.shtml

2,关于配置resolv.conf

文件/etc/resolv.conf配置DNS客户,它包含了主机的域名搜索顺序和DNS服务器的地址,每一行应包含一个关键字和一个或多个的由空格隔开的参数。下面是一个例子文件: 

  search mydom.edu.cn
  nameserver 210.34.0.14
  nameserver 210.34.0.2

  合法的参数及其意义如下:

  nameserver 表明DNS服务器的IP地址。可以有很多行的nameserver,每一个带一个IP地址。在查询时就按nameserver在本文件中的顺序进行,且只有当第一个nameserver没有反应时才查询下面的nameserver。 

  domain   声明主机的域名。很多程序用到它,如邮件系统;当为没有域名的主机进行DNS查询时,也要用到。如果没有域名,主机名将被使用,删除所有在第一个点( .)前面的内容。 

  search   它的多个参数指明域名查询顺序。当要查询没有域名的主机,主机将在由search声明的域中分别查找。domain和search不能共存;如果同时存在,后面出现的将会被使用。 

  sortlist  允许将得到域名结果进行特定的排序。它的参数为网络/掩码对,允许任意的排列顺序。 

  Red Hat中没有提供缺省的/etc/resolv.conf文件,它的内容是根据在安装时给出的选项动态创建的。

有关DNS配置文件(resolv.conf),感兴趣可以看

http://blog.chinaunix.net/u2/60589/showart_1423592.html

 

声明:本文档可以随意更改,但必须署名原作者

                    

作者:凤凰舞者 qq:578989855

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值