Linux网络控制命令

1.ifconfig

  • 1.1 查看已被激活的网卡的详细信息
$ ifconfig
eth0 Link encap:Ethernet HWaddr 00:30:67:F2:10:CF
inet addr:10.0.0.253 Bcast:10.0.255.255 Mask:255.255.0.0
inet6 addr: fe80::230:67ff:fef2:10cf/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:4663517 errors:0 dropped:0 overruns:0 frame:0
TX packets:6122850 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:1852734274 (1.7 GiB) TX bytes:1487018040 (1.3 GiB)

HWaddr :网卡的硬件地址,即MAC地址
inet addr:IPv4的IP 地址
Bcast:广播地址
mask:子网掩码
inet6 addr:IPv6地址
MTU:最大传输单元
Metric:用于计算路由的成本
RX:表示网络启动到现在的封包接受情况 (Receive)
packets:表示接包数
errors:表示接包发生错误的数量
dropped:表示丢弃的包数量
overruns:表示接收时因过速而丢失的数据包数
frame:表示发生frame错误而丢失的数据包数
TX:从网络启动到现在传送的情况 (Transmit)
collisions:冲突信息包的数目
txqueuelen:发送队列的大小
RX byte、TX byte:总传送/接受的量

注:由RX和TX可以了解网络是否非常繁忙
注:errors:0 dropped:0 overruns:0 frame:0,都为0 说明网络比较稳定
注:collisions发生太多次表示网络状况不太好

  • 1.2. 临时IP配置
$ ifconfig eth0 172.16.0.118 netmask 255.255.0.0
$ ifconfig eth0 172.16.0.118/16
$ ifconfig eth0:1 172.16.0.119/16  指定子接口
  • 1.3. 配置临时MAC地址(配置文件中的mac地址不可直接改,要不就不写)
$ ifconfig eth0 hw ether B8:97:5A:00:4E:3A
  • 1.4. 简单的启动和关闭网络接口
$ ifdown eth0 ; ifup eth0
  • 1.5. 关闭临时的网络接口
$ ifconfig eth0:1 down
  • 1.6. 启用和关闭arp协议
$ ifconfig eth0  arp
$ ifconfig eth0  -arp
  • 1.7. 设置传输单元mtu的值
$ ifconfig  eth0  mtu  1000

2.ip

  • 2.1. 关于额外IP的相关设定:ip add 临时增加/删除IP地址
$ ip add add 192.168.1.126/24  dev eth0:0
$ ip add del  192.168.1.126/24  dev eth0:0
$ ip add  show
$ ip add  show eth0
  • 2.2. 关于接口设备的相关设置:ip link
$ ip link set eth0 up        //开启网卡
$ ip link set eth0 down      //关闭网卡
$ ip link set eth0 name lyj  //网卡改名
$ ip link set eth0 mtu 1000  //改mtu值
$ ip link show   //显示所有接口信息
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 52:54:00:d6:81:26 brd ff:ff:ff:ff:ff:ff
$ ip -s link show eth0  //显示接口流量信息
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 52:54:00:d6:81:26 brd ff:ff:ff:ff:ff:ff
RX: bytes  packets  errors  dropped overrun mcast
107193541  1118624  0       0       0       0
TX: bytes  packets  errors  dropped carrier collsns
116799818  1093559  0       0       0       0
$ ip -s -s link show eth0  //多一个-s表示更详细的信息
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 52:54:00:d6:81:26 brd ff:ff:ff:ff:ff:ff
RX: bytes  packets  errors  dropped overrun mcast
107031087  1116940  0       0       0       0
RX errors: length  crc     frame   fifo    missed
0        0       0       0       0
TX: bytes  packets  errors  dropped carrier collsns
116526036  1091941  0       0       0       0
TX errors: aborted fifo    window  heartbeat
0        0       0       0
  • 2.3. 关于路由的相关设置:ip route
$ ip route show  //查看路由信息

10.0.0.0/16 dev eth0  proto kernel  scope link  src 10.0.10.158
169.254.0.0/16 dev eth0  scope link  metric 1002
default via 10.0.0.254 dev eth0
# ip route add 10.10.10.0/24 via 172.16.0.254  dev eth0  //添加一条路由
# ip route del 10.10.10.0/24                             //删除一条路由
# ip route add default via 172.16.0.254  dev eth0     //添加默认路由
# ip route del default  via 172.16.0.254   dev eth0   //删除默认路由
  • 2.4. 其他
$ ip monitor all   //所在局域网的一台电脑根据它的状态可以被分类成REACHABLE或者STALE
[NEIGH]10.104.64.1 dev eth0 lladdr fe:ee:ff:ff:ff:ff STALE
[NEIGH]10.104.64.1 dev eth0 lladdr fe:ee:ff:ff:ff:ff REACHABLE
[NEIGH]10.104.64.1 dev eth0 lladdr fe:ee:ff:ff:ff:ff STALE
[NEIGH]10.104.64.1 dev eth0 lladdr fe:ee:ff:ff:ff:ff REACHABLE
[NEIGH]10.104.64.1 dev eth0 lladdr fe:ee:ff:ff:ff:ff STALE
[NEIGH]10.104.64.1 dev eth0 lladdr fe:ee:ff:ff:ff:ff REACHABLE
$ ip neighbour  //查看接入你所在的局域网的设备的MAC地址
10.104.64.1 dev eth0 lladdr fe:ee:ff:ff:ff:ff REACHABLE

3.route

  • 3.1. 查看路由状态
$ route  -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
10.104.64.0     0.0.0.0         255.255.192.0   U     0      0        0 eth0
169.254.0.0     0.0.0.0         255.255.0.0     U     1002   0        0 eth0
0.0.0.0         10.104.64.1     0.0.0.0         UG    0      0        0 eth0

Destination:目的地
Genmask:路由的网络掩码
Gateway:该网络通过哪个网关连接出去的(下一跳)
      0.0.0.0:表示路由直接由本机传送,即局域网的MAC直接发送的
      IP:表示该路由需要路由器(网关)的转发才能发送
Flags:标志
      U Up表示此路由当前为启动状态
      H Host,表示此网关为一主机
      G Gateway,表示此网关为一路由器
      R Reinstate Route,使用动态路由重新初始化的路由
      D Dynamically,此路由是动态性地写入
      M Modified,此路由是由路由守护程序或导向器动态修改
      ! 表示此路由当前为关闭状态
Iface:这个路由传递数据包的接口

  • 3.2.增删/设置路由
$ route add -net  172.16.0.0/16  netmask 255.255.0.0  gw 172.16.0.254  dev eth0    //增加一条路由 -net后面接的路由为一个网络

$ route del  -net  172.16.0.0/16  netmask 255.255.0.0  gw 172.16.0.254  dev eth0   //删除一条路由

$ route  add  -host  172.16.10.10 gw 192.168.1.1   //-host连接到单部主机的路由

$ route  add  default  gw  192.168.1.1             //增加默认路由 gw指定下一跳

$ route  del   default  gw 192.168.1.1

4.ping

  • ping用于检测主机,执行ping指令会使用ICMP,发出要求回应的信息。若远端主机网络功能没有问题,就会回应该信息,因为确定该主机运作正常;

ping [-aAbBdDfhLnOqrRUvV64] [-c <完成次数>] [-i <间隔秒数>] [-I <网络接口>] [-m mark] [-M pmtudisc_option] [-l preload] [-p <范式文本>] [-Q tos] [-s <数据包大小>] [-S sndbuf] [-t <存活数值>] [-T timestamp_option] [-w deadline] [-W timeout] [hop1 ...] destination

  • 实例
$ ping www.aliyun.com         #检测是否与主机联通
$ ping -c 2 www.baidu.com     #指定接收包的次数
$ ping 192.168.100.1 -s 100 -c 5 #指定ping5次,每次ping的数据长度为100字节

5.telnet

  • telnet用于远端登录;执行telnet指令开启终端机阶段作业,并登入远端主机;

telnet [-4] [-6] [-8] [-E] [-L] [-S tos] [-a] [-c] [-d] [-e char] [-l user] [-n <记录文件>] [-b <主机别名> ] [-r]
[host-name [port]]

  • 实例
$ telnet www.baidu.com 80     #检测端口是否开启

6.traceroute

  • traceroute命令用于显示数据包到主机间的路径。追踪网络数据包的路由途径。

traceroute [ -46dFITnreAUDV ] [ -f <存活数值> ] [ -g <网关>,... ] [ -i <网络界面> ] [ -m <存活数值> ] [ -N squeries ] [ -p <通信端口> ] [ -t <服务类型> ] [ -l flow_label ] [ -w <超时秒数> ] [ -q nqueries ] [ -s <来源地址> ] [ -z sendwait ] [ --fwmark=num ] 主机名或IP [ 数据包大小 ]

7.tcpdump

  • tcpdump命令用于输出网络传输数据,执行tcpdump指令可列出经过指定网络界面的数据包文件头。

tcpdump [-aAbdDefhHIJKlLnNOpqStuUvxX#] [ -B size ] [ -c <数据包数目> ] [ -C file_size ] [ -E algo:secret ] [ -F <表达文件> ] [ -G seconds ] [ -i <网络接口> ] [ -j tstamptype ] [ -M secret ] [ --number ] [ -Q|-P in|out|inout ] [ -r <数据包文件> ] [ -s snaplen ] [ --time-stamp-precision precision ] [ --immediate-mode ] [ -T <数据包类型> ] [ --version ] [ -V file ]
[ -w <数据包文件> ] [ -W filecount ] [ -y datalinktype ] [ -z postrotate-command ] [ -Z user ] [ expression ]

  • 实例
# 抓取当前服务器eth0网卡端口8080的网络数据
$ tcpdump -n -i eth0 port 8080

# 抓取所有经过eth0,目的或原地址是192.168.56.103的网络数据
$ tcpdump -n -i eth0 host 192.168.56.103

8.netstat

#安装netstat
$ yum install -y net-tools
#查看路由表
$ netstat -rn
$ route -n
#查看某端口
$ netstat -antulp|grep :80
#查看所有监听端口
$ netstat -antulp|grep LISTEN
#查看所有端口
$ netstat -atunlp

9.nc

  Linux nc命令主要功能如下:1. 实现任意TCP/UDP端口的侦听,nc可以作为server以TCP或UDP方式侦听指定端口;2. 端口的扫描,nc可以作为client发起TCP或UDP连接;3. 机器之间传输文件;4. 机器之间网络测速。

-g<网关> 设置路由器跃程通信网关,最多可设置8个。
-G<指向器数目> 设置来源路由指向器,其数值为4的倍数。
-h 在线帮助。
-i<延迟秒数> 设置时间间隔,以便传送信息及扫描通信端口。
-l 使用监听模式,nc作为server,侦听并接受连接,而非向其它地址发起连接。
-n 直接使用IP地址,而不通过域名服务器。
-o<输出文件> 指定文件名称,把往来传输的数据以16进制字码倾倒成该文件保存。
-p<通信端口> 设置本地主机使用的通信端口。
-r 乱数指定本地与远端主机的通信端口。
-s<来源位址> 设置本地主机送出数据包的IP地址。
-u 使用UDP传输协议,默认为TCP。
-v 显示指令执行过程。
-w<超时秒数> 设置等待连线的时间。
-z 使用0输入/输出模式,只在扫描通信端口时使用,扫描时不发送任何数据
  • 常用使用场景
$ nc -vzn 192.168.0.3 端口                         #检测端口是否打开
$ nc -l -u 192.168.0.3 端口(可以发送和接受信息)    #服务器监听udp端口
$ nc -u 192.168.0.3 端口(可以发送和接受信息)       #客户端检测udp端口
$ nc -vz -w2 192.168.0.3 1-100                #扫描192.168.0.3端口范围是 1-100
$ nc -u -z -w2 192.168.0.1 1-1000 //扫描192.168.0.3 的端口 范围是 1-1000
$ nc -nvv 192.168.0.1 22                          #扫描 22端口
$ nc -nzv 192.168.0.1 80                          #扫描 80端口
$ nc -v -w 2 192.168.2.34 -z 21-24              #端口扫描21~24(以IP192.168.2.34为例)

#从192.168.2.33拷贝文件到192.168.2.34。
#在192.168.2.34上:
nc -l 1234 > test.txt
#在192.168.2.33上:
nc 192.168.2.34 < test.txt

#用nc命令操作memcached。
存储数据:printf “set key 0 10 6rnresultrn” |nc 192.168.2.34 11211
获取数据:printf “get keyrn” |nc 192.168.2.34 11211
删除数据:printf “delete keyrn” |nc 192.168.2.34 11211
查看状态:printf “statsrn” |nc 192.168.2.34 11211
模拟top命令查看状态:watch “echo stats” |nc 192.168.2.34 11211
清空缓存:
printf “flush_allrn” |nc 192.168.2.34 11211       #谨慎操作,清空了缓存就没了

10.ss

  ss命令用于显示socket状态. 他可以显示PACKET sockets, TCP sockets, UDP sockets, DCCP sockets, RAW sockets, Unix domain sockets等等统计. 它比其他工具展示等多tcp和state信息. 它是一个非常实用、快速、有效的跟踪IP连接和sockets的新工具

$ ss -ant         #查看所有监听的tcp端口
$ ss -anu         #查看所有监听的udp端口
$ ss -ano         #查看所有协议端口
$ ss -l           #显示本地打开的所有端口
$ ss -pl          #显示每个进程具体打开的socket
$ ss -o state established '( dport = :smtp or sport = :smtp )'      #显示所有已建立的SMTP连接
$ ss -o state established '( dport = :http or sport = :http )'      #显示所有已建立的HTTP连接
$ ss -x src /tmp/.X11-unix/*          #找出所有连接X服务器的进程
$ ss -s         #列出当前socket详细信息:显示sockets简要信息,列出当前已经连接,关闭,等待的tcp连接
$ ss -pl        # ss列出每个进程名及其监听的端口
$ ss -o state established '( dport = :http or sport = :http )'      # ss列出所有http连接中的连接,以上包含对外提供的80,以及访问外部的80,用以上命令完美的替代netstat获取http并发连接数,监控中常用到
$ ss -x src /tmp/.X11-unix/*        # ss列出本地哪个进程连接到x server
$ ss -o state fin-wait-1 '( sport = :http or sport = :https )'      # ss列出处在FIN-WAIT-1状态的http、https连接

发表评论

邮箱地址不会被公开。 必填项已用*标注