iproute介绍
iproute是用于linux下网络配置工具,该工具包含下面工具组件,分别为:
ip 网络配置命令 tc 用来进行流量控制的命令(traffic control) rtacct 查看数据包流量状态的命令 ifcfg 网络地址配置管理 rtstat 路由状态查看工具 nstat 显示网络统计信息 ss 类似于netstat 命令,显示活动的连接
iproute安装
Turbolinux GTES10.5安装光盘已经包含iproute安装包iproute-2.6.9-3.2.i386.rpm,使用下面命令安装该软件包:
# rpm –ivh iproute-2.6.9-3.2.i386.rpm
iproute常用命令语法说明
tc命令语法
详细说明请连接到下面链接: http://www.turbolinux.com.cn/turbo/wiki/doku.php?id=网络管理:traffic-control
ip命令语法
ip [ OPTIONS ] OBJECT [ COMMAND [ ARGUMENTS ]]
OPTIONS常用的有
V 打印iproute 信息
r 将ip地址转换成域名
s 输出更为详细的结果,如果连续使用多个-s可以得到更为详细的结果。
OBJECT 即管理的对象:
Link 指网络设备,通过此对象命令,我们可以查看及更改网络设备的属性。 Address 地址管理 Neighbour arp表管理 route 路由管理 Rule 路由策略 Maddress 多址广播地址 Mroute 多播路由缓存管理 Tunnel 通道管理
COMMAND 即指定对对象所执行的操作。
Add 添加 Delete 删除 List/show 列表 Help 帮助 Set 设置 Change 改变 Replace 替换
ARGUMENTS 即操作参数,对不同的对象和操作,其可能的参数也不一样: Link管理相关参数:
dev name 指定要进行操作的网络设备名称 up/down 激活/禁用网络设备 arp on / arp off 在该网络设备上使用arp协议/禁用arp协议 multicast on / multicast off 打开/关闭多目传送 dynamic on / dynamic off 打开/关闭动态标志 name NAME 更改网络设备名称(需停止设备) txqlen number 设置传输队列长度 mtu number 设置最大传输单元 address mac 设置网络设备的MAC地址 broadcast mac 设置网络设备的硬件广播地址
Address 地址管理相关参数:
local ADDRESS 协议地址,如192.168.1.100/24。 peer ADDRESS 使用点对点连接时对端的协议地址。 broadcast ADDRESS 协议广播地址,可以简写成brd。 label NAME 地址标志。 scope SCOPE_VALUE 地址范围,可能的值有: global:说明该地址全局有效; site:说明该地址只在本地站点内有效,该值只在ipv6中使用; link:只在该网络设备上有效; host:只在该主机上有效;
Neighbour arp管理相关参数:
to ADDRESS 指定协议地址,可以是ipv4或者ipv6的 dev NAME 指定网络设备名称 lladdr LLADDRESS 指定硬件地址 nud NUD_STATE 指定neighbour的nud值,即邻居不可到达检测,可以是以下值: permanent:说明该记录将永久有效,只能出于管理的目的将其删除。 Noarp:说明该记录有效,但是在其生存时间到达以后可以被删除。 Reachable:说明该记录有效,直到可到达超时溢出。 Stale:说明该记录有效,但是其有效性值得怀疑。
Route管理相关参数:
to PREFIX 路由的目标前缀(prefix) metric NUMBER 定义路由的优先值,NUMBER是任意32位数字 table TABLEID 路由要加入的表 dev NAME 输出设备的名字 via ADDRESS 指定下一跳路由器的地址 src ADDRESS 在向目的prefix发送数据包时选择的源地址 realm REALMID 指定路由分配的realm mtu MTU 设置到达目的路径的最大传输单元(MTU) window NUMBER 设置到目的地址TCP连接的最大窗口值,以字节为单位 rtt NUMBER 估算初始往返时间(Round Trip Time) rttvar NUMBER 估算初始往返时间偏差(RTT variance) ssthresh NUMBER 估算慢启动阀值(slow start threshould) cwnd NUMBER 把拥挤窗口(congestion window)值锁定为NUMBER advmss NUMBER 设置在建立TCP连接时,向目的地址声明的最大报文段大小,如果没有设置,Linux内核会使用计算第一跳的最大传输单元得到的数值。 nexthop NEXTHOP 设置多路径路由的下一跳地址 via ADDRESS 表示下一跳路由器 scope SCOPE_VAL 路由前缀(prefix)覆盖的范围 protocol RTPROTO 本条路由得路由协议识别符
iproute 使用实例
设置网络设备的MAC地址
# ip link set eth0 address ff:ff:ff:ff:ff:ff
注意:在设置前要先执行 ip link set eth0 down,设置完成后再执行ip link set eth0 up
禁用网络接口
# ip link set eth0 down
查看网络Link信息
# ip link list 1: lo: <LOOPBACK,UP> mtu 16436 qdisc noqueue link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 2: eth0: <BROADCAST,MULTICAST,UP> mtu 1500 qdisc pfifo_fast qlen 1000 link/ether 00:e0:81:51:d9:43 brd ff:ff:ff:ff:ff:ff
查看地址信息
# ip addr list 1: lo: <LOOPBACK,UP> mtu 16436 qdisc noqueue link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 inet 127.0.0.1/8 brd 127.255.255.255 scope host lo inet6 ::1/128 scope host valid_lft forever preferred_lft forever 2: eth0: <BROADCAST,MULTICAST,UP> mtu 1500 qdisc pfifo_fast qlen 1000 link/ether 00:00:b4:c2:7e:4b brd ff:ff:ff:ff:ff:ff inet 192.168.0.200/24 brd 192.168.0.255 scope global eth0 inet6 fe80::200:b4ff:fec2:7e4b/64 scope link valid_lft forever preferred_lft forever
查看路由表
# ip route show 192.168.1.0/24 dev eth1 proto kernel scope link src 192.168.1.200 192.168.0.0/24 dev eth0 proto kernel scope link src 192.168.0.200 169.254.0.0/16 dev eth1 scope link default via 192.168.0.1 dev eth0
查看arp表
# ip neighbour show 192.168.0.5 dev eth1 lladdr 00:90:f5:4d:f7:16 nud reachable