繁体   English   中英

释放 TCP/IP 端口?

[英]Freeing up a TCP/IP port?

netstat -tulnap显示正在使用的端口。 如何在 Linux 中释放端口?

正如其他人所说,您必须杀死在该端口上侦听的所有进程。 最简单的方法是使用 fuser(1) 命令。 例如,要查看在端口 80 上侦听 http 请求的所有进程(以 root 身份运行或使用 sudo):

# fuser 80/tcp

如果你想杀死它们,那么只需添加 -k 选项。

要杀死 Linux 中的特定端口,请使用以下命令

sudo fuser -k Port_Number/tcp

用您占用的端口替换 Port_Number。

在终端类型:

netstat -anp|grep "port_number"

它将显示端口详细信息。 转到最后一栏。 它将采用这种格式。 例如:- PID/java

然后执行:

kill -9 PID. Worked on Centos5

对于 MAC:

lsof -n -i :'port-number' | grep LISTEN

示例响应:

java   4744 (PID)  test  364u  IP0 asdasdasda   0t0  TCP *:port-number (LISTEN)

然后执行:

kill -9 PID 

在 Macbook 上工作

您可以使用tcpkilldsniff包的一部分)来tcpkill您需要的端口上的连接:

sudo tcpkill -9 port PORT_NUMBER

检查所有端口:

netstat -lnp

关闭一个开放的端口:

fuser -k port_no/tcp

例子:

fuser -k 8080/tcp

在这两种情况下,您都可以根据需要使用sudo命令。

假设您是root用户, "netstat --programs"命令将为您提供进程信息。 然后你将不得不终止“冒犯”的进程,它很可能会再次启动,只是为了惹恼你。

根据您实际尝试实现的目标,该问题的解决方案将根据持有这些端口的进程而有所不同。 例如,您可能需要禁用服务(假设它们不需要)或将它们配置为使用不同的端口(如果您确实需要它们但您需要更多的端口)。

杀死正在侦听相关端口的进程。 我相信 netstat 会向您显示进程 ID。

如果你真的想立即杀死一个进程,你发送一个 KILL 信号而不是一个 TERM 信号(后者是一个停止请求,第一个将立即生效,无需任何清理)。 很容易做到:

kill -KILL <pid>

但是请注意,根据您要停止的程序,执行此操作时其状态可能会严重损坏。 您通常只想在正常终止不起作用时发送 KILL 信号。 我想知道您试图解决的根本问题是什么,以及杀戮是否是正确的解决方案。

我认为唯一的方法是停止打开端口的进程。

sudo killall -9 “进程名称”

关闭计算机总是会杀死我的进程。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM