表达api,为什么会出现错误:监听EADDRINUSE ::: 5000

时间:2019-07-23 10:11:21

标签: node.js api express

我正在使用此代码创建一个简单的快速api

//server.js
const express = require('express');
const mongoose = require('mongoose');
const bodyParser = require('body-parser');

const app = express();

app.use(bodyParser.json());

const db = require('./config/keys').mongoURI;

mongoose
  .connect(db, { useNewUrlParser: true })
  .then(() => console.log('db connected'))
  .catch(err => console.error(err))

const port = process.env.PORT || 5000;

app.listen(port, () => console.log('server connected'))



//config/keys.js
module.exports = {
  mongoURI: 'mongodb://db address'
};

当我运行它或对文件进行更改时,我总是会收到错误消息

Error: listen EADDRINUSE :::5000
    at Server.setupListenHandle [as _listen2] (net.js:1327:14)
    at listenInCluster (net.js:1375:12)
    at Server.listen (net.js:1462:7)
    at Function.listen (/Users/user/Desktop/mern-2/node_modules/express/lib/application.js:618:24)
    at Object.<anonymous> (/Users/user/Desktop/mern-2/server.js:18:5)
    at Module._compile (internal/modules/cjs/loader.js:702:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:713:10)
    at Module.load (internal/modules/cjs/loader.js:612:32)
    at tryModuleLoad (internal/modules/cjs/loader.js:551:12)
    at Function.Module._load (internal/modules/cjs/loader.js:543:3)
    at Function.Module.runMain (internal/modules/cjs/loader.js:744:10)
    at startup (internal/bootstrap/node.js:238:19)
    at bootstrapNodeJSCore (internal/bootstrap/node.js:572:3)
Emitted 'error' event at:
    at emitErrorNT (net.js:1354:8)
    at process._tickCallback (internal/process/next_tick.js:63:19)
    at Function.Module.runMain (internal/modules/cjs/loader.js:746:11)
    at startup (internal/bootstrap/node.js:238:19)
    at bootstrapNodeJSCore (internal/bootstrap/node.js:572:3)

我可以先运行lsof -i :5000然后再运行kill返回的节点来解决此问题

为什么会出现此错误,并且有办法阻止它

1 个答案:

答案 0 :(得分:1)

错误mainWindow.loadURL('http://localhost:3000'); 是自描述的。

好像另一个应用程序正在监听端口Error: listen EADDRINUSE :::5000,或者同一应用程序的另一个实例已经在系统中运行。

您的终止进程的解决方案有效-因为在那里您终止了监听端口5000的进程。

从给出的信息中并不能立即得知它是您自己的应用程序的另一个实例还是使用端口5000的其他应用程序。

如果它是另一个应用程序(您可以通过查看5000来确定),则应使用另一个端口。

如果它是您自己应用程序的另一个实例,请确保在编辑之前终止正在运行的实例(lsof -i -n -P)。

也许您可以使用DotNetSeleniumExtras