![](/img/trans.png)
[英]Emitting data to all the users in given channel - Nodejs (Socket.io)
[英]NodeJS with Socket.IO delay emitting data
我正在使用Socket.IO主页(http://socket.io/)中的示例。 它可以工作,但是在发送数据和在另一端接收数据之间存在很大的延迟。
我正在使用XAMPP,我在我的目录中有socket.html,并在浏览器中使用“http://localhost/socket.html”导航到它,我让服务器在端口8080上侦听。
服务器:
var io = require('socket.io').listen(8080);
io.sockets.on('connection', function (socket) {
socket.emit('news', { hello: 'world' });
socket.on('my other event', function (data) {
console.log(data);
});
});
HTML文件:
<html>
<head>
<script src="http://localhost:8080/socket.io/socket.io.js"></script>
<script>
var socket = io.connect('http://localhost:8080');
socket.on('news', function (data) {
console.log(data);
socket.emit('my other event', { my: 'data' });
});
</script>
</head>
<body>
</body>
</html>
我发现了这个问题。
在服务器中我改变了:
var io = require('socket.io').listen(8080);
至
var io = require('socket.io', { rememberTransport: false, transports: ['WebSocket', 'Flash Socket', 'AJAX long-polling'] }).listen(8080);
这会强制服务器使用WebSockets,Flash套接字或长轮询。 它会尝试按顺序使用它们。 rememberTransport强制服务器和客户端忘记它最后使用的连接,并尝试连接上面的“传输”。
在客户端,我几乎做了同样的事情。 我补充说:
{ rememberTransport: false, transports: ['WebSocket', 'Flash Socket', 'AJAX long-polling']}
到socket构造函数。 所以它看起来像:
var socket = io.connect('http://localhost:843', { rememberTransport: false, transports: ['WebSocket', 'Flash Socket', 'AJAX long-polling']});
现在看起来效果很好。
多谢你们。
你试过更长的消息吗?
套接字肯定有缓冲区。 如果发送少于X个字节,则在刷新缓冲区之前可能会有一些等待时间,因为它没有被填充。
使用websockets改进了行为,因为它禁用了缓冲。 Websockets是使用setNoDelay(true)
实现的,如websockets代码中所示,因此它不会缓冲消息。
您可以通过将websocket
首先放在transports
数组中来明确请求websockets。 在最新版本的socket.io
和engine.io
,正确的参数和实现如下所示:
import socketIO from 'socket.io';
const server = express();
const requestHandler = server.listen(PORT, () => console.log(`Listening on ${PORT}`));
const io = socketIO(requestHandler, { transports: ['websocket', 'polling'] });
在客户端:
import io from 'socket.io-client';
let socket = io(SERVER_URL, { transports: ['websocket', 'polling'] });
你使用的是什么浏览器? Socket.IO降级为轮询,这将比本机浏览器Web套接字或闪存轮询慢得多。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.