net-tools和iproute2的命令做对比,做到简单明了,分别演示如何去获取、配置和操作系统网络信息。
以下是net-tools和iproute2的大致对比:

4.1 ip link set--改变设备的属性. 缩写:set、s

  示例1:up/down 起动/关闭设备。

  # ip link set dev eth0 up

  这个等于传统的 # ifconfig eth0 up(down)

  示例2:改变设备传输队列的长度。

  参数:txqueuelen NUMBER或者txqlen NUMBER

  # ip link set dev eth0 txqueuelen 100

  示例3:改变网络设备MTU(最大传输单元)的值。

  # ip link set dev eth0 mtu 1500

  示例4: 修改网络设备的MAC地址。

  参数: address LLADDRESS

  # ip link set dev eth0 address 00:01:4f:00:15:f1

  4.2 ip link show--显示设备属性. 缩写:show、list、lst、sh、ls、l

  -s选项出现两次或者更多次,ip会输出更为详细的错误信息统计。

  示例:

  # ip -s -s link ls eth0

  eth0: mtu 1500 qdisc cbq qlen 100

  link/ether 00:a0:cc:66:18:78 brd ff:ff:ff:ff:ff:ff

  RX: bytes packets errors dropped overrun mcast

  2449949362 2786187 0 0 0 0

  RX errors: length crc frame fifo missed

  0 0 0 0 0

  TX: bytes packets errors dropped carrier collsns

  178558497 1783946 332 0 332 35172

  TX errors: aborted fifo window heartbeat

  0 0 0 332

  这个命令等于传统的 ifconfig eth0

  5.1 ip address add--添加一个新的协议地址. 缩写:add、a

  示例1:为每个地址设置一个字符串作为标签。为了和Linux-2.0的网络别名兼容,这个字符串必须以设备名开头,接着一个冒号,

  # ip addr add local 192.168.4.1/28 brd + label eth0:1 dev eth0

  示例2: 在以太网接口eth0上增加一个地址192.168.20.0,掩码长度为24位(155.155.155.0),标准广播地址,标签为eth0:Alias:

  # ip addr add 192.168.4.2/24 brd + dev eth1 label eth1:1

  这个命令等于传统的: ifconfig eth1:1 192.168.4.2

  5.2 ip address delete--删除一个协议地址. 缩写:delete、del、d

  # ip addr del 192.168.4.1/24 brd + dev eth0 label eth0:Alias1

  5.3 ip address show--显示协议地址. 缩写:show、list、lst、sh、ls、l

  # ip addr ls eth0

  5.4.ip address flush--清除协议地址. 缩写:flush、f

  示例1 : 删除属于私网10.0.0.0/8的所有地址:

  # ip -s -s a f to 10/8

  示例2 : 取消所有以太网卡的IP地址

  # ip -4 addr flush label "eth0"

  6. ip neighbour--neighbour/arp表管理命令

  缩写 neighbour、neighbor、neigh、n

  命令 add、change、replace、delete、fulsh、show(或者list)

  6.1 ip neighbour add -- 添加一个新的邻接条目

  ip neighbour change--修改一个现有的条目

  ip neighbour replace--替换一个已有的条目

  缩写:add、a;change、chg;replace、repl

  示例1: 在设备eth0上,为地址10.0.0.3添加一个permanent ARP条目:

  # ip neigh add 10.0.0.3 lladdr 0:0:0:0:0:1 dev eth0 nud perm

  示例2:把状态改为reachable

  # ip neigh chg 10.0.0.3 dev eth0 nud reachable

  6.2.ip neighbour delete--删除一个邻接条目

  示例1:删除设备eth0上的一个ARP条目10.0.0.3

  # ip neigh del 10.0.0.3 dev eth0

  6.3.ip neighbour show--显示网络邻居的信息. 缩写:show、list、sh、ls

  示例1: # ip -s n ls 193.233.7.254

  193.233.7.254. dev eth0 lladdr 00:00:0c:76:3f:85 ref 5 used 12/13/20 nud reachable

  6.4.ip neighbour flush--清除邻接条目. 缩写:flush、f

  示例1: (-s 可以显示详细信息)

  # ip -s -s n f 193.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.ip route add -- 添加新路由

  ip route change -- 修改路由

  ip route replace -- 替换已有的路由

  缩写:add、a;change、chg;replace、repl

  示例1: 设置到网络10.0.0/24的路由经过网关193.233.7.65

  # ip route add 10.0.0/24 via 193.233.7.65

  示例2: 修改到网络10.0.0/24的直接路由,使其经过设备dummy

  # ip route chg 10.0.0/24 dev dummy

  示例3: 实现链路负载平衡.加入缺省多路径路由,让ppp0和ppp1分担负载(注意:scope值并非必需,它只不过是告诉内核,

  这个路由要经过网关而不是直连的。实际上,如果你知道远程端点的地址,使用via参数来设置就更好了)。

  # ip route add default scope global nexthop dev ppp0 nexthop dev ppp1

  # ip route replace default scope global nexthop dev ppp0 nexthop dev ppp1

  示例4: 设置NAT路由。在转发来自192.203.80.144的数据包之前,先进行网络地址转换,把这个地址转换为193.233.7.83

  # ip route add nat 192.203.80.142 via 193.233.7.83

  示例5: 实现数据包级负载平衡,允许把数据包随机从多个路由发出。weight 可以设置权重.

  # ip route replace default equalize nexthop via 211.139.218.145 dev eth0 weight 1 nexthop via 211.139.218.145 dev eth1 weight 1

  7.7.ip route delete-- 删除路由

  缩写:delete、del、d

  示例1:删除上一节命令加入的多路径路由

  # ip route del default scope global nexthop dev ppp0 nexthop dev ppp1

  7.8.ip route show -- 列出路由

  缩写:show、list、sh、ls、l

  示例1: 计算使用gated/bgp协议的路由个数

  # ip route ls proto gated/bgp |wc

  1413 9891 79010

  示例2: 计算路由缓存里面的条数,由于被缓存路由的属性可能大于一行,以此需要使用-o选项

  # ip -o route ls cloned |wc

  159 2543 18707

  示例3: 列出路由表TABLEID里面的路由。缺省设置是table main。TABLEID或者是一个真正的路由表ID或者是/etc/iproute2/rt_tables文件定义的字符串,

  或者是以下的特殊值:

  all -- 列出所有表的路由;

  cache -- 列出路由缓存的内容。

  ip ro ls 193.233.7.82 tab cache

  示例4: 列出某个路由表的内容

  # ip route ls table fddi153

  示例5: 列出默认路由表的内容

  # ip route ls

  这个命令等于传统的: route

  7.9.ip route flush -- 擦除路由表

  示例1: 删除路由表main中的所有网关路由(示例:在路由监控程序挂掉之后):

  # ip -4 ro flush scope global type unicast

  示例2:清除所有被克隆出来的IPv6路由:

  # ip -6 -s -s ro flush cache

  示例3: 在gated程序挂掉之后,清除所有的BGP路由:

  # ip -s ro f proto gated/bgp

  示例4: 清除所有ipv4路由cache

  # ip route flush cache

  *** IPv4 routing cache is flushed.

  7.10 ip route get -- 获得单个路由 .缩写:get、g

  使用这个命令可以获得到达目的地址的一个路由以及它的确切内容。

  ip route get命令和ip route show命令执行的操作是不同的。ip route show命令只是显示现有的路由,而ip route get命令在必要时会派生出新的路由。

  示例1: 搜索到193.233.7.82的路由

  # ip route get 193.233.7.82

  193.233.7.82 dev eth0 src 193.233.7.65 realms inr.ac cache mtu 1500 rtt 300

  示例2: 搜索目的地址是193.233.7.82,来自193.233.7.82,从eth0设备到达的路由(这条命令会产生一条非常有意思的路由,这是一条到193.233.7.82的回环路由)

  # ip r g 193.233.7.82 from 193.233.7.82 iif eth0

  193.233.7.82 from 193.233.7.82 dev eth0 src 193.233.7.65 realms inr.ac/inr.ac

  cache <src-direct,redirect> mtu 1500 rtt 300 iif eth0

  8. ip route -- 路由策略数据库管理命令

  命令

  add、delete、show(或者list)

  注意:策略路由(policy routing)不等于路由策略(rouing policy)。

  在某些情况下,我们不只是需要通过数据包的目的地址决定路由,可能还需要通过其他一些域:源地址、IP协议、传输层端口甚至数据包的负载。

  这就叫做:策略路由(policy routing)。

  8.5. ip rule add -- 插入新的规则

  ip rule delete -- 删除规则

  缩写:add、a;delete、del、d

  示例1: 通过路由表inr.ruhep路由来自源地址为192.203.80/24的数据包

  ip ru add from 192.203.80/24 table inr.ruhep prio 220

  示例2:把源地址为193.233.7.83的数据报的源地址转换为192.203.80.144,并通过表1进行路由

  ip ru add from 193.233.7.83 nat 192.203.80.144 table 1 prio 320

  示例3:删除无用的缺省规则

  ip ru del prio 32767

  8.7. ip rule show -- 列出路由规则

  缩写:show、list、sh、ls、l

  示例1: # ip ru ls

  0: from all lookup local

  32762: from 192.168.4.89 lookup fddi153

  32764: from 192.168.4.88 lookup fddi153

  32766: from all lookup main

  32767: from all lookup 253

  9. ip maddress -- 多播地址管理

  缩写:show、list、sh、ls、l

  9.3.ip maddress show -- 列出多播地址

  示例1: # ip maddr ls dummy

  9.4. ip maddress add -- 加入多播地址

  ip maddress delete -- 删除多播地址

  缩写:add、a;delete、del、d

  使用这两个命令,我们可以添加/删除在网络接口上监听的链路层多播地址。这个命令只能管理链路层地址。

  示例1: 增加 # ip maddr add 33:33:00:00:00:01 dev dummy

  示例2: 查看 # ip -O maddr ls dummy

  2: dummy

  link 33:33:00:00:00:01 users 2 static

  link 01:00:5e:00:00:01

  示例3: 删除 # ip maddr del 33:33:00:00:00:01 dev dummy

  10.ip mroute -- 多播路由缓存管理

  10.4. ip mroute show -- 列出多播路由缓存条目

  缩写:show、list、sh、ls、l

  示例1:查看 # ip mroute ls

  (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: eth0 Oifs: pimreg

  示例2:查看 # ip -s mr ls 224.66/16

  (193.233.7.65, 224.66.66.66) Iif: eth0 Oifs: pimreg

  9383 packets, 300256 bytes

  11. ip tunnel -- 通道配置

  缩写

  tunnel、tunl

  11.4.ip tunnel add -- 添加新的通道

  ip tunnel change -- 修改现有的通道

  ip tunnel delete -- 删除一个通道

  缩写:add、a;change、chg;delete、del、d

  示例1:建立一个点对点通道,最大TTL是32

  # ip tunnel add Cisco mode sit remote 192.31.7.104 local 192.203.80.1 ttl 32

  11.4.ip tunnel show -- 列出现有的通道

  缩写:show、list、sh、ls、l

  示例1: # ip -s tunl ls Cisco

  12. ip monitor和rtmon -- 状态监视

  ip命令可以用于连续地监视设备、地址和路由的状态。这个命令选项的格式有点不同,命令选项的名字叫做monitor,接着是操作对象:

  ip monitor [ file FILE ] [ all | OBJECT-LIST ]

  示例1: # rtmon file /var/log/rtmon.log

  示例2: # ip monitor file /var/log/rtmon.log r

ip iproute2的典型应用的更多相关文章

  1. linux网络工具iproute2的使用简介

    一.写本文的目的 本文完全是自己在学习iproute2的过程中搜集的大杂烩,记录在这里,方便以后自己查询学习,图片都是来自网络,在此表示感谢! 二.简单了解iproute2工具套装 iproute2是 ...

  2. linux包之iproute之ip命令

    [root@localhost ~]# rpm -qf /sbin/ipiproute-2.6.32-31.el6.x86_64ip 是个命令, ip 命令的功能很多!基本上它整合了 ifconfig ...

  3. 从ip addr add和ifconfig的区别看linux网卡ip地址的结构

    今天一个老外在邮件列表上问了一个问题,就是ip addr add和ifconfig的区别,我给他进行了解答,可能因为英语不好吧,解答的很简单,因此我还是要在这里详细说明一下.其实它们之间没有什么区别, ...

  4. 第6章 TCP/IP路由协议故障处理

    第6章 TCP/IP路由协议故障处理 一.缺省网关 当包的目的地址不在路由器的路由表中,如路由器配置了缺省网关,则转发到缺省网关,否则就丢弃. Show ip route :查看Cisco路由器的缺省 ...

  5. 二十、网络ifconfig 、ip 、netstat、ss之二

    ip 网络层协议 ip地址 点分十进制分为4段,范围 0-255 ip分类 A 占据1段,最左侧一段第一位固定为0 0 000 0000 - 0 111 1111  0 - 127:其中0为网络,12 ...

  6. TCP/IP协议基本知识

    1.TCP/IP协议中主机与主机之间通信的三要素: IP地址(IP address) 子网掩码(subnet mask) IP路由(IP router) 2.IP地址的分类及每一类的范围: A类1-1 ...

  7. Linux--网络基础(概念+协议的了解+OSI七层模型,TCP/IP五层协议,网络数据传输流程)

    网络的发展 网络的发展有下面几个阶段: 独立模式:计算机最开始是以单机模式被广泛使用的.每一台计算机都是独立的,之间不能够进行数据共享与通信 网络互联: 计算机之间可以链接在一起,完成数据共享,计算机 ...

  8. Linux网络命令与脚本使用

    作为系统管理员,经常需要诊断和解决网络问题,而配置.监控与保护网络有助于发现问题并在事情范围扩大前得意解决,并且网络的性能与安全也是管理与诊断网络的重要部分.这里总结一下常用与Linux网络管理的命令 ...

  9. 前端学HTTP之网络基础

    × 目录 [1]网络 [2]OSI [3]TCP/IP 前面的话 HTTP协议对于前端工程师是非常重要的.我们在浏览网站时,访问的每一个WEB页面都需要使用HTTP协议实现.如果不了解HTTP协议,就 ...

随机推荐

  1. Java之Object类

    0 引言 Object类是类层次结构的根,Java中所有的类从根本上都继承自这个类.Object类是Java中唯一没有父类的类. 其他所有的类,包括标准容器类,比如数组,都继承了Object类中的方法 ...

  2. centos7下安装pyspark

    1.安装python 2.安装jdk 3.下载spark:http://spark.apache.org/downloads.html, 下载新版(spark-2.3.1-bin-hadoop2.7. ...

  3. python3 列表操作

    - 创建列表 #创建列表: list1 = [1, 2, 3, 4, 5] - 向列表中添加元素 - append # 向列表中添加元素: list1 = [1, 2, 3, 4, 5] list1. ...

  4. 2019-02-25 SQL:cast(itemvalue as decimal(19,4))

    1.Operand data type nvarchar(max) is invalid for sum operator 要转换格式 2.Conversion failed when convert ...

  5. Django Rest Framework 简介及 初步使用

    使用Django Rest Framework之前我们要先知道,它是什么,能干什么用? Django Rest Framework 是一个强大且灵活的工具包,用以构建Web API 为什么要使用Res ...

  6. git pull 跟 fetch的区别

    今天在公司碰到个问题,公司不使用master分支作为主分支,而使用release分支作为主分支,这就碰到了个问题,也就是当clone一个项目下来的时候,如果master跟release分支有冲突,就不 ...

  7. spring security中当前用户信息

    1:如果在jsp页面中获取可以使用spring security的标签库 在页面中引入标签   1 <%@ taglib prefix="sec" uri="htt ...

  8. 005推断两个字符串是否是变位词 (keep it up)

    写一个函数推断两个字符串是否是变位词. 变位词(anagrams)指的是组成两个单词的字符同样,但位置不同的单词.比方说, abbcd和abcdb就是一对变位词 这也是简单的题. 我们能够排序然后对照 ...

  9. POJ 2369

    我们知道,当循环长度为L时,置换群幂次为K ,则结果是GCD(L,K)个积相乘. 于是,我们只需要求出每个循环的长度,求得它们的最小公倍数即为解. #include <iostream> ...

  10. Hadoop学习;測试;启动bug;secondary合并edits到fsimage

    一个Hadoop集群拥有多个并行的计算机.用以存储和处理大规模的数据集 Hadoop强调代码向数据迁移 要执行的程序在规模上比数据小的多,更easy移动,此外通过网络移动数据比载入执行程序更花时间,这 ...