我有一个简单的TCP服务器侦听端口。

var net = require("net");

var server = net.createServer(function(socket) {
    socket.end("Hello!\n");
});

server.listen(7777);

我用node server.js启动它,然后在Mac上用Ctrl + Z关闭它。当我尝试再次用node server.js运行它时,我得到这个错误消息:

node.js:201
        throw e; // process.nextTick error, or 'error' event on first tick
          ^
Error: listen EADDRINUSE
at errnoException (net.js:670:11)
at Array.0 (net.js:771:26)
at EventEmitter._tickCallback (node.js:192:41)

我关闭程序的方式是否错误?我怎样才能防止这种情况发生呢?


要结束程序,您应该使用Ctrl + c。如果您这样做,它将发送SIGINT,这将允许程序优雅地结束,解除与它正在侦听的任何端口的绑定。

参见:https://superuser.com/a/262948/48624


Ctrl+Z挂起它,这意味着它仍然可以运行。

Ctrl+C会杀死它。

你也可以像这样手动杀死它:

ps aux | grep node

查找进程ID(左起第二):

kill -9 PROCESS_ID

这也可能有用

killall node

$ sudo killall节点在另一个终端在mac上工作,而killall节点不工作:

$ killall node
No matching processes belonging to you were found

你可以输入.exit退出节点js REPL


如果你以交互方式运行Node.js (REPL):

Ctrl + C将带你回到>提示,然后输入:

process.exit()

或者使用Ctrl + D。


或者你可以在一行中完成所有这些:

kill -9 $(ps aux | grep '\snode\s' | awk '{print $2}')

您可以将'\snode\s'中的node替换为任何其他进程名。


如果你想用npm stop来停止你的服务器。你可以编写这样的代码来杀死你的服务器进程:

require('child_process').exec(`kill -9 ${pid}`)

查看这个链接了解详细信息: https://gist.github.com/dominhhai/aa7f3314ad27e2c50fd5


虽然这是一个晚的答案,但我从NodeJS文档中找到了这个:

当REPL退出时,通过接收.exit命令作为输入,用户按下<ctrl>-C两次发出SIGINT信号,或者按下<ctrl>-D在输入流上发出'end'信号,都会触发'exit'事件。侦听器回调调用时不带任何参数。

总结一下,你可以通过以下方式退出:

在nodejs的REPL中输入.exit。 按两次<ctrl>-C。 按< ctrl > - d。 process.exit(0)表示从REPL中自然退出。如果你想返回任何其他状态,你可以返回一个非零的数字。 process.kill(process.pid)是使用nodejs api从代码中或从REPL中进行kill的方法。


恢复并终止进程:

Ctrl+Z挂起它,这意味着它仍然作为挂起的后台进程运行。

你现在可能会看到终端提示……

在前台输入fg命令恢复进程。 按Ctrl+C正确地杀死它。


或者,你可以像这样手动杀死它:

(注意:以下命令可能需要root,所以sudo…是你的朋友吗?

pkill -9 node

或者,如果你没有pkill,这可以工作:

killall node

或许是这样:

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

有时进程会列出它自己的grep,在这种情况下,你需要:

kill $(ps -e | grep dmn | awk '{print $2}')

.


H /t @ruffin来自对问题本身的评论。我也有同样的问题,他的评论帮助我自己解决了问题。


我遇到了一个问题,有多个节点服务器正在运行,我只想杀死其中一个并从脚本重新部署它。

注意:这个例子在Mac上的bash shell中。

为此,我确保我的节点调用尽可能具体。例如,我没有从apps目录调用节点server.js,而是调用节点app_name_1/app/server.js

然后我可以杀死它使用:

Kill -9 $(ps aux | grep 'node\ app_name_1/app/server.js' | awk '{print $2}')

这只会杀死运行app_name_1/app/server.js的节点进程。

如果你运行节点app_name_2/app/server.js,该节点进程将继续运行。

如果你决定杀死他们,你可以使用killall节点,就像其他人提到的那样。


我添加这个答案是因为对于许多具有生产部署的项目,我们有停止这些过程的脚本,所以我们不必这样做。

管理Node Server进程的一种干净的方法是使用永久包(来自NPM)。

例子:

安装永远

NPM install forever -g

运行节点服务器

永久启动-al ./logs/ Forever .log -ao ./logs/out.log -ae ./logs/err.log server.js

结果:

永远处理文件:server.js

关机节点服务器

永远停止server.js

结果

永久停止进程: Uid命令脚本永久pid id logfile正常运行时间 [0] sBSj "/usr/bin/nodejs/node" ~/path/to/your/project/server.js 23084 13176 ~/.forever/forever.log 0:0:0:0:0.247

这将彻底关闭服务器应用程序。


Linux下尝试:pkill节点

在windows上:

Taskkill /IM node.exe /F

or

from subprocess import call

call(['taskkill', '/IM', 'node.exe', '/F'])

我的用例:在MacOS上,通过脚本在不同端口上运行/重新运行多个节点服务器

运行:“cd $PATH1 && node server1.js & cd $PATH2 && node server2.js &…”

stop1: "kill -9 $(lsof -nP -i4TCP:$PORT1 | grep LISTEN | awk '{print $2}')"

stop2 stop3…

重新运行:“stop1 & stop2 &…& stopN;运行

有关通过端口查找进程的更多信息:谁正在监听Mac OS X上的给定TCP端口?


在windows上,用CTRL+ALT+DEL打开任务管理器,然后杀死Node.js进程可以解决这个错误。


对于windows,首先用端口号搜索PID

netstat -ano | findStr "portNumber"

在那之后,杀死任务,确保你在根你的“c”驱动器 命令是taskkill /F /PID你的PID


你可以在localserver kill中使用以下命令(这里是8000)

http://localhost:8000/ kill PID(processId):

$:lsof -i tcp:8000

它会给你以下几组tcp:

命令pid user fd类型设备大小/关闭节点名称 节点21521 ubuntu 12u IPv6 345668 0t0 TCP *:8000 (LISTEN)

$:kill -9 21521

它将杀死TCP*:8000对应的processId


是操作系统

打开终端 运行下面的代码并按enter键 Sudo kill $(Sudo lsof -t:4200)


你可以使用fuser来完成你想做的事情。

为了获取运行在端口上的任务的进程号,您可以执行以下操作:

fuser <<target_port>>/tcp

假设端口是8888,命令变成:

fuser 8888/tcp

要终止端口上运行的进程,只需添加-k开关。

fuser <<target_port>>/tcp -k

示例(端口为8888):

fuser 8888/tcp -k

就是这样!它将关闭监听端口的进程。 我通常在运行服务器应用程序之前这样做。


如果你使用VS Code和终端选择节点从右边的下拉菜单,然后按Ctrl + c,然后它将工作

出现提示时按“y”。

谢谢