使用Nodemon在每次保存时都会生成EADDRINUSE

时间:2020-08-28 12:54:53

标签: node.js express nodemon

我使用Ubuntu 20.04,Nodemon 2.0.4,Node 14.9.0和Express 4.17.1。每次保存代码时,都会出现此错误:

events.js:291
      throw er; // Unhandled 'error' event
      ^

Error: listen EADDRINUSE: address already in use :::3000
    at Server.setupListenHandle [as _listen2] (net.js:1318:16)
    at listenInCluster (net.js:1366:12)
    at Server.listen (net.js:1452:7)
    at Function.listen (/home/ubuntu/kopum/node_modules/express/lib/application.js:618:24)
    at Object.<anonymous> (/home/ubuntu/kopum/app.js:37:5)
    at Module._compile (internal/modules/cjs/loader.js:1075:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1096:10)
    at Module.load (internal/modules/cjs/loader.js:940:32)
    at Function.Module._load (internal/modules/cjs/loader.js:781:14)
    at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:72:12)
    at internal/main/run_main_module.js:17:47
Emitted 'error' event on Server instance at:
    at emitErrorNT (net.js:1345:8)
    at processTicksAndRejections (internal/process/task_queues.js:80:21) {
  code: 'EADDRINUSE',
  errno: -98,
  syscall: 'listen',
  address: '::',
  port: 3000
}
[nodemon] app crashed - waiting for file changes before starting...

然后我尝试在终端上运行它:

sudo lsof -i :3000
kill -9 {PID}

然后我通过运行nodemon app.js重新启动Nodemon,一切恢复正常。但是,当我添加一些代码并保存时,EADDRINUSE又回来了。

3 个答案:

答案 0 :(得分:4)

当我遇到类似问题时,一个简单的修复方法是delay Nodemon稍微重启:

nodemon --delay 500ms app.js

这似乎为正确释放端口提供了一些时间。

答案 1 :(得分:0)

似乎nodemon在启动之前无法正确终止子生成进程;

scripts文件中编辑package.json属性,并添加kill命令,以在服务器启动之前终止监听您端口的所有进程。

"scripts": {
    "start": "npm run kill && nodemon app.js",
    "kill": "kill -9 $(lsof -i :3000) &>/dev/null | exit 0"
}

答案 2 :(得分:0)

在每个保存命令之后尝试运行npx kill-port 3000