我已经在一个node.js项目上工作了几个星期,它一直工作得很好。通常,我使用npm start来运行我的应用程序,并在localhost上的浏览器中查看它,端口3000。
今天,我在使用npm start时开始得到以下错误:
Server started on port 3000
Port 3000 is already in use
我已经检查了资源监视器,我没有在端口3000上运行其他进程。我为什么会得到这个错误消息?
在我的app.js中,我有以下代码来设置端口…这是错误的吗?它以前工作得很好,所以我不确定我做错了什么。
// Set Port
app.set('port', (process.env.PORT || 3000));
app.listen(app.get('port'), function() {
console.log('Server started on port '+app.get('port'));
});
谢谢你的帮助!
编辑:
我已经尝试运行netstat和TCPView来检查哪个进程正在使用该端口,但是没有使用该端口。我也尝试重新启动我的笔记本电脑,但我仍然得到同样的错误。
只是想提一个已经给出的答案没有涵盖的问题。它与Hyper-V(和Docker)有关“窃取”端口:
摘自Docker问题(链接如下):
禁用hyper-v(这需要重新启动几次)
dism.exe /Online /Disable-Feature:Microsoft-Hyper-V
当您完成所有必需的重新启动时,保留您想要的端口,这样hyper-v就不会再保留它
netsh int ipv4 add excludedportrange protocol=tcp startport=3000 numberofports=1
重新启用hyper-V(这需要重新启动几次)
dism.exe /Online /Enable-Feature:Microsoft-Hyper-V /All
https://github.com/docker/for-win/issues/3171#issuecomment-459205576
终止拥有端口3000的进程
首先,让我们看看如何终止打开端口的进程。
使用lsof命令,我们可以检索具有给定端口的PID:
$ lsof -i :3000 -t
12345
然后我们可以通过这样做来终止这个进程:
$ kill 12345
让我们把它变成一行代码:
lsof -i 3000 -t | xargs kill
如果你使用环境变量来设置服务器端口,我们可以指定它,而不是硬编码我们的值:
lsof -i ${PORT} -t | xargs kill
最后,如果没有设置环境变量,我们可以默认端口3000:
lsof -i ${PORT:-3000} -t | xargs kill
没有恶魔来执行钩子
Nodemon允许你通过Nodemon设置事件钩子。Json配置文件:
{
"events": {
"crash": "sh -c 'lsof -i :${PORT:-3000} -t | xargs kill'"
}
}
这将导致nodemon在应用程序崩溃时执行sh -c 'lsof -i:${PORT:-3000} -t | xargs kill命令,从而杀死它所生成的保持端口打开的子进程。
或者你可以试试这个
fuser -k PORT-NO/tcp
Eg:
fuser -k 3000/tcp
你也可以试试这个
fuser -n tcp -k PORT-NO
Eg:
fuser -n tcp -k 3000
在MAC
kill -9 $(lsof -ti:PORT_NO)
Eg:
kill -9 $(lsof -ti:9229)
我在NodeJS上使用nodemon快速服务器。
我收到以下消息,这似乎是一个错误:
$ node ./bin/www
Port 3000 is already in use
有一个通用的解决方案,如果您终止所有节点服务器连接,则可以在包中添加此代码。json文件:
"scripts": {
"start": "node ./bin/www",
"stop": "taskkill -f -im node.exe"
},
此外,我还找到了几个解决方案,windows命令和bash在win10 x64。
我所有的笔记都在这里:
#终止所有NodeJS服务器连接
$ taskkill -f -im node.exe
SUCCESS: The process "node.exe" with PID 14380 has been terminated.
SUCCESS: The process "node.exe" with PID 18364 has been terminated.
SUCCESS: The process "node.exe" with PID 18656 has been terminated.
#示例:打开Windows任务管理器,查看Windows上的“node.exe”PID编号
>> Command Line
$ netstat /?
$ netstat -a -n -o
$ netstat -ano
#根据端口号杀死Windows进程(示例)
寻求帮助:
$ taskkill /?
$ tskill /?
代码1:
$ taskkill -pid 14228
ERROR: The process with PID 14228 could not be terminated.
Reason: This process can only be terminated forcefully (with /F option).
代码2:
$ taskkill -f -pid 14228
SUCCESS: The process with PID 14228 has been terminated.
代码3:
$ tskill 14228
#查看特定端口的命令行
在cmd:
$ netstat -ano | find "14228"
在bash中:
$ netstat -ano | grep "14228" or $ netstat -ano | grep 14228
使用tasklist命令找到node.exe
在cmd:
$ tasklist | find "node"
在bash中:
$ tasklist | grep node
$ tasklist | grep node.exe
node.exe 14228 Console 2 48,156 K
node.exe 15236 Console 2 24,776 K
node.exe 19364 Console 2 24,428 K