wozijisunfly 2010-01-14
传统的在1--3点,ip高级路由命令在4--12点,两者部分可以通用,并达到同样的目的,但ip的功能更强大,可以实现更多的配置目的。
首先,先了解传统的网络配置命令:
1.使用ifconfig命令配置并查看网络接口情况
示例1:配置eth0的IP,同时激活设备:
#ifconfigeth0192.168.4.1netmask255.255.255.0up
示例2:配置eth0别名设备eth0:1的IP,并添加路由
#ifconfigeth0:1192.168.4.2
#routeadd–host192.168.4.2deveth0:1
示例3:激活(禁用)设备
#ifconfigeth0:1up(down)
示例4:查看所有(指定)网络接口配置
#ifconfig(eth0)
2.使用route命令配置路由表
示例1:添加到主机路由
#routeadd–host192.168.4.2deveth0:1
#routeadd–host192.168.4.1gw192.168.4.250
示例2:添加到网络的路由
#routeadd–netIPnetmaskMASKeth0
#routeadd–netIPnetmaskMASKgwIP
#routeadd–netIP/24eth1
示例3:添加默认网关
#routeadddefaultgwIP
示例4:删除路由
#routedel–host192.168.4.1deveth0:1
示例5:查看路由信息
#route或route-n(-n表示不解析名字,列出速度会比route快)
3.ARP管理命令
示例1:查看ARP缓存
#arp
示例2:添加
#arp–sIPMAC
示例3:删除
#arp–dIP
4.ip是iproute2软件包里面的一个强大的网络配置工具,它能够替代一些传统的网络管理工具。例如:ifconfig、route等,
上面的示例完全可以用下面的ip命令实现,而且ip命令可以实现更多的功能.下面介绍一些示例:
4.0ip命令的语法
ip[OPTIONS]OBJECT[COMMAND[ARGUMENTS]]
4.1iplinkset--改变设备的属性.缩写:set、s
示例1:up/down起动/关闭设备。
#iplinksetdeveth0up
这个等于传统的#ifconfigeth0up(down)
示例2:改变设备传输队列的长度。
参数:txqueuelenNUMBER或者txqlenNUMBER
#iplinksetdeveth0txqueuelen100
示例3:改变网络设备MTU(最大传输单元)的值。
#iplinksetdeveth0mtu1500
示例4:修改网络设备的MAC地址。
参数:addressLLADDRESS
#iplinksetdeveth0address00:01:4f:00:15:f1
4.2iplinkshow--显示设备属性.缩写:show、list、lst、sh、ls、l
-s选项出现两次或者更多次,ip会输出更为详细的错误信息统计。
示例:
#ip-s-slinklseth0
eth0: mtu1500qdisccbqqlen100
link/ether00:a0:cc:66:18:78brdff:ff:ff:ff:ff:ff
RX:bytes packets errors droppedoverrunmcast
244994936227861870000
RXerrors:lengthcrcframefifomissed
00000
TX:bytes packetserrorsdroppedcarriercollsns
178558497 1783946332033235172
TXerrors:abortedfifowindowheartbeat
000332
这个命令等于传统的ifconfigeth0
5.1ipaddressadd--添加一个新的协议地址.缩写:add、a
示例1:为每个地址设置一个字符串作为标签。为了和Linux-2.0的网络别名兼容,这个字符串必须以设备名开头,接着一个冒号,
#ipaddraddlocal192.168.4.1/28brd+labeleth0:1deveth0
示例2:在以太网接口eth0上增加一个地址192.168.20.0,掩码长度为24位(155.155.155.0),标准广播地址,标签为eth0:Alias:
#ipaddradd192.168.4.2/24brd+deveth1labeleth1:1
这个命令等于传统的:ifconfigeth1:1192.168.4.2
5.2ipaddressdelete--删除一个协议地址.缩写:delete、del、d
#ipaddrdel192.168.4.1/24brd+deveth0labeleth0:Alias1
5.3ipaddressshow--显示协议地址.缩写:show、list、lst、sh、ls、l
#ipaddrlseth0
5.4.ipaddressflush--清除协议地址.缩写:flush、f
示例1:删除属于私网10.0.0.0/8的所有地址:
#ip-s-safto10/8
示例2:取消所有以太网卡的IP地址
#ip-4addrflushlabel"eth0"
6.ipneighbour--neighbour/arp表管理命令
缩写neighbour、neighbor、neigh、n
命令add、change、replace、delete、fulsh、show(或者list)
6.1ipneighbouradd--添加一个新的邻接条目
ipneighbourchange--修改一个现有的条目
ipneighbourreplace--替换一个已有的条目
缩写:add、a;change、chg;replace、repl
示例1:在设备eth0上,为地址10.0.0.3添加一个permanentARP条目:
#ipneighadd10.0.0.3lladdr0:0:0:0:0:1deveth0nudperm
示例2:把状态改为reachable
#ipneighchg10.0.0.3deveth0nudreachable
6.2.ipneighbourdelete--删除一个邻接条目
示例1:删除设备eth0上的一个ARP条目10.0.0.3
#ipneighdel10.0.0.3deveth0
6.3.ipneighbourshow--显示网络邻居的信息.缩写:show、list、sh、ls
示例1:#ip-snls193.233.7.254
193.233.7.254.deveth0lladdr00:00:0c:76:3f:85ref5used12/13/20nudreachable
6.4.ipneighbourflush--清除邻接条目.缩写:flush、f
示例1:(-s可以显示详细信息)
#ip-s-snf193.233.7.254
7.路由表管理
7.1.缩写route、ro、r
7.5.路由表
从Linux-2.2开始,内核把路由归纳到许多路由表中,这些表都进行了编号,编号数字的范围是1到255。另外,
为了方便,还可以在/etc/iproute2/rt_tables中为路由表命名。
默认情况下,所有的路由都会被插入到表main(编号254)中。在进行路由查询时,内核只使用路由表main。
7.6.iprouteadd--添加新路由
iproutechange--修改路由
iproutereplace--替换已有的路由
缩写:add、a;change、chg;replace、repl
示例1:设置到网络10.0.0/24的路由经过网关193.233.7.65
#iprouteadd10.0.0/24via193.233.7.65
示例2:修改到网络10.0.0/24的直接路由,使其经过设备dummy
#iproutechg10.0.0/24devdummy
示例3:实现链路负载平衡.加入缺省多路径路由,让ppp0和ppp1分担负载(注意:scope值并非必需,它只不过是告诉内核,这个路由要经过网关而不是直连的。实际上,如果你知道远程端点的地址,使用via参数来设置就更好了)。
#iprouteadddefaultscopeglobalnexthopdevppp0nexthopdevppp1
#iproutereplacedefaultscopeglobalnexthopdevppp0nexthopdevppp1
示例4:设置NAT路由。在转发来自192.203.80.144的数据包之前,先进行网络地址转换,把这个地址转换为193.233.7.83
#iprouteaddnat192.203.80.142via193.233.7.83
示例5:实现数据包级负载平衡,允许把数据包随机从多个路由发出。weight可以设置权重.
#iproutereplacedefaultequalizenexthopvia211.139.218.145deveth0weight1nexthopvia211.139.218.145deveth1weight1
7.7.iproutedelete--删除路由
缩写:delete、del、d
示例1:删除上一节命令加入的多路径路由
#iproutedeldefaultscopeglobalnexthopdevppp0nexthopdevppp1
7.8.iprouteshow--列出路由
缩写:show、list、sh、ls、l
示例1:计算使用gated/bgp协议的路由个数
#iproutelsprotogated/bgp wc
1413989179010
示例2:计算路由缓存里面的条数,由于被缓存路由的属性可能大于一行,以此需要使用-o选项
#ip-oroutelscloned wc
159254318707
示例3:列出路由表TABLEID里面的路由。缺省设置是tablemain。TABLEID或者是一个真正的路由表ID或者是/etc/iproute2/rt_tables文件定义的字符串,
或者是以下的特殊值:
all--列出所有表的路由;
cache--列出路由缓存的内容。
iprols193.233.7.82tabcache
示例4:列出某个路由表的内容
#iproutelstablefddi153
示例5:列出默认路由表的内容
#iproutels
这个命令等于传统的:route
7.9.iprouteflush--擦除路由表
示例1:删除路由表main中的所有网关路由(示例:在路由监控程序挂掉之后):
#ip-4roflushscopeglobaltypeunicast
示例2:清除所有被克隆出来的IPv6路由:
#ip-6-s-sroflushcache
示例3:在gated程序挂掉之后,清除所有的BGP路由:
#ip-srofprotogated/bgp
示例4:清除所有ipv4路由cache
#iprouteflushcache
***IPv4routingcacheisflushed.
7.10iprouteget--获得单个路由.缩写:get、g
使用这个命令可以获得到达目的地址的一个路由以及它的确切内容。
iprouteget命令和iprouteshow命令执行的操作是不同的。iprouteshow命令只是显示现有的路由,而iprouteget命令在必要时会派生出新的路由。
示例1:搜索到193.233.7.82的路由
#iprouteget193.233.7.82
193.233.7.82deveth0src193.233.7.65realmsinr.accachemtu1500rtt300
示例2:搜索目的地址是193.233.7.82,来自193.233.7.82,从eth0设备到达的路由(这条命令会产生一条非常有意思的路由,这是一条到193.233.7.82的回环路由)
#iprg193.233.7.82from193.233.7.82iifeth0
193.233.7.82from193.233.7.82deveth0src193.233.7.65realmsinr.ac/inr.ac
cache;mtu1500rtt300iifeth0
8.iproute--路由策略数据库管理命令
命令 add、delete、show(或者list)
注意:策略路由(policyrouting)不等于路由策略(rouingpolicy)。
在某些情况下,我们不只是需要通过数据包的目的地址决定路由,可能还需要通过其他一些域:源地址、IP协议、传输层端口甚至数据包的负载。
这就叫做:策略路由(policyrouting)。
8.5.ipruleadd--插入新的规则
ipruledelete--删除规则
缩写:add、a;delete、del、d
示例1:通过路由表inr.ruhep路由来自源地址为192.203.80/24的数据包
ipruaddfrom192.203.80/24tableinr.ruhepprio220
示例2:把源地址为193.233.7.83的数据报的源地址转换为192.203.80.144,并通过表1进行路由
ipruaddfrom193.233.7.83nat192.203.80.144table1prio320
示例3:删除无用的缺省规则
iprudelprio32767
8.7.ipruleshow--列出路由规则
缩写:show、list、sh、ls、l
示例1:#ipruls
0:fromalllookuplocal
32762:from192.168.4.89lookupfddi153
32764:from192.168.4.88lookupfddi153
32766:fromalllookupmain
32767:fromalllookup253
9.ipmaddress--多播地址管理
缩写:show、list、sh、ls、l
9.3.ipmaddressshow--列出多播地址
示例1:#ipmaddrlsdummy
9.4.ipmaddressadd--加入多播地址
ipmaddressdelete--删除多播地址
缩写:add、a;delete、del、d
使用这两个命令,我们可以添加/删除在网络接口上监听的链路层多播地址。这个命令只能管理链路层地址。
示例1:增加#ipmaddradd33:33:00:00:00:01devdummy
示例2:查看#ip-Omaddrlsdummy
2:dummy
link33:33:00:00:00:01users2static
link01:00:5e:00:00:01
示例3:删除#ipmaddrdel33:33:00:00:00:01devdummy
10.ipmroute--多播路由缓存管理
10.4.ipmrouteshow--列出多播路由缓存条目
缩写:show、list、sh、ls、l
示例1:查看#ipmroutels
(193.232.127.6,224.0.1.39)Iif:unresolved
(193.232.244.34,224.0.1.40)Iif:unresolved
(193.233.7.65,224.66.66.66)Iif:eth0Oifs:pimreg
示例2:查看#ip-smrls224.66/16
(193.233.7.65,224.66.66.66)Iif:eth0Oifs:pimreg
9383packets,300256bytes
11.iptunnel--通道配置
缩写 tunnel、tunl
11.4.iptunneladd--添加新的通道
iptunnelchange--修改现有的通道
iptunneldelete--删除一个通道
缩写:add、a;change、chg;delete、del、d
示例1:建立一个点对点通道,最大TTL是32
#iptunneladdCiscomodesitremote192.31.7.104local192.203.80.1ttl32
11.4.iptunnelshow--列出现有的通道
缩写:show、list、sh、ls、l
示例1:#ip-stunllsCisco
12.ipmonitor和rtmon--状态监视
ip命令可以用于连续地监视设备、地址和路由的状态。这个命令选项的格式有点不同,命令选项的名字叫做monitor,接着是操作对象:
ipmonitor[fileFILE][all OBJECT-LIST]
示例1:#rtmonfile/var/log/rtmon.log
示例2:#ipmonitorfile/var/log/rtmon.logr