我有一个简单的服务器运行在node.js使用连接:

var server = require('connect').createServer();
//actions...
server.listen(3000);

在我的代码中,我有实际的处理程序,但这是基本的思想。我一直遇到的问题是

EADDRINUSE, Address already in use

我收到这个错误时再次运行我的应用程序后,它以前崩溃或错误。因为我没有打开一个新的终端实例,所以我用ctr + z关闭了这个进程。

我非常确定我所要做的就是关闭服务器或连接。我尝试在进程中调用server.close()。(“退出”,…);运气不好。


Linux

运行ps并确定节点进程的PID。

然后执行sudo kill PID

窗户

使用tasklist显示正在运行的进程列表:

tasklist /O

然后,像这样(使用tasklist命令获得的PID)杀死节点进程:

taskkill /pid PID

的过程。On ('exit', ..)在进程崩溃或被杀死时不会被调用。它只在事件循环结束时被调用,由于server.close()在某种程度上结束了事件循环(它仍然需要等待当前正在运行的堆栈),因此将它放在退出事件中没有意义…

在崩溃时,执行进程。on('uncaughtException', ..)和on kill do进程。(SIGTERM, . .)

也就是说,SIGTERM(默认终止信号)让应用程序清理,而SIGKILL(立即终止)不会让应用程序做任何事情。


你也可以通过命令行方式:

ps aux | grep node

来获取进程id。

然后:

kill -9 PID

在kill时执行-9会发送SIGKILL(而不是SIGTERM)。 SIGTERM有时会被节点忽略。


节点正在内存中的某个地方运行,并且锁定了该端口。在Windows上,这个问题会发生,像大多数Windows问题一样,通过按CTRL+ALT+DEL和/或重新启动来解决。


我在运行win8的笔记本电脑上打出了这个。这工作。

以“管理员”身份运行cmd.exe:

C:\Windows\System32>taskkill /F /IM node.exe
SUCCESS: The process "node.exe" with PID 11008 has been terminated.

您可以使用热节点来防止服务器崩溃/运行时错误。当节点程序[source] /进程[running node program]发生变化时,Hot-node会自动重启nodejs应用程序。

使用global选项使用npm安装hot-node:

安装-g hotnode


我得到这个错误一次,并采取了许多方法在这里。

我的问题是我有两个app.listen(3000);在同一个app.js脚本中调用。第一个app.listen()在第二个抛出错误的地方成功了。

我遇到的另一个帮助我调试的有用命令是sudo fuser -k 3000/tcp,它会杀死你可能启动的任何恶意进程(一些进程可能会重新启动,例如,如果使用forever.js运行,但它对我很有用)。


出现这个问题的原因是:

任何一个应用程序都可以在这个端口上运行,比如Skype。 节点可能已经崩溃,端口可能没有被释放。 您可能已经尝试启动多个服务器。为了解决这个问题,可以维护一个布尔值来检查服务器是否已经启动。只有当boolean返回false或undefined时才应该启动;


任务管理器(ctrl+alt+del) -> .使用实例

进程选项卡->

选择“node.exe”进程,点击“结束进程”


供你参考,你可以用一个命令sudo fuser -k 3000/tcp来终止进程。这可以用于开发中常用的所有其他端口,如8000、8080或9000。


这个命令列出了与“节点”相关的任务,并终止了每个任务。

kill -9  $( ps -ae | grep 'node' | awk '{print $1}')

这意味着你有两个节点服务器运行在同一个端口上,如果一个运行在端口上,比如3000,将另一个端口更改为另一个端口,比如3001,一切都将正常工作


我找到了这个解决办法,试试吧 使用sudo给予许可

  sudo pkill node

出于对表格中所有答案的尊重,我想补充一点。

我发现,当我终止一个节点应用程序错误使用Ctrl + Z,非常下一次当我试图打开它得到相同的错误EADDRINUSE。

当我使用Ctrl + C终止一个节点应用程序时,下一次我打开它时,它没有任何问题。

将端口号更改为错误的端口号可以解决该问题。


首先,您需要知道哪个进程正在使用端口3000

sudo lsof -i :3000

这将列出该端口上所有的PID监听,一旦你有了PID,你可以用下面的方法终止它:

kill -9 <PID>

其中,将<PID>替换为进程ID或进程ID列表,即前面的命令输出。


PowerShell \用户:

任务杀戮 /IM 节点.exe /F


以防万一,检查一下你是否错误地多次添加了这一行

app.listen(3000, function() {
  console.log('listening on 3000')
});

上面的代码是用于表达的,但只要检查一下您是否试图在代码中两次使用相同的端口。


我想知道,为什么还没有人提到这种可能性:

如果你用字符串(有意或无意)提供::listen(port),这将不是一个有效的端口号表示,然后它可以在内部转换为端口号-1,然后引擎将尝试连接到那个-1端口,然后产生相同的EADDRINUSE错误,这反过来可能会有点混乱,让你在错误修复搜索的错误方向(hi, me xD)。

因此,在开始检查使用端口的进程之前,调试代码并检查传递给函数的确切内容。


在Linux上。

给~/.bashrc添加函数:

function killTcpListen () {
  kill -9 $(lsof -sTCP:LISTEN -i:$1 -t)
}

Pull changes: source ~/.bashrc

并使用它:killTcpListen 3000


使用以下命令检查PID,即运行在端口3000上的进程id:

lsof -i tcp:3000

它将输出如下内容:

COMMAND  PID   USER   FD   TYPE  DEVICE  SIZE/OFF NODE NAME
node     5805  xyz    12u  IPv6  63135    0t0     TCP  *:3000 (LISTEN)

现在使用以下命令终止进程:

kill -9 5805

Win10, git bash v2.15, node v8.9.1, npm v5.5.1

我有一个包裹。Json脚本启动节点:"start": "node index.js"

无论何时我使用它,不管我是否用ctrl+c杀死它,我都遇到了这个问题。

如果我只是从git bash运行node index.js而不是npm run start并用ctrl+c杀死,我永远不会得到这个错误。

我不知道为什么,但我想这可能会帮助到一些人。


对于所有来到这个帖子并尝试了所有可能使用无恶魔或永远做到这一点的人。 例如,如果你跑步 端口= 6060 Nodemon 您可能会得到端口6060已被使用的相同错误。

如果是这种情况,如果你真的需要在运行过程中定义port,那么就运行你的项目而不使用nodemon。或者,如果你想坚持使用nodemon,你可以在你的文件中定义port。

对我来说,我现在这样做PORT=6060 node app.js


下面是一行代码(将3000替换为端口或配置变量):

kill $(lsof -t -i:3000)

首先找出正在运行的是什么:

sudo lsof -nP -i4TCP:3000 | grep LISTEN

你会得到这样的东西:

php-fpm 110 root    6u  IPv4 0x110e2ba1cc64b26d      0t0  TCP 127.0.0.1:3000 (LISTEN)
php-fpm 274 _www    0u  IPv4 0x110e2ba1cc64b26d      0t0  TCP 127.0.0.1:3000 (LISTEN)
php-fpm 275 _www    0u  IPv4 0x110e2ba1cc64b26d      0t0  TCP 127.0.0.1:3000 (LISTEN)

然后你可以像下面这样终止进程:

sudo kill 110

然后,您将能够运行而不会得到listen EADDRINUSE:::3000错误


对于windows,打开任务管理器,找到node.exe进程。用结束任务杀死所有敌人


对于像我这样的Visual Studio新手来说

您可能正在其他终端上运行该进程!

在Visual Studio中关闭终端后,终端就消失了。

我手动创建了一个新的,以为之前的已经销毁了。实际上,每次我点击New Terminal时,我实际上是在之前的终端上创建了一个新的终端。

所以我找到了第一个终端然后…瞧,我在那里运行服务器。


对我来说,这是因为我打开了Eclipse……


Server.close()需要一段时间来关闭连接,因此我们应该将其作为一个异步调用:

await server.close();

重要的是: 当使用await时,我们必须在封装函数中使用async关键字:

async () => {
  await server.close();
}

只杀死使用给定PORT的节点进程。正如其他人提到的,在bash中可以使用kill $(lsof -t -i:PORT)

这里有一个Windows解决方案(有一个方法!): Netstat -bona | findstr "。0:PORT +0.0.0.0:0 +LISTENING" | for /f "令牌=5" %t in ('more') do taskkill /PID:%t /f。你需要一个提升终端(在VSCode中,你需要通过提升来打开自己,因为集成终端不能被提升)。

PS:如果findstr不可用,您可以简单地使用查找和替换空格“+”(非正则模式)


你可能会遇到这样的情况,即使杀死线程或进程也不会真正终止应用程序(我在Linux和Windows上每隔一段时间就会遇到这种情况)。有时,您可能已经有一个正在运行的实例,但没有关闭。

由于这些情况,我更喜欢在package.json中添加:

"scripts": {
    "stop-win": "Taskkill /IM node.exe /F",
    "stop-linux": "killall node"
},

然后我可以调用它们使用:

npm run stop-win
npm run stop-Linux

如果您愿意,还可以让这些BIN命令带有参数标志。您还可以将它们添加为在try-catch子句中执行的命令。


ps aux | grep node
kill -9 [PID] (provided by above command)

描述:


Ps将给出进程状态,aux提供a:所有用户进程,u:用户自己的进程,x:所有其他未连接到终端的进程的列表。 管道符号:|将传递ps aux的结果以进行进一步操作。 Grep将从ps aux提供的列表中搜索所提供的字符串(在本例中为节点)。


Windows用户的UI解决方案:我发现顶部的答案对我不起作用,它们似乎是Mac或Linux用户的命令。我找到了一个简单的解决方案,不需要记住任何命令:打开任务管理器(ctrl+shift+esc)。查看正在运行的后台进程。找到任何Node.js并结束任务。

在我这么做之后,这个问题就消失了。正如在其他答案中所述,它的后台进程仍然在运行,因为之前遇到了一个错误,常规的退出/清理函数没有被调用,所以杀死它们的一种方法是在任务管理器中找到该进程并在那里杀死它。如果你从终端/powerShell运行进程,你通常可以使用ctrl+c来终止它。


windows用户:打开任务管理器,结束任务的nodejs.exe文件,可以正常工作。


在terminal/cmd中使用下面的命令来改变端口(npm run dev是node.js的),你可能有其他命令来运行你的应用程序,其中大多数在改变端口时都可以工作,更简单,更快。此外,您可以使用系统中任何空闲的端口号,而不是3002

PORT=3002 npm run dev

大多数情况下,当一个人运行项目时突然或不知情地退出一个,按下control + z,让你退出端口,总是选择control + c,不会从端口退出来运行服务器或项目。

此外,是时候更改代码中的端口号了

server.listen(3002);

我也有同样的问题,但我发现这不是恶魔的问题。首先,我使用这个脚本开始我的过程:

{"dev": "nodemon -r dotenv/config app.js"}

应用程序可以正确启动,但只要任何文件改变,nodemon就不能重新启动它。与此同时,应用程序仍在后台继续运行。如果我按Ctrl+C,它退出,但端口3000上没有更多的进程,所以通过端口fuser -k 3000/tcp杀死它没有任何作用。

并且,我在app.js文件中使用。env端口。

const port = process.env.PORT || 3000;

因此,我只将端口值更改为3000,它就工作了。

const port = 3000;

我不得不找到另一种方法来加载.env文件,但这解决了我的问题。希望这能有所帮助。


在我的回答中重写@Gerard的评论:

在类unix操作系统上尝试pkill nodejs或pkill node。

这将杀死运行在任何端口上的节点服务器的进程。 为我工作。


bash$ sudo netstat -ltnp | grep -w ':3000'
 - tcp6    0      0 :::4000      :::*        LISTEN      31157/node      

bash$ kill 31157

删除项目根目录中未定义的文件(在应用程序崩溃时创建的)


我也面临着同样的问题。我刚刚把我的端口号从8000改成了6000。 当你有3000的时候,你可以尝试5000、4000、7000、8000等等。


我正在使用调试器,只是没有停止使用Ctrl+C运行的进程。当我想开始调试时,我得到了这个错误。


在Windows上,我得到以下错误:

EADDRINUSE:地址已经在使用:::8081。

遵循以下步骤:

以管理员身份打开CMD 执行以下操作

命令netstat -ano|findstr "PID:8081"

得到以下流程:

通过:

Taskkill /pid 43144 /f

在MAC上你可以这样做:

raghavkhunger@MacBook-Air ~ % lsof -i tcp:8081 命令pid user fd类型设备大小/关闭节点名称 节点23722用户名24u IPv6 0xeed16d7ccfdd347 0t0 TCP *:sunproxyadmin (LISTEN)

username@MacBook-Air ~ % kill -9 23722


通过Cmd打开Windows

1/2。Search => write CMD => open node.js命令提示符


2/2。执行windows命令:taskkill

结束一个或多个任务或流程。

taskkill /f /im node.exe

/f - force结束

/im -要终止的进程的镜像名称。

Node.exe -可执行文件

Windows -手动任务管理器

这个命令相当于在详细信息选项卡下进入任务管理器并选择节点任务(在我看来很整洁)。

结束任务

Visual studio

有时有多个终端/任务(客户端/服务器等)。 选择并按ctrl + c关闭。


我还有另一个问题。我已经申报了两次港口。不要再犯那个错误了。

app.listen(port, function () {
  console.log('Example app listening on port')
})

app.listen(3000, function() {
  console.log("Server started on port 3000");
});

而是这样做:

const port = 3000;

app.listen(port, function () {
  console.log('Example app listening on port')
})

简单地退出服务器,并将服务器端口3000更改为31000,其工作正常。


使用netstat获取所有节点进程和它们正在使用的端口,然后通过PID杀死你想要的唯一一个

netstat -lntp | grep node

您将获得所有节点进程

tcp6  0      0 :::5744    :::*    LISTEN     3864/node

然后当你得到PID(3864)时,通过PID终止进程

  kill -HUP PID 

尝试更改端口号。这对我很管用。 例如,可以将端口号从3000修改为3001。


对于macOS Monterey(12.0):

苹果公司在macOS Monterey上对AirPlay进行了一些更改。现在,它使用5000和7000端口。如果在项目中使用这些端口,则需要禁用此功能。

系统首选项>共享>取消AirPlay接收器


macOS Ventura(13.0)及以上用户:

系统设置>常规>禁用AirPlay Receiver


我通常用

npx kill-port 3000

或者在我的mac上。

killall node

这发生在我身上,因为我在我的ubuntu中打开了多个visual studio实例而没有注意到它,其中一个实例中已经运行了xdebug。


在我的例子中,这个问题是由NodeJS环境引起的

两种解决方案:

打开任务管理器,关闭所有Nodejs进程(名称:Node.js JavaScript Runtime) 尝试将服务器的端口从3000更改为当前未被使用的其他端口(例如:3111)。


现代Windows (powershell)

当前版本的Windows默认使用Powershell而不是cmd。你可以这样跑:

Get-NetTCPConnection | where Localport -eq 3000 | select Localport,OwningProcess

找出这个应用是什么。


真的很简单,所有的操作系统..

npx kill-port 3000

尽管您的问题如上所述,但您需要捕获节点退出的不同方式

process.on('uncaughtException', (err, origin) => {
    console.log(err);
});

// insert other handlers.

如果你是windows用户,只需进入任务管理器并结束node js的所有任务


一种简单的方法是列出在端口上侦听的所有进程

lsof -i tcp:YOUR_PORT | grep监听

然后你可以杀死他们:

kill -9 {PID}