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. 在代码中增加端口检测逻辑,避免应用崩溃。

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

相关推荐
头发多多程序媛1 天前
解决依赖下载报错,npm ERR! code EPERM
前端·npm·node.js
fanjinzhi1 天前
Node.js通用计算15--TypeScript介绍
javascript·typescript·node.js
light blue bird1 天前
MES/ERP的Web多页签报表系统
数据库·node.js·ai大数据·mes/erp·web报表
Doris8931 天前
【Node.js 】Node.js 与 Webpack 模块化工程化入门指南
前端·webpack·node.js
alanesnape1 天前
在 Surface Pro X (ARM64) 上成功部署 Claude Code 的完整复盘
git·node.js·claude code部署·msys2clangarm64·美区apple id·礼品卡支付·surface pro x
MuShan-bit1 天前
CSDN-推荐开源项目-auto-x-to-wechat
爬虫·微信·开源·node.js·twitter
JohnsonXin1 天前
一次线上白屏排查:静态 import 是如何悄悄破坏 Webpack 共享 Chunk 的
前端·webpack·node.js
徐小夕@趣谈前端1 天前
借助AI,1周,0后端成本,我们开源了一款Office预览SDK
前端·人工智能·开源·node.js·编辑器·github·格式工厂
None3212 天前
【NestJs】Websocket 通关指南:从入门到实战
后端·node.js