Mote.ioの開発中に同様の問題に遭遇し、ロード バランサーを構築する代わりに、ホストされたソリューションを使用することにしました。サーバー間でデータを同期するか、クライアントが同じインスタンスに負荷を分散して、すべて同じメッセージを確実に受信できるようにする必要があるため、この問題に対処するのは非常に困難です。
特にSocket.ioはあまり役に立ちません。redis、その他のデータ同期または負荷分散アプリを実装する必要があります。
これも PubNub が処理します。バックエンドは抽象レベルでメッセージの同期、負荷分散などを担当するため、チャネル名を指定するだけで、PubNub はそのチャネル内のすべてのクライアントがメッセージを確実に受信できるようにします。
10 行のコードによるリアルタイム チャット アプリ
Enter Chat and press enter
<div><input id=input placeholder=you-chat-here /></div>
Chat Output
<div id=box></div>
<script src=http://cdn.pubnub.com/pubnub.min.js></script>
<script>(function(){
var box = PUBNUB.$('box'), input = PUBNUB.$('input'), channel = 'chat';
PUBNUB.subscribe({
channel : channel,
callback : function(text) { box.innerHTML = (''+text).replace( /[<>]/g, '' ) + '<br>' + box.innerHTML }
});
PUBNUB.bind( 'keyup', input, function(e) {
(e.keyCode || e.charCode) === 13 && PUBNUB.publish({
channel : channel, message : input.value, x : (input.value='')
})
} )
})()</script>