当我运行节点项目时指定的端口说未定义。
> sf-chain@1.0.0 dev E:Systemdevnodesf-chain
> nodemon ./app "HTTP_PORT=3002" "P2P_PORT=5002" "PEERS=ws://localhost:5001"
[nodemon] 1.18.3
[nodemon] to restart at any time, enter `rs`
[nodemon] watching: *.*
[nodemon] starting `node ./app HTTP_PORT=3002 P2P_PORT=5002 PEERS=ws://localhost:5001`
process.env.HTTP_PORT :: undefined
HTTP_PORT :: 3001
Listening for peer-to-peer connections on: 5001
events.js:160
throw er; // Unhandled 'error' event
^
Error: listen EADDRINUSE :::3001
at Object.exports._errnoException (util.js:1022:11)
at exports._exceptionWithHostPort (util.js:1045:20)
at Server._listen2 (net.js:1259:14)
at listen (net.js:1295:10)
at Server.listen (net.js:1391:5)
at EventEmitter.listen (E:Systemdevnodesf-chainnode_modulesexpresslibapplication.js:618:24)
at Object.<anonymous> (E:Systemdevnodesf-chainappindex.js:28:5)
at Module._compile (module.js:570:32)
at Object.Module._extensions..js (module.js:579:10)
at Module.load (module.js:487:32)
[nodemon] app crashed - waiting for file changes before starting...
我使用运行了第一个实例
npm run dev
const HTTP_PORT=process.env.HTTP_PORT||3001;
由于我没有在run命令中指定HTTP_port,应用程序在端口3001上成功启动运行。但是,当尝试通过使用以下命令指定HTTP_PORT来运行另一个实例时
npm run dev HTTP_PORT=3002 P2P_PORT=5002 PEERS=ws://localhost:5001
我得到这个错误。
Error: listen EADDRINUSE :::3001
这意味着在运行时指定的HTTP_PORT被视为未定义,这就是它试图将3001端口用于第一个实例的原因。
错误:侦听EADDRINUSE-当某个东西已经在该端口上运行/侦听时,就会出现错误
这是因为同一nodejs的某个实例获取了端口,并且没有正确地终止/退出进程,
如果你有Ubuntu,请先通过检查哪个进程正在使用端口
lsof -i :3001 // Port no.
那么输出将是这样的。
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
node 2496 nasiruddin 13u IPv6 37696 0t0 TCP *:3001 (LISTEN)
使用PID杀死
kill 2496
然后重新启动