[英]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 上工作
您可以使用tcpkill
( dsniff
包的一部分)来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.