我使用ws4py.websocket包创建了一个安全的WebSocket服务器。
javascript客户端连接到此Websocket并向其发送一些JSON消息。
现在,当我的JS客户端关闭连接(function disconnect
)时,在调用服务器的closed
函数之前需要大约30个secondes
以下是代码:
服务器
class ControlWebSocket(WebSocket):
def opened(self):
print("Client connected")
def closed(self, code, reason=None):
print("Connection closed [%d]" % (code))
def received_message(self, m):
#some business logic using 'm'
server = make_server('', 8999, server_class=WSGIServer, handler_class=WebSocketWSGIRequestHandler, app=WebSocketWSGIApplication(handler_cls=ControlWebSocket))
server.socket = ssl.wrap_socket (server.socket, certfile='./cert.pem', keyfile='key.pem', server_side=True)
server.initialize_websockets_manager()
server.serve_forever()
客户端
ws = new WebSocket("wss://192.168.42.1:8999/");
ws.onopen = function() {
console.log("Connected to WebSocket server");
};
ws.onmessage = function(e) {
//some business logic using e
};
ws.onclose = function() {
console.log("Disconnected from WebSocketServer");
};
function disconnect() {
console.log("Disconnecting from WebSocketServer");
ws.close();
}
关于为什么关闭连接这么长时间的任何线索?有没有办法更快地终止连接?
答案 0 :(得分:2)
这是您的客户端问题。如果您查看ws
模块。在顶部你有
const closeTimeout = 30 * 1000; // Allow 30 seconds to terminate the connection cleanly.
然后你有以下代码
if (!this._finalized) {
if (this._closeFrameReceived) this._socket.end();
//
// Ensure that the connection is cleaned up even when the closing
// handshake fails.
//
this._closeTimer = setTimeout(this._finalize, closeTimeout, true);
}
这是为了确保连接在30秒之前不会关闭,并为每一方提供足够的时间来清理连接。这个时间是const
,而不是configurable
。但是,如果您希望立即发生终止,您可以在ws.finalize()
之后添加ws.close()
,它会立即断开
const WebSocket = require('ws');
let ws = new WebSocket("wss://127.0.0.1:8999/", {
rejectUnauthorized: false
});
ws.onopen = function() {
console.log("Connected to WebSocket server");
};
ws.onmessage = function(e) {
//some business logic using e
};
ws.onclose = function() {
console.log("Disconnected from WebSocketServer");
};
function disconnect() {
console.log("Disconnecting from WebSocketServer");
ws.close();
ws.finalize();
}
setTimeout(disconnect, 100)
修改-1 强>
在深入挖掘之后,ws4py
似乎有一些不符合rfc6455的内容。
当您从NodeJS关闭时,它会发送一个\x88\x80
的关闭帧,表示应该关闭连接并应该发送一个关闭帧。文件ws4py/streaming.py
存在一些问题,即它无法正确响应此框架。它基本上期望读取更多数据并等待相同的数据。这会导致从客户端关闭连接,默认为30秒超时。
所以这是你正在使用的python库中的一个错误。我创建了一个使用NodeJS WebSocket.server
的客户端,它正确关闭了。
为什么不在NodeJS中使用Server?在下面的链接
中有一个很好的例子https://github.com/websockets/ws/blob/master/examples/ssl.js
此处的代码供参考
'use strict';
const https = require('https');
const fs = require('fs');
const WebSocket = require('..');
const server = https.createServer({
cert: fs.readFileSync('../test/fixtures/certificate.pem'),
key: fs.readFileSync('../test/fixtures/key.pem')
});
const wss = new WebSocket.Server({ server });
wss.on('connection', function connection (ws) {
ws.on('message', function message (msg) {
console.log(msg);
});
});
server.listen(function listening () {
//
// If the `rejectUnauthorized` option is not `false`, the server certificate
// is verified against a list of well-known CAs. An 'error' event is emitted
// if verification fails.
//
// The certificate used in this example is self-signed so `rejectUnauthorized`
// is set to `false`.
//
const ws = new WebSocket(`wss://localhost:${server.address().port}`, {
rejectUnauthorized: false
});
ws.on('open', function open () {
ws.send('All glory to WebSockets!');
});
});