websocket获取实时数据
def ws_sample(client_id):
method = "GET"
path = "/ws"
sign_headers = {"host": ws_host}
authorization = sign(ak, sk, method, path, None, sign_headers)
headers = {"hobot_xpush_client_id": client_id,
"authorization": authorization}
print("ws://"+ws_host+path)
ws = websocket.WebSocketApp("ws://"+ws_host+path,header=headers,
on_message=on_message,
on_error=on_error,
on_close=on_close)
ws.on_open = ws_on_open
ws.run_forever()
def on_message(ws, message): ## 服务器有数据更新时,主动推送过来的数据
print("cig cig cig cig cig")
print(message)
def on_error(ws, error): # # 程序报错时,就会触发on_error事件
print(error)
def on_close(ws):
print("### closed ###")
def ws_on_open(ws): # 连接到服务器之后就会触发on_open事件,这里用于send数据 ,用于指定连接成功后的回调函数。
def run(*args):
for i in range(30000):
time.sleep(1)
ws.send("Hello %d" % i)
time.sleep(1)
ws.close()
print("thread terminating...")
thread.start_new_thread(run, ())
WebSocketApp 长连接,参数介绍:
(1)url: websocket的地址。
(2)header: 客户发送websocket握手请求的请求头,{‘head1:value1’,‘head2:value2’}。
(3)on_open:在建立Websocket握手时调用的可调用对象,这个方法只有一个参数,就是该类本身。
(4)on_message:这个对象在接收到服务器返回的消息时调用。有两个参数,一个是该类本身,一个是我们从服务器获取的字符串(utf-8格式)。
(5)on_error:这个对象在遇到错误时调用,有两个参数,第一个是该类本身,第二个是异常对象。
(6)on_close:在遇到连接关闭的情况时调用,参数只有一个,就是该类本身。
(7)on_cont_message:这个对象在接收到连续帧数据时被调用,有三个参数,分别是:类本身,从服务器接受的字符串(utf-8),连续标志。
(8)on_data:当从服务器接收到消息时被调用,有四个参数,分别是:该类本身,接收到的字符串(utf-8),数据类型,连续标志。
(9)keep_running:一个二进制的标志位,如果为True,这个app的主循环将持续运行,默认值为True。
(10)get_mask_key:用于产生一个掩码。
(11)subprotocols:一组可用的子协议,默认为空。
长连接关键方法:ws.run_forever(ping_interval=60,ping_timeout=5)
如果不断开关闭websocket连接,会一直阻塞下去。另外这个函数带两个参数,如果传的话,启动心跳包发送。
ping_interval:自动发送“ping”命令,每个指定的时间(秒),如果设置为0,则不会自动发送。
ping_timeout:如果没有收到pong消息,则为超时(秒)。
参考:
https://www.cnblogs.com/yhleng/p/9487764.html