使用带有node-webkit的expressjs时的EADDRINUSE

时间:2015-02-22 07:35:25

标签: node.js express socket.io node-webkit nw.js

我想将nw.js用作独立的套接字客户端和服务器。我试图将socket.io网站上的sample socket.io聊天应用程序放入nw.js应用程序中。但是当我启动nw.js时出现以下错误:

[5591:0222/143044:ERROR:nw_shell.cc(325)] Error: listen EADDRINUSE :::3000
    at Object.exports._errnoException (util.js:734:11)
    at exports._exceptionWithHostPort (util.js:757:20)
    at Server._listen2 (net.js:1153:14)
    at listen (net.js:1179:10)
    at Server.listen (net.js:1266:5)
    at Object.<anonymous> (/Users/xxxx/nwjs/chat-example/index.js:23:6)
    at Module._compile (module.js:451:26)
    at Object.Module._extensions..js (module.js:469:10)
    at Module.load (module.js:346:32)
    at Function.Module._load (module.js:301:12)

我尝试过多个端口但没有工作。 这是我用于服务器的代码,它与socket.io指南提供的代码大致相同。

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);

app.get('/', function(req, res){
    res.sendFile(__dirname + '/index.html');
});


io.on('connection', function(socket){
    console.log('a user connected');
    socket.on('disconnect', function(){
        console.log('user disconnected');
    });


    socket.on('chat message', function(msg){
        console.log('message: ' + msg);
        io.emit('chat message', msg);
    });
});

http.listen( 3000, function(){
    console.log('listening on *:3000');
});

这是我的package.json for nw.js

{
  "name": "socket-chat-example",
  "version": "0.0.1",
  "description": "my first socket.io app",
  "dependencies": {
    "express": "^4.10.2",
    "socket.io": "^1.3.4"
  },
  "main": "index.html",
  "node-main": "index.js"
}

我的nwjs版本: v0.12.0-alpha3-osx-x64

2 个答案:

答案 0 :(得分:2)

查看node-webkit-express了解工作示例。

我无法解释原因,但通过“node-main”启动express是导致问题的原因。也许这是一个多进程问题或者其他什么......但你可以做到。

答案 1 :(得分:0)

每次重新加载,刷新或打开新窗口时,都会运行node-main脚本。 基本上,您希望将服务器脚本作为bg-script启动。这是manifest docs。在应用程序运行时,后台脚本运行一次,因此您应该启动服务器。

您可能还想听nwjs窗口close event,这样当应用程序关闭时,您可以正常关闭服务器并进行清理。