Windows/Linux 系统中获取端口被哪个应用程序占用

  • 2020 年 3 月 13 日
  • 筆記

管理服务程序的时候,可能会查询某个端口当前被哪个进程占用。不仅能找出有问题的进程将其处理掉,也可以用来辅助检查某个程序是否开启了服务并在监听端口。

Windows 系统

Windows 系统上可以使用 PowerShell 命令来查询占用某个端口的程序。

比如,我们需要查询 5000 端口被占用的进程是谁,可以在 PowerShell 中输入命令:

Get-Process -Id (Get-NetTCPConnection -LocalPort 5000).OwningProcess

Linux 系统

在终端中输入命令 lsof 可以查询占用某个端口的进程。

lsof -i:端口号

比如,我们需要查询 5000 端口被占用的进程是谁,可以在中断中输入命令:

walterlv@localhost:~# lsof -i:5000  COMMAND        PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME  dotnet_serve   731 root    3u  IPv6  12890      0t0  TCP *:5000

或者使用 netstat 查询。

netstat -tunpl | grep 端口号

举例:

walterlv@localhost:~# netstat -tunpl | grep 35412  tcp6   0   0 :::5000     :::*             731/dotnet_serve

本文会经常更新,请阅读原文: https://blog.walterlv.com/post/get-port-owning-process.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://blog.walterlv.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系 ([email protected])