2016-05-24 14 views
1

私はsocket.ioとnode.jsで簡単なアプリケーションを作成しました。これはプッシュ通知サービスです。 ユーザがWebSocketに接続すると、ユーザ名(およびダッシュボードの名前)が送信され、すぐにユーザ名の部屋に参加します。アプリケーションはPOST要求をリッスンし、保存してユーザーの部屋にメッセージを送信します。Socket.IOルームはAzureでは動作しませんが、ローカルで作業しています

io.on('connection', function(socket) { 
    socket.on('userid', function(data) { 
     socket.join(data.userid+'-'+data.dashboard); 
     notification.find({userid: data.userid, to: data.dashboard, received_by_user: false}, function(err, notifs) { 
      socket.emit('get_notifications', notifs); 
     } 
    } 
}); 
app.post('/notify', function(req, res, next) { 
    var notif_recv = new notification(req.body); 
    notif_recv.save(function (err, notif_recv) { 
     io.sockets.in(notif_recv.userid+'-'+notif_recv.dashboard).emit('new_notification', notif_recv); 
    }); 
res.send(200); 
}); 

私は、ローカルノードでそれをテストするとき、それは私が/notifyPOSTを送信し、私は通知がダッシュボードに到着見ることができ、正常に動作します。問題は、私がAzureのAppServiceでテストすると、クライアントはWebSocketに接続して最初の通知(get_notificationsイベント)を受信しますが、POSTから/notifyになると、クライアントは何も受信しません。 (no new_notificationイベント、io.sockets.in(...).emit(...)はAzureで動作しないようです)。デバッグ目的のために

は、私はio.socket.in(...).emit(...)は、任意のチャンネルと接続せずに、IOサーバーを返すように思われること、その結果、サーバーの機能socket.join(...)io.sockets.in(...).emit(...)の戻り値をログに記録するにconsole.log(...)を使用しました!

IISはそれを乱用する可能性がありますか?私はIISがapp.post('/notify'...io.on('connection'...のために異なるプロセスを持っていると思う傾向があるので、私がapp.postで参照しているソケットは、私がio.on('connection'..socket.join(...))というユーザに加わっているからです。

Azure/IISでsocket.ioの部屋を使用するときのヒント? ありがとう!

+0

アプリケーションでポートをどのように設定しますか?あなたは 'app.listen(process.env.PORT);を使用しようとしましたか? –

+0

はい、私は 'varポート= normalizePort(process.env.PORT || '8090'); ' 私は問題がIISがSocket.IO部屋のプロトコルで厄介だと思う... – jam

答えて

0

Azure App Servicesでsocket.ioおよびの問題をテストするには、プロジェクトを簡略化し、Azureでテストしてください。

テストserver.js

var app = require('express')(); 
var server = require('http').Server(app); 
var io = require('socket.io')(server); 
var bodyParser = require('body-parser') 
app.use(bodyParser.json());  // to support JSON-encoded bodies 
app.use(bodyParser.urlencoded({  // to support URL-encoded bodies 
    extended: true 
})); 
server.listen(process.env.PORT ||3000, function(){ 
    console.log('listening on *:3000'); 
}); 

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

app.post('/notify', function(req, res, next) { 
    io.sockets.emit('new_notification', req.body); 
    res.send(200); 
}); 

io.on('connection', function (socket) { 
    socket.emit('get_notifications', "get_notifications_:"+new Date()); 
}); 

クライアントのコンテンツ:

<body> 
    <script src="/socket.io/socket.io.js"></script> 
    <script src="http://code.jquery.com/jquery-1.11.1.js"></script> 
    <script> 
    var socket = io(); 
    $.post("/notify",{ 
     msg:"notification from client" 
    }); 
    socket.on('get_notifications',function(msg){ 
     console.log(msg); 
    }); 
    socket.on('new_notification',function(msg){ 
     console.log(msg); 
    }); 
    </script> 
    </body> 

そして、この単純なプロジェクトはAzureのアプリケーションサービスに正常に動作します。

これは、問題を引き起こすアプリケーションの別の部分である可能性があります。

Diagnostics Logsを確認するか、Visual Studio Team Servicesを利用して問題のトラブルシューティングを行うことができます。 Azure App ServicesでTeam Services拡張を有効にする方法については、How to run django manage.py command on Azure App Serviceの回答を参照してください。

さらに詳しいことがありましたら、お気軽にお知らせください。

0

デバッグ用に「切断」ハンドラを追加しましたか?

io.on('connection', function (socket) { 
    socket.on('disconnect', function(){ //add this part 
    console.log('Client disconnected');  
    }); 
    socket.emit('get_notifications', "get_notifications_:"+new Date()); 
}); 

また、すべてのログを送信して受信するので、クライアントが切断されたタイミングを知ることができます。 get_notificationsイベントの後に接続が切断される場合は、クライアントにコールバックを送信していないこと、またはクライアントがサーバーからのコールバックを期待していないことを確認してください。

notification.find(..)socket.on('userid'..)の中かっこの一部が欠落しています。私はあなたがここに貼り付けたコードの中にあることを願っています。

関連する問題