开发问题(一)在windows和linux端口占用问题

时间:2022-04-22
本文章向大家介绍开发问题(一)在windows和linux端口占用问题,主要内容包括一、在windows平台中、二、在LInux平台中、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。

前言

  今天在MyEclipse中使用tomcat发现tomcat端口8080竟然被占用了,所以就找了一下解决办法共参考!

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

  它到底被那个进程(对应PID)占用了,或者你还需要把它Kill掉。

  如果你在Windows操作系统,你可以使用netstat命令来查询PID,然后可以打开任务管理器,查看这个PID对应的进程名;如果PID没有显示,菜单——>查看——>选择列——>选中PID即可;得知进程后,我们可以将进程杀掉。

  下面我简单描述一下我所了解的在Windows和Linux系统下处理方式。 

一、在windows平台中

  在windows控制台窗口下执行:     netstat -nao | findstr "8080"     TCP 127.0.0.1:8080 0.0.0.0:0 LISTENING 208

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

    tasklist | findstr "208" 

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

    taskkill /pid 208

  如果你想强制杀死进程加一个-F参数

    taskkill -F  /pid 208

二、在LInux平台中

  netstat -pan | grep 8080 

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

  格式:

    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 选项一起使用时将显示包含于为所有可执行组件创建连接或监听端口的组件。

  解决办法:   

    1)查找被占用的端口:

      netstat -tln

      netstat -tln | grep 8080 

    2)查看端口属于哪个程序

      lsof -i :8080

    3)杀掉占用端口的进程:

      kill -9 进程ID