node.js + socket.io - duplicate websocket writes?

前端 未结 1 1794
有刺的猬
有刺的猬 2021-01-22 08:15

I\'m new to the node.js and socket.io scene, so this may be a simple fix... but here goes. I have the following POC for taking in messages via UDP and echoing them back to a br

1条回答
  •  栀梦
    栀梦 (楼主)
    2021-01-22 09:15

    As far as I can tell without having node to test on; you're not really interested in doing anything on socket.io connection events as long as the client doesn't send any data you need to handle, so you should be able to ignore them. What you want is only to receive UDP events and broadcast to all clients that are connected right then, which should be as simple as;

    ...
    var io = require('socket.io').listen(server);
    server.listen(12345);  //tcp http listener
    
    udpserver.on('message', function (msg, rinfo) {
        io.sockets.emit('update', msg.toString());
    });
    

    Just for completeness; what your current code does is to add a new UDP message callback for every new socket.io connection. The callback broadcasts to all clients, which means that when the second client connects, all broadcasts will happen 2 times to all clients, for 3 clients 3 times to all clients etc. You only want to set the UDP message handler up once since it broadcasts to all connected clients anyway.

    0 讨论(0)
提交回复
热议问题