Node.js 端口占用错误及解决方案:从 EADDRINUSE 到成功启动服务器

在 Node.js 开发过程中,端口冲突 (EADDRINUSE: address already in use) 是一个常见的错误。这篇文章将基于一次真实的调试过程,深入解析该错误的成因,并提供详细的解决方案。

一、错误分析

在启动 Node.js 服务器时,遇到了以下错误:

复制代码
Error: listen EADDRINUSE: address already in use :::8060
    at Server.setupListenHandle [as _listen2] (node:net:1872:16)
    at listenInCluster (node:net:1920:12)
    at Server.listen (node:net:2008:7)
    ...

错误解读

  • EADDRINUSE:表示端口 8060 已经被占用,导致当前服务器无法正常监听该端口。
  • listen:表明问题出现在 server.listen() 方法,即 Express 服务器试图绑定端口时失败。

二、问题排查

1. 检查端口占用情况

使用 netstat 命令来查找 8060 端口的占用情况:

复制代码
netstat -ano | findstr :8060 

输出如下:

TCP 0.0.0.0:8060 0.0.0.0:0 LISTENING 37584 TCP [::]:8060 [::]:0 LISTENING 37584

可以看到,进程 37584 正在监听 8060 端口。

2. 终止占用端口的进程

使用 taskkill 命令终止该进程:

复制代码
taskkill /PID 37584 /F

如果终止成功,则端口 8060 释放,此时可以重新启动服务器。

然而,在这次调试过程中,执行 taskkill 时遇到了 "系统找不到指定的文件" 的问题。这通常意味着:

  • 进程已经自行退出,但端口仍然被占用。
  • 进程 ID (PID) 发生了变化,需要重新获取最新的 PID 进行终止。

3. 解决无法找到进程的问题

如果 taskkill 无法终止进程,可以尝试:

复制代码
netstat -ano | findstr :8060

再次确认端口状态。如果仍然显示 LISTENING,可以使用以下方法强制释放端口:

方法 1:重启服务器

在 Windows 上可以执行:

复制代码
shutdown -r -t 0

这将立即重启计算机并释放所有端口。

方法 2:使用 PowerShell 释放端口

如果不想重启,可以用 PowerShell 终止占用进程:

复制代码
Stop-Process -Id 37584 -Force

或者:

复制代码
Get-Process | Where-Object { $_.Id -eq 37584 } | Stop-Process -Force

三、服务器成功启动

在成功释放 8060 端口后,重新运行 npm start,服务器正常启动:

Server is up and running on port: 8060 Database initialized! query: SELECT COUNT(1) AS `cnt` FROM `tasks` `tasks` query: SELECT task_id, project_id, title, description, status FROM `tasks` ORDER BY task_id DESC LIMIT 10

日志显示服务器正在查询数据库,并返回 tasksusers 表的数据,证明应用已经恢复正常。

四、如何预防端口占用问题?

为了避免 EADDRINUSE 错误,可以采取以下措施:

1. 启动前检查端口是否被占用

可以在 app.ts 中添加以下代码:

复制代码
import net from 'net'; const PORT = 8060; const server = net.createServer(); server.once('error', (err: any) => { if (err.code === 'EADDRINUSE') { console.error(`Port ${PORT} is already in use. Please choose a different port.`); process.exit(1); } }); server.once('listening', () => server.close()); server.listen(PORT);

这样,在服务器启动时会检测端口是否被占用,避免直接崩溃。

2. 自动寻找可用端口

可以使用 portfinder 自动查找可用端口:

复制代码
import express from 'express'; import portfinder from 'portfinder'; const app = express(); portfinder.getPortPromise() .then((port) => { app.listen(port, () => { console.log(`Server running on port ${port}`); }); }) .catch((err) => console.error(err));

3. 使用 process.env.PORT

.env 文件中定义端口:

复制代码
PORT=8060

然后在 app.ts 里使用:

复制代码
const PORT = process.env.PORT || 3000; app.listen(PORT, () => console.log(`Server running on port ${PORT}`));

这样可以灵活调整端口,避免冲突。


五、总结

在本次调试过程中,我们遇到了 EADDRINUSE 端口占用错误,经过以下步骤成功解决:

  1. 使用 netstat 确定占用端口的进程。
  2. 使用 taskkill 终止进程,或通过 PowerShell 释放端口。
  3. 若仍然占用,可以重启计算机或动态分配端口。
  4. 在代码中增加端口检测逻辑,避免应用崩溃。

希望这篇文章能帮助你解决类似的端口冲突问题!🚀

相关推荐
还是鼠鼠2 小时前
Node.js 如何发布一个 NPM 包——详细教程
前端·vscode·npm·node.js
有人说风轻的像雨14 小时前
使用 Node.js 和 163 邮箱发送邮件
node.js
还是鼠鼠18 小时前
Node.js 监听 GET 和 POST 请求并处理参数
前端·javascript·vscode·node.js·json
bnnnnnnnn18 小时前
宝塔面板快速部署 Node.js + Express 后端,一步到位!
前端·后端·node.js
编代码的小王18 小时前
Node.js 批量修改文件名脚本
node.js
南囝coding19 小时前
做定时任务,一定要用这个神库!!
前端·面试·node.js
前端的阶梯19 小时前
Electron中深度解读实现多tabs的几种方式
electron·node.js
莫循瑾木1 天前
莫循跃迁:nvm管理node版本速通
前端·后端·node.js
还是鼠鼠1 天前
认识 Express.js:Node.js 最流行的 Web 框架
开发语言·前端·javascript·vscode·node.js·json·express
zxg_神说要有光2 天前
Three.js 小册上线了,我最重要的一部作品
前端·javascript·node.js