1,发现进程监听端口通过lsof命令 + p" N5 a. W& a, M! ]1 G3 V
/ h5 M& ~/ h5 d, u z4 zlsof 命令代表“列出打开的文件”。由于Linux中的所有内容都是文件,包括端口和套接字,因此我们可以获得所需的所有信息。要查找使用 lsof 侦听特定端口的进程,请运行以下命令:
6 x3 T1 ^7 O7 a0 R- e7 s# K/ N6 W% P3 S( L; v
1 z& M R) r% I* e& S9 Q+ U [9 @
注:如果运行以下命令提示命令未发现,请执行"yum install lsof"安装。 - lsof -iTCP:22 -sTCP:LISTEN
复制代码
$ E' q4 ]# e1 e% W9 Rlsof 命令在所有主要的 Linux 发行版上都可用,并且通常默认安装。" ?2 @! o: p' J$ _: N' v* w/ o- m$ e
1 u7 C4 `/ z" }# L$ W' g
2,发现进程监听端口通过netstat netstat 命令是一个老古董,但一个好东西。它自80年代初以来一直存在,不仅可用于每个Linux系统,而且至少从XP开始,还可以在任何UNIX或UNIX变体和Microsoft Windows上使用。
, X0 P& I7 o3 e6 h要查找使用 netstat 侦听特定端口的进程,请使用以下命令: - netstat -anp | grep ":22"
复制代码
% U; l, Q1 U, ~1 K1 l1 Y$ I/ t& O. J' ~-a 选项表示全部,-n 表示以数字而不是名称显示端口,-p 表示显示进程 ID 和名称。 注意:Windows 和 UNIX 系统上的语法可能会有所不同。 0 p7 r9 F* w, d, T
# i3 u2 p) J& y% n, y# Y" q! v
3,发现进程监听端口通过fuser , ^4 E/ l+ B6 O, c* y
fuser 命令标识哪个进程正在使用文件或套接字。通过一些聪明的选项,可以找到有关哪个进程正在侦听端口的所有信息。如果执行以下命令提示未找到命令,请执行“yum install psmisc.x86_64”安装fuser。
V( |8 m/ k4 c' z! I我们使用 -v 选项表示详细模式,使用 -n 选项选择相应的命名空间,后面跟上TCP以及端口22。
& B/ A C# W+ B# P; S! g7 ]" m# f( O0 j2 e0 G2 s
4,发现进程监听端口通过ss
8 E2 o, G, j) m% q4 S K$ g4 W& A+ M$ G! e7 y1 N/ @" q" \1 @# L
ss 命令被固定为netstat 的替代项。然而,通常netstat在人们中是如此根深蒂固,以至于它需要一段时间才能消失。因此可以看出,ss命令语法有点复杂,但这可能是因为很久未更新这个命令,并且按照老的命令方式来设置。
$ m) A' w* P7 q0 G8 S
% k t; y! P0 L! n6 E3 ]" m: T0 d j$ l: {7 T8 F
要使用 ss 命令查找侦听特定端口的进程,可以使用以下命令: - sudo ss -lptn 'sport = :22'
复制代码 , C3 Q4 ]" |: Q' r+ q
总结:本文主要讲解通过四种方法来查看进程监听的端口,从而也能够通过查找端口来终止服务,或者能够查询该机器上是否开启了该服务都可以通过以上四种方式来查看。
* B2 K: ^0 C/ D
; v7 X) L) d: B% p/ Q
5 _4 V: `9 b( U2 @. t$ V
; [) M" E/ l( x. F9 T9 G# |7 w: e/ I: R4 ~5 O$ A8 n$ ]
|