如何解决错误:使用nodejs时监听EADDRINUSE?


466

如果我使用端口80运行服务器,并且尝试使用xmlHTTPrequest,则会出现此错误:Error: listen EADDRINUSE

在80端口上运行服务器时,如果要发出请求,为什么nodejs会出现问题?对于网络浏览器来说,这不是问题:服务器运行时,我可以在Internet上冲浪。

服务器是:

  net.createServer(function (socket) {
    socket.name = socket.remoteAddress + ":" + socket.remotePort;
    console.log('connection request from: ' + socket.remoteAddress);
    socket.destroy();
  }).listen(options.port);

并要求:

var xhr = new XMLHttpRequest();

xhr.onreadystatechange = function() {
    sys.puts("State: " + this.readyState);

    if (this.readyState == 4) {
        sys.puts("Complete.\nBody length: " + this.responseText.length);
        sys.puts("Body:\n" + this.responseText);
    }
};

xhr.open("GET", "http://mywebsite.com");
xhr.send();

您确定options.port定义为80吗?XHR代码是否在浏览器中运行?当此服务器未运行时,可以运行“ nc -l 0.0.0.0 80”吗?
蒂莫西·米德


您在哪个系统上?如果您要侦听某个阈值以下的端口,则某些系统需要sudo。
Kebman

出现此问题是因为您要么在该端口上运行服务器而未关闭该端口,错误明确表明该端口已在使用中,这是我在vs代码中打开新项目而不关闭其他项目时发生的(打开拖放)
Ashad Nasim

Answers:


412

EADDRINUSE表示listen()试图将服务器绑定到的端口号已被使用。

因此,在您的情况下,必须已经在端口80上运行了服务器。

如果在此端口上运行其他Web服务器,则必须将node.js放在该服务器后面,并通过它进行代理。

您应该检查listening此类事件,以查看服务器是否确实在监听:

var http=require('http');

var server=http.createServer(function(req,res){
    res.end('test');
});

server.on('listening',function(){
    console.log('ok, server is running');
});

server.listen(80);

1
我只运行此服务器。在我启动服务器之前,xmlhttprequest可以工作。在端口80上启动服务器后,服务器也可以正常工作。但是,如果我在启动服务器后执行xmlhttprequest,则会收到此错误。
丹尼·福克斯

6
如果服务器已经在侦听,这是否还会引发错误?
trysis

1
对于我这个在车里被引起

559

对我真正的帮助是:

killall -9 node

但这会杀死系统进程。

ps ax

您可以检查它是否有效。


1
也对我来说。以我
为例,

2
在相关说明中,您还可以阅读我什么时候不应该杀死-9进程
2015年

12
这里的问题是你们在第一次运行后没有优雅地退出节点进程。因此,节点仍绑定到该端口。ps aux | grep node会表明这一点。与其使用CTRL + Z终止应用程序,不如使用CTRL + C退出应用程序。这将正常退出应用程序,并删除端口绑定。
Riser101

22
超过150票的解决方案等于用槌敲打您的软件。
LeeGee

1
该解决方案非常有问题,因为-9标志将在不释放内存的情况下终止进程。您实际上应该仅将此作为最后的解决方案。
亚基·克莱因

279

killall -9 nodePatrick所建议的上述方法按预期工作,并且可以解决问题,但是您可能希望阅读此答案的编辑部分,以了解为什么kill -9不是最佳方法。

最重要的是,您可能希望针对单个进程,而不是盲目地杀死所有活动进程。

在这种情况下,首先获取在该端口上运行的进程的进程ID(PID)(例如8888):

lsof -i tcp:8888

这将返回类似:

COMMAND   PID    USER   FD   TYPE             DEVICE SIZE/OFF NODE NAME
node     57385   You   11u  IPv6 0xac745b2749fd2be3      0t0  TCP *:ddi-tcp-1 (LISTEN)

然后就做(ps-实际上不行。请继续阅读下面的内容):

kill -9 57385

您可以在这里阅读更多有关此的内容。

编辑:我今天正在阅读一个相当相关的主题,偶然发现了一个有趣的话题,为什么我不应该kill -9进行处理

通常,您应该在kill -9之前使用kill -15,以使目标进程有机会在其自身之后清理。(进程无法捕获或忽略SIGKILL,但是它们可以并且经常捕获SIGTERM。)如果您不给进程提供完成进程并清理的机会,则可能会留下损坏的文件(或其他状态)重新启动后将无法理解。

因此,如上所述,您最好使用以下方法终止上述过程:

kill -15 57385

编辑2:正如在此处的注释中多次提到的,此错误是由于没有正常退出进程而导致的。这意味着许多人使用CTRL + Z退出节点命令(或其他任何命令)。停止正在运行的进程的正确方法是发出CTRL + C命令,该命令执行干净退出。

以正确的方式退出进程将在关闭时释放该端口。这样一来,您就可以重新启动该过程,而不必担心在重新运行之前自行杀死该过程。


我应该在哪里运行此命令?在命令提示符下?在NPM控制台上?
尤利西斯·阿尔维斯

@UlyssesAlves只是打开一个终端窗口,然后从那里终止进程。
大雄

@Nobita在Windows中可以使用吗?现在我意识到这可能是MAC OS命令。无论如何,我重新启动了PC,再也没有收到此错误。我认为其他一些应用程序正在使用同一端口节点。
尤利西斯·阿尔维斯

2
pgrep node显示是否有任何节点进程在您身上失控。pkill node会杀死他们。
Josh.F,2016年

3
不适用于Windows,人们-您必须尝试其他端口或重新启动计算机:P
Tom Stickel

62

抬起头来,Skype有时会在端口80上侦听,因此,如果您尝试从Node.js或任何其他应用程序侦听端口80,则会导致此错误。

您可以通过访问选项并单击“高级”->“连接”->“使用端口80”(取消选中此选项)来在Skype中关闭该行为。

关闭Skype端口80的使用

PS进行更改后,请不要忘记重新启动Skype!


14
PS进行更改后,请不要忘记重新启动Skype!
Rob Evans

16
这是我见过的最令人震惊的设计缺陷之一。他们曾经考虑接管80或443 的Skype开发人员有多疯狂?
AJB

5
Rob为您的调试技能大+ 1,Rob。
AJB

@AJB他们这样做是为了尝试刺穿将出站流量限制为http请求的防火墙,但是在防火墙未使用DPI的情况下,只需执行基本端口阻止即可。仍然...默认情况下启用此功能有点愚蠢!
罗布·埃文斯

是的,这是我对他们为什么要这么做的想法进行了思考之后才想到的。尽管如此,还是很丑陋的。而且默认情况下启用它的想法只是自大。
AJB

38

您应该尝试终止正在侦听端口80的进程。

Killall将杀死所有正在运行的节点应用程序。您可能不想这样做。使用此命令,您只能杀死正在已知端口上监听的一个应用程序。

如果使用unix,请尝试以下命令:

sudo fuser -k 80/tcp    

1
谢谢亚基。killall节点对我来说失败了,但这可行。
Pat M

谢谢!killall lsof -i不能为我工作,但是可以。
karfus

1
您可能不想杀死所有正在运行的节点应用程序。
亚基·克莱因

28

错误原因:您正在尝试使用忙port number

Windows / Mac的两种可能的解决方案

  1. 当前免费使用的端口号
  2. 为您的当前程序选择另一个端口号


1.空闲端口号

视窗

1. netstat -ano | findstr :4200
2. taskkill /PID 5824 /F

在此处输入图片说明

苹果电脑

您可以尝试netstat

netstat -vanp tcp | grep 3000

对于OSX El Capitan和更高版本(或者如果您的netstat不支持-p),请使用lsof

sudo lsof -i tcp:3000

如果这不能解决您的问题,则Mac用户可以参考有关此问题的完整讨论,在Mac上查找(并终止)进程以锁定端口3000


2.更改端口号?

视窗

set PORT=5000

苹果电脑

export PORT=5000

您也可以在Windows中执行一个命令:netstat -ona | findstr ".0:PORT +0.0.0.0:0 +LISTENING" | for /f "tokens=5" %t in ('more') do taskkill /PID:%t /f
Z. Khullah

27

在控制器环境下,您可以使用:

pkill node 在运行脚本之前,应该先完成这项工作。

请记住,此命令将终止所有node进程,如果您有一个只运行一个实例的容器,那么这可能是正确的,因为您拥有可以保证这一点的环境。

在任何其他情况下,我建议使用命令以编程方式查找找到的特定进程ID或名称来杀死它。就像您的进程被称为node-server-1一样,您可以这样做pkill node-server-1

理解以下资源可能会很有用:https : //www.thegeekstuff.com/2009/12/4-ways-to-kill-a-process-kill-killall-pkill-xkill/


2
pgrep node如果您想稍微小心一点,然后看一下node正在运行的进程,
请先

1
完全!我是在说这是一个容器或对该过程进行严格控制的地方。
哈维尔·科伯斯

与上面提供的其他答案相比,这是一个很棒的答案。大家请投票。
Jitendra Pawar

@JavierCobos:如果您是在容器或类似受控空间中发言,请将该信息添加到答案本身。许多人不在这样的环境中,尤其是在开发机器上,这可能会带来意想不到的后果。赞成票,但很高兴在适当澄清的情况下更改投票。
林德斯

1
很多人都会……但是作为一个花费大量时间帮助培训初级开发人员的人,甚至超出了这种背景,我可以告诉你,很多人在Stack Overflow上利用了答案,而没有真正理解他们在做什么。 ..他们只是面临一个问题,并且看到一些东西代表着似乎是他们的问题的解决方案,于是他们奔走了。所以...我个人希望该站点提供良好的解释并养成良好的一般习惯。所以,这就是我从中来的地方。我知道这不是唯一的观点。:)
林德斯

16

您的应用程序已经在该端口8080上运行。使用此代码杀死端口并再次运行您的代码

sudo lsof -t -i tcp:8080 | xargs kill -9

这个问题引用的是端口80,而不是8080。尽管这样做可能会摆脱端口8080上的问题,但使用kill -9它肯定是过大的,而且,我认为,如果没有关于以下方面的具体警告,则可以提供可怕的建议它。kill可能就可以解决问题,实际上,这个问题的根本问题是,我认为他们试图一遍又一遍地重新运行服务器,因此,这只是黑客,而不是解决方法。他们需要对正在发生的事情有更好的了解,而这个答案并没有真正提供。
林德斯

15

可能导致此错误的另一件事是同一节点代码中的两个HTTP服务器。我正在将一些Express 2更新为Express 3代码,并且有这个...

http.createServer(app).listen(app.get('port'), function(){            
  console.log('Express server listening on port ' + app.get('port')); 
});        

// tons of shit.

http.createServer(app).listen(app.get('port'), function(){            
  console.log('Express server listening on port ' + app.get('port')); 
});                                                                   

并且,它触发了此错误。


14

这对我有效(我正在使用mac)。运行此命令

lsof -PiTCP -sTCP:LISTEN

这将显示您的系统正在使用的端口列表。找到PID您的节点正在运行

COMMAND     PID          USER   FD   TYPE             DEVICE SIZE/OFF NODE NAME
node      17269 hientrq   16u  IPv6 0xc42959c6fa30c3b9      0t0  TCP *:51524 (LISTEN)
node      17269 hientrq   19u  IPv4 0xc42959c71ae86fc1      0t0  TCP localhost:1337 (LISTEN)

并运行 kill -9 [YOUR_PID]


11

EADDRINUSE意味着该端口(我们尝试在节点应用程序中监听)已被使用。为了克服这个问题,我们需要确定哪个进程正在该端口上运行。

例如,如果我们尝试在3000端口监听我们的节点应用程序。我们需要检查该端口是否已被任何其他进程使用。

步骤1:

$sudo netstat -plunt |grep :3000

上面的命令给出了以下结果。

tcp6       0      0 :::3000                 :::*                    LISTEN      25315/node

第2步:

现在您获得了进程ID(25315),请杀死该进程。

kill -9 25315

第三步:

npm run start

注意:此解决方案适用于linux用户。


9
lsof -i:3000;
kill -9 $(lsof -t -i:3000);
// 3000 is a your port
// This "lsof -i:3000;" command will show PID 
kill PID 
ex: kill 129393

3
请在您的答案中添加更多上下文,以帮助将来的读者理解代码/命令。
米洛

8

须藤杀死$(须藤lsof -t -i:80)

为了杀人

sudo kill -9 $(sudo lsof -t -i:80)

使用上面的cmd杀死特定端口,然后运行服务器



5

当您要在其上运行应用程序的端口上运行任何进程时,就会出现此错误。

如何获取在该端口上运行的进程=>命令:sudo netstat -ap | grep:3000

输出:您将获得使用该端口的过程信息

tcp 0 0 IP地址:3000 LISTEN 26869 / node

现在您可以杀死该进程sudo kill -9 26869


检查所有答案。但是你解决了我的问题。
拉胡尔


5

EADDRINUSE表示您的nodejs应用程序的端口已在使用中。

  • 现在,您已经杀死了在该端口上运行的进程/应用程序。
  • 通过以下方式查找应用的进程ID:

lsof -i tcp:3000

  • 现在,您将从中获取进程ID。
  • 运行这个:

杀死-9 processId


4

有一种使用任务管理器终止该过程的方法:

请注意,此解决方案仅适用于Windows

  1. 进入任务管理器(或使用快捷键Ctrl+ Shift+ Esc

  2. 在“后台进程”上,找到“ Node.js”进程并终止它们(右键单击它们,然后选择“结束任务”)

在此处输入图片说明

  1. 现在您应该可以重新开始了

对于Mac用户:1.启动“活动监视器”。2.在右上方的搜索栏中搜索“节点”。3.双击节点进程并退出。你们都准备好了!!!!快乐的编码。
Apogee

3

我在使用http.client之前(在节点中)已经看到此错误,并且我记得,该问题与未初始化httpClient或在httpClient创建和/或url请求中设置错误的选项有关。


3

我也有同样的问题,我只需要关闭终端并打开一个新终端并运行

node server.js

再次。这项功能对我来说有效,有时只需要等待几秒钟,直到它再次起作用。

但这仅适用于开发人员机器,而不适用于服务器控制台。


3

错误:监听EADDRINUSE表示您要分配/绑定到应用程序服务器的端口已在使用中。您可以为应用程序分配另一个端口。

或者,如果您想为应用程序分配相同的端口。然后终止在所需端口上运行的应用程序。

对于节点应用程序,您可以尝试通过以下方式找到该节点应用程序的进程ID:

ps -aux | grep node

获取进程ID后,执行

kill process_id

-aux在Windows 10上?
汤姆·斯蒂克

-aux不适用于基于Linux的系统。对于基于Windows的系统,您可以查找所需节点进程的系统监视器并结束它。
Parth Vyas


2

在我的情况下,Apache HTTP Server在端口80上运行,我通过以root身份发出命令来解决该问题

sudo killall httpd

更新资料

如果Jenkin已在Mac上安装并运行;

  1. 你可以用 sudo lsof -i tcp:8080
  2. 如果是,并且只想停止詹金斯一次,请运行: sudo launchctl unload /Library/LaunchDaemons/org.jenkins-ci.plist

2

似乎正在运行另一个Node ng服务进程。在控制台(Linux / Mac)中输入以下命令进行检查:

ps aux|grep node

并退出:

kill -9 <NodeProcessId>

或交替使用

ng serve --port <AnotherFreePortNumber>

在您选择的免费端口上为您的项目提供服务。


1

在杀死NODE_PORT的同时,它可能会杀死您的chrome进程或正在侦听同一端口的任何东西,这很烦人。

此shell脚本可能会有所帮助-在我的情况下,端口为1337,但您可以随时更改它

# LOGIC

CHROME_PIDS=`pidof chrome`
PORT_PIDS=`lsof -t -i tcp:1337`

for pid in $PORT_PIDS
do

if [[ ${CHROME_PIDS} != *$pid* ]];then

    # NOT FOUND IN CHROME PIDS

    echo "Killing $pid..."
    ps -p "$pid"

    kill -kill "$pid"
    fi

done

sails lift
# OR 'node app' OR whatever that starts your node

exit

1

在我的情况下,我使用网络托管,但是在本地主机中,我使用的是:

ps -aef | grep 'node' 

为了监视节点进程,控制台将显示带有PID的进程。要杀死该进程,您必须使用以下命令:

kill -9 PID

其中PID是上述命令的进程ID。


1

两台服务器无法在同一端口上侦听,因此请检查是否有其他服务器在同一端口上侦听,并且还检查浏览器是否同步在同一端口上运行


1

对于在Windows 10上使用node作为localhost并在3500(而不是80)端口上运行的其他人...

什么不起作用:

killall    ?  command not found
ps -aux | grep 'node'     ?     ps:  user x unknown 

显示信息但仍然不起作用的内容:

 ps -aef | grep 'node'
 ps ax
 kill -9 61864

什么有效:

Windows上的Git Bash或Powershell

  net -a -o | grep 3500   (whatever port you are looking for) 

注意PID(最右边),
我无法killall上班...所以

  1. 打开您的任务管理器
  2. 在“进程”选项卡上,右键单击“名称”或任何列,然后选择以包含PID
  3. 按PID排序,然后右键单击右PID,然后单击结束任务。

现在,在Windows上进行了不太有趣的练习之后,我意识到我可以使用任务管理器并找到Node引擎并结束它。

仅供参考,我使用Visual Studio Code在端口3500上运行Node,并且在VS代码中使用Git Bash shell。我已经用Ctrl + C正常退出了,但是有时候这并不能杀死它。我不想更改端口或重新启动,因此可以正常工作。希望它可以帮助其他人。否则,这是我自己的文档。


1

对于Windows用户,请在PowerShell窗口中执行以下命令以杀死所有节点进程。

Stop-Process -processname node

1

对我有用的选项:

跑:

ps -ax | grep node

您会得到类似的信息:

 8078 pts/7    Tl     0:01 node server.js
 8489 pts/10   S+     0:00 grep --color=auto node    
 kill -9 8078
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.