常用Linux路由命令
第一组命令: ifconfig, ifup, ifdown
1) ifconfig
作用:手动启动、观察与修改网络接口的相关参数,包括IP地址以及MTU大小等。
例1.1:暂时修改IP地址
# ifconfig eth0 192.168.100.100
例1.2:修改IP地址、掩码和MTU
# ifconfig eth0 192.168.100.100 netmask 255.255.255.128 mtu 8000
例1.3:关闭eth0
# ifconfig eth0 down
注意,修改接口的任何参数都是“暂时”的,执行/etc/init.d/network restart (RH)后,所有修改都丢失了。
2)ifup和ifdown
仅就/etc/sysconfig/network-scripts内的ifcfg-ethx(x为数字)进行启动或关闭操作,并不能直接修改接口的参数,而需要手工调整ifcfg-ethx文件才行。
例2.1:启动eth0
# ifup eth0
例2.2:关闭eth0
# ifdown eth0
上面一节中,通过执行/etc/init.d/network restart 来重启网络接口,这条命令其实也要读取配置文件ifcfg-ethx。
第二组命令: route
作用:查看和更改主机Linux路由表。
例1:查看主机的Linux路由表
# route -n
Destination Gateway Genmask Flags Metric Ref Use Iface
192.168.1.0 0.0.0.0 255.255.255.0 U 1 0 0 eth0
169.254.0.0 0.0.0.0 255.255.0.0 U 1000 0 0 eth0
0.0.0.0 192.168.1.1 0.0.0.0 UG 0 0 0 eth0
例2:Linux路由的添加
#route add -net 192.168.100.0 netmask 255.255.255.0 dev eth0
例3:Linux路由的删除
# route del -net 169.254.0.0 netmask 255.255.0.0 dev eth0
例4:设置默认Linux路由
# route add default gw 192.168.10.30
说明:gw表示后面接的是一个IP地址,而不是dev。
第三组命令: ip
1) IP link
1.1 ) ip [-s] link show [dev]
作用: 查看设备的硬件相关设置,包括MAC地址、MTU等。
例1:查看接口eth0
# ip -s link show eth0
2: eth0: mtu 1500 qdisc pfifo_fast state UNKNOWN qlen 1000
link/ether 00:0c:29:e7:53:6c brd ff:ff:ff:ff:ff:ff
RX: bytes packets errors dropped overrun mcast
86168 892 0 0 0 0
TX: bytes packets errors dropped carrier collsns
184674 797 0 0 0 0
上面的显示内容中还包括接收和发送的数据包的数量。
1.2) ip link set eth0 name vbird
ip link set eth0 address aa.aa.aa.aa.aa.aa
作用:修改接口eth0的硬件设备参数name和address。
2) ip address
2.1)ip address show eth0
作用:显示网络接口eth0的IP参数。
例:
# ip address show eth0
2: eth0: mtu 1500 qdisc pfifo_fast state UNKNOWN qlen 1000
link/ether 00:0c:29:e7:53:6c brd ff:ff:ff:ff:ff:ff
inet 192.168.1.3/24 brd 192.168.1.255 scope global eth0
inet6 fe80::20c:29ff:fee7:536c/64 scope link tentative
valid_lft forever preferred_lft forever
3) ip route
3.1) ip route show
作用:显示当前的Linux路由配置。
例:
# ip route show
192.168.1.0/24 dev eth0 proto kernel scope link src 192.168.1.3 metric 1
169.254.0.0/16 dev eth0 scope link metric 1000
default via 192.168.1.1 dev eth0 proto static
可见上面的输出信息与route -n 的输出差不多。
3.2) ip route add 192.168.10.0/24 via 192.168.5.100 dev eth0
作用:增加可以通往外部的Linux路由
3.3) ip route add default via 192.168.1.2 dev eth0
作用:增加默认Linux路由
第四组命令: ping、traceroute、netstat、host和nslookup
4.1)ping
作用:通过ICMP数据包来进行整个网络的状况报告。
例1:检测主机168.95.1.1是否连通
# ping -c 3 168.95.1.1
例2:检测整个网段有多少主机存活
# ping -c 3 -b 192.168.1.255
例3:追踪MTU大小
# ping -c 3 -s 8000 -M do 192.168.10.10
-s参数表示发送的ICMP包大小为8000个字节,-M do表示不能拆包,结果将返回错误信息。
PING 192.168.1.2 (192.168.1.2) 8000(8028) bytes of data.
From 192.168.1.3 icmp_seq=1 Frag needed and DF set (mtu = 1500)
From 192.168.1.3 icmp_seq=1 Frag needed and DF set (mtu = 1500)
--- 192.168.1.2 ping statistics ---
0 packets transmitted, 0 received, +2 errors
上面的错误信息表示MTU为1500字节,如果不能拆包,便无法进行传递。
4.2)traceroute
作用:显示数据包到目标主机的路径。
这个命令会针对通往目的主机的所有router进行ICMP的超时等待,并测试回复时间。如果在默认的5秒钟之内traceroute听不到节点的回应,那么屏幕上就会出现一个*的符号,告知该节点无法有顺利的响应。这可能是由于有些防火墙或者主机将ICMP数据包丢掉,或者某些gateway不支持traceroute的功能。
4.3)netstat
这个命令的详细使用方法在我的另一篇博客文章中已经有了叙述。
参数:
-r:列出Linux路由表(route table)
-n:不使用主机名称与服务名称,使用IP与Port Number
-a:列出所有联机状态,包括tcp/udp/unix socket
-t:列出TCP数据包的连接
-u:列出UDP数据包的连接
-l: 列出在listen(监听)的服务之网络状态
-p:列出PID与Program的文件名
-c:可以设置几秒后自动更新一次网络状态的显示
5)host
作用:查出某个主机名称的IP,利用/etc/resolv.conf文件里的DNS主机查询主机的IP地址
例1:
# host yahoo.com.cn
yahoo.com.cn has address 202.165.102.205
yahoo.com.cn mail is handled by 10 mta-v1.mail.vip.cnb.yahoo.com.
6)nslookup
作用:功能与host基本相同。
语法:nslookup [-query=[type]] [hostname|IP]
-query=type:查询的类型,除了传统的IP与主机的对应外,DNS还有很多信息。如mx,cname。
例1:host-->IP
# nslookup www.google.cn
Server: 192.168.1.1
Address: 192.168.1.1#53
Non-authoritative answer:
www.google.cn canonical name = google.cn.
Name: google.cn
Address: 203.208.37.104
Name: google.cn
Address: 203.208.37.99
例2:IP-->host
# nslookup 168.95.1.1
server: 192.168.1.1
Address: 192.168.1.1#53