nodejsでredisとsocketioを使用してpubsubを試しています。
私のサーバー側のコードは次のとおりです。
var io = require('socket.io').listen(server);
var pub = redis.createClient();
io.sockets.on("connection", function(socket) {
console.log('connecteed');
var sub = redis.createClient();
sub.subscribe("messages");
sub.on("message", function(channel, message) {
console.log('message',message);
socket.emit(channel,message);
});
socket.on("disconnect", function() {
sub.unsubscribe("messages");
sub.quit();
});
});
pub.publish("messages", JSON.stringify({type: "foo", content: "bar"}));
私のhtmlページindex.htmlには、次のスクリプトが含まれています。
var host = window.location.host.split(':')[0];
var socket = io.connect('http://' + host);
socket.on('messages',function(msg){
console.log(msg);
})
ただし、index.htmlではconsole.logが実行されることはありません。
初歩的なものですが、コードにエラーが見つかりません。それはどこにある?