Linux之网络管理(8)网络监控工具(linux网络管理器)

网友投稿 346 2022-09-14


Linux之网络管理(8)网络监控工具(linux网络管理器)

Linux之网络管理(8)网络监控工具

linux中有很多查看网络、进程通信状态的查看工具,而网络之间建立通信是通过soket套接字进行的,所谓套接字,就是相当于插座,而一台主机上会产生多种套接字,就是相当于插头向插座插入的过程,也就是主机中进程通信。而在网络中建立通信,就是双方各种插入对方。当然这些只是粗率的比喻,实际上,soket是用来将tcp/udp等协议发送的数据包进行封装:也就是相当于食品包装,把数据包加上port端口号、进程号等然后发送给对方,然后对方根据数据的包装袋来放回特定需要的数据。这样网络之间各种进程直接通信之间互不干扰。就像送快递和收快递的一样,谁的快递,谁来收,路线就是到你家。

linux中提供的工具:

netstat  命令

man 文档帮助的说明:

netstat - Print network connections, routing tables, interface statistics, masquerade connections, and multicast memberships

打印网络连接、路由表、接口统计、伪装连接、多播连接等信息。

选项介绍:

netstat  [option]...

-r   : 显示路由表

-t   : 已经建立的tcp协议相关

-u  :  已经建立的udp协议相关

-w  : raw  sokect (未包装处理的)

-l   : 处于监听状态

-a  : 所有状态

-n  : 及数字显示IP和端口

-e  : 扩展方式详细更多状态信息

-p  : 显示相关进程及PID

常用组合使用:

查明网络连接:

netstat  -tan    显示所有tcp相关的连接状态

netstat  -uan    显示所有udp相关的连接状态

netstat  -tnl     显示所有监听状态的tcp连接

netstat  -unl     显示所有监听状态的udp连接

显示路由表:

netstat  -rn      不做反向解析显示内核路由表

显示接口统计数据:

netstat  -i       #显示所有网络接口信息状态

netstat  -I=FACE_NAME  #显示指定设备信息状态

例子:netstat  -I=eth0  #显示eth0设备数据连接状态信息

ss命令

ss - another utility to investigate sockets

这是另一种显示套接字信息的工具,netstat命令通过遍历proc 来获取socket信息,以及是老旧的命令了,ss使用netlink与内核tcp_diga模块通信获取socket信息,更加准确。

格式及选项介绍:

ss[option]  [FILTER]

option:

-t  : tcp 协议相关

-u  : udp协议相关

-w : 裸套接字符相关

-x  : unix sock系统内核相关

-l  : listen监听状态的连接

-a  : 所有连接

-n  : 数字格式

-p  : 相关的程序及PID

-e  : 扩展的信息

-m  : 内存用量

-o  : 计时器信息

FILTER :  =  [ state TCP-STATE ]  [ EXPRESSION ]

TCP的标准状态:

LISTEN :监听

ESTABLISHED:已建立的连接

FIN_WAIT_1

FIN_WAIT_2

SYN_SENT

SYN_RECV

CLOSED关闭

EXPRESSION:

dport =#目标端口

sport =              #源端口

例子:’(  dport  =  :ssh  or  sport  = :ssh  )’

常用组合:

ss  -tan#所有tcp连接状态

ss  -tanl     #所有监听的tcp状态

ss  -tanlp    #所有监听tcp的并显示进程PID

ss  -uan     #所有udp状态

额外用法:

ssh  -A  QUERY#查看对应类型或协议的状态,QUERY参数为要指定的类型

QUERY:

all,  inet,  tcp,  udp,  raw,  unix,  packet,  netlink,  unix_dgram,  unix_stream,

unix_seqpacket,  packet_raw,  packet_dgram.

TCP-STATE中可用的标示符参数:

所有TCP标准状态参数:

established,  syn-sent,   syn-recv,  fin-wait-1,  fin-wait-2,  time-wait,  closed,

close-wait,   last-ack,  listen,  closing.

复杂状态参数:

all              所有的状态

connection       所有连接的(除了监听和关闭的)状态

synchronized      所有同步的,除了syn-sent所有连接的状态

bucket           所有维护scokect和 syn-recv的状态

big              所有和bucket相反的状态

案例展示:

显示本地打开的所有端口  ss  -l

[root@localhost socket。

[root@localhost socket

[root@localhost Socekt

[root@localhost www]# ss -u -a

显示所有已经建立的SMTP连接

[root@localhost www]# ss -o state established  '( dport = :smtp or sport = :smtp )'

显示所有已经建立的HTTP连接

[root@localhost www]# ss -o state established  '( dport = :http or sport = :http )'

找出所有连接X服务器的进程

[root@localhost www]# ss -x src /tmp/.X11-unix/*

列出当前各协议的各套接字个数

[root@localhost www]# ss -s


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:9.6_Linux网络管理命令的使用(linux网络命令详解)
下一篇:Linux网络管理(7)centos7中team组的实现
相关文章

 发表评论

暂时没有评论,来抢沙发吧~