命令行查看端口号被哪个进程占用

转载 2012年01月19日 20:46:57

 

在网络程序的调试过程中,经常发生一些出乎意料的事情,比如创建一个TCP服务失败,这时候往往需要查看系统的网络情况,最常用的网络抓包当然非WireShark模式。但往往很多时候只需要查看某个端口的使用情况,它到底被那个进程(对应PID)占用了,或者你还需要把它Kill掉。如果你在Windows操作系统,你可以使用netstat命令来查询PID,然后可以打开任务管理器,查看这个PID对应的进程名;如果PID没有显示,菜单》查看》选择列》选中PID即可;得知进程后,我们可以将进程杀掉。下面我简单描述一下我所了解的在Windows和Linux系统下处理方式。 (假如我们需要确定谁占用了我们的9010端口)

 

1、Windows平台
在windows控制台窗口下执行:
netstat -nao | findstr "9010"
TCP 127.0.0.1:9010 0.0.0.0:0 LISTENING 3017

 

你看到是PID为3017的进程占用了9010端口,如果进一步你想知道它的进程名称,你可以使用如下命令:

tasklist | findstr "3017"

 

如果你想杀死这个进程,你当然可以用前面描述的那种方法,在任务管理器里把它KILL了,但如果你喜欢高效一点,那么用taskkill命令就可以了。

taskkill /pid 3017

那么这个进程就灰灰湮灭了:)

 

 

2、Linux

如果你是个Linux爱好者,那个这个命令你应该很熟了,

netstat -pan | grep 9010

 

 

如果你稍微仔细一点,你会发现,用的都是netsta命令,事实上,netstat是一个比较通用的网络统计命令,几乎适用于所有现在流行的操作系统,无论是Linux,Window,还是其他Unix,或者Unix-like操作系统,而且用法基本一致。

 

下面是一个对Windows系统中netstat命令行参数的详细解释。

 

格式:

netstat [-a] [-e] [-n] [-o] [-p Protocol] [-b] [-r] [-s] [-v] [Interval]

 

参数说明:

-a 显示所有连接和监听端口。
-n 以数字形式显示地址和端口号。

-o 显示与每个连接相关的所属进程 ID。

 

-p 在Windows系统中,该选项用于指定默认情况的子集。proto 显示 proto 指定的协议的连接;proto 可以是下列协议之一: TCP、UDP、TCPv6 或 UDPv6。

如果与 -s 选项一起使用以显示按协议统计信息,proto 可以是下列协议之一:
IP、IPv6、ICMP、ICMPv6、TCP、TCPv6、UDP 或 UDPv6。


-b 显示包含于创建每个连接或监听端口的可执行组件。在某些情况下已知可执行组件拥有多个独立组件,并且在这些情况下; 包含于创建连接或监听端口的组件序列被显示。这种情况下,可执行组件名在底部的 [] 中,顶部是其调用的组件,等等,直到 TCP/IP 部分。注意此选项
可能需要很长时间,如果没有足够权限可能失败。

-e 显示以太网统计信息。此选项可以与 -s选项组合使用。


-s 显示按协议统计信息。默认地,显示 IP、IPv6、ICMP、ICMPv6、TCP、TCPv6、UDP 和 UDPv6 的统计信息。

 

-r 显示路由表。

-v 与 -b 选项一起使用时将显示包含于为所有可执行组件创建连接或监听端口的组件。

interval 重新显示选定统计信息,每次显示之间暂停时间间隔(以秒计)。按 CTRL+C 停止重新显示统计信息。如果省略,netstat 显示当前
配置信息(只显示一次)。

 

命令行查看端口号被哪个进程占用

命令行查看端口号被哪个进程占用  在网络程序的调试过程中,经常发生一些出乎意料的事情,比如创建一个TCP服务失败,这时候往往需要查看系统的网络情况,最常用的网络抓包当然非WireShark模式。但...
  • yihui8
  • yihui8
  • 2015年04月27日 19:42
  • 3383

查看端口号被哪个进程占用的方法

前不久,看了一些这方面的资料,现汇总一下: Windows平台 比如测试端口1793是谁在使用,首先找到进程id. PS C:\Users\d00101270> ne...
  • zhaifengmin
  • zhaifengmin
  • 2014年11月10日 00:01
  • 657

如何查看端口号被哪个进程占用

在网络程序的调试过程中,经常发生一些出乎意料的事情,比如创建一个TCP服务失败,这时候往往需要查看系统的网络情况,最常用的网络抓包当然非WireShark模式。但往往很多时候只需要查看某个端口的使用情...
  • dayancn
  • dayancn
  • 2014年09月15日 10:43
  • 2941

命令行查看端口号被哪个进程占用(转)

在网络程序的调试过程中,经常发生一些出乎意料的事情,比如创建一个TCP服务失败,这时候往往需要查看系统的网络情况,最常用的网络抓包当然非WireShark模式。但往往很多时候只需要查看某个端口的使用情...
  • datoubangzhu
  • datoubangzhu
  • 2018年01月16日 13:03
  • 15

命令行查看端口号被哪个进程占用(转)

在网络程序的调试过程中,经常发生一些出乎意料的事情,比如创建一个TCP服务失败,这时候往往需要查看系统的网络情况,最常用的网络抓包当然非WireShark模式。但往往很多时候只需要查看某个端口的使用情...
  • datoubangzhu
  • datoubangzhu
  • 2018年01月06日 13:20
  • 61

查看那个进程占用了端口号(LINUX与AIX)

在LINUX中: netstat命令 [root@limt ~]# netstat -tulp Active Internet connections (only servers) Proto R...
  • lmt818583
  • lmt818583
  • 2014年12月17日 14:35
  • 1462

Linux 查看端口命令

Linux下如果我们需要知道2809号端口的情况的话,我们可以这样,如下命令:   $netstat -pan|grep 2809   tcp    0   0 0.0.0.0:2809   0....
  • peter123asd
  • peter123asd
  • 2015年12月08日 18:11
  • 1312

查找linux系统下的端口被占用进程的两种方法

http://blog.chinaunix.net/uid-7552018-id-293585.html 在linux下开发时,你的软件可能要使用某一个端口,或者想查找某一个端口是否被占用。需要...
  • liukuan73
  • liukuan73
  • 2016年02月14日 16:45
  • 1550

linux下常用命令查看端口占用

在Linux使用过程中,需要了解当前系统开放了哪些端口,并且要查看开放这些端口的具体进程和用户,可以通过netstat命令进行简单查询 netstat命令各个参数说明如下:   -t : 指明显示...
  • ws379374000
  • ws379374000
  • 2017年07月03日 16:54
  • 3471

查看端口号被哪个进程占用的方法

前不久,看了一些这方面的资料,现汇总一下: Windows平台 比如测试端口1793是谁在使用,首先找到进程id. PS C:\Users\d00101270> ne...
  • myweishanli
  • myweishanli
  • 2014年11月07日 08:52
  • 319
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:命令行查看端口号被哪个进程占用
举报原因:
原因补充:

(最多只允许输入30个字)