31-RPC技术与websocket介绍

先来介绍一下websocket(WS),它是一种类似于http的一种协议,http请求,响应后建立连接然后直接就结束,而websocket是建立连接后保持一个持久性的双向通道来传输数据,然后RPC是什么呢,RPC其实就是将远程服务器想要调用的"函数名"和"参数"打包成一份数据然后通过某种通道(websocket等)传给远程服务器上的某个程序,然后在远程服务器调用完函数后的结果再通过,某种管道(websocket等)传给我们。

下面我们实现一下websocket,需要安装websockets10版本的库:

javascript 复制代码
pip install websockets==10

客户端:

javascript 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=
    , initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <input type="text" id="box">
    <button onclick="pc()">send</button>

    <script>
        var ws = new WebSocket('ws://127.0.0.1:8080')

        // 报错
        ws.onerror = function(e) {
            console.log(e)
        }

        // 成功回调
        // ws.onopen

        // 接收数据
        ws.onmessage = function(dataBack) {
            console.log(dataBack.data)
        }

        // 关闭连接
        // ws.onclose

        function pc() {
            data = document.getElementById('box')
            ws.send(data.value)
        }
    </script>
</body>
</html>

运行起来发现:

因为我们没有服务器,下面来写一下服务端代码:

javascript 复制代码
import asyncio
import websockets

async def echo(ws):
    await ws.send("Hello")
    return True

async def rec_message(ws):
    while True:
        data = await ws.recv()
        print(data)

async def main(ws, path):
    await echo(ws)
    await rec_message(ws)

# 创建服务器实例
ser = websockets.serve(main, '127.0.0.1', 8080)
# 创建一个异步循环对象实例
loop = asyncio.get_event_loop()
# 运行服务器实例直到完成
loop.run_until_complete(ser)
# 一直处于监听状态(即一直运行服务器实例)
loop.run_forever()

这两段代码本质就是相互建立连接,py代码是服务器,当服务器打开之后会寻找ip和端口号相同的客户端,找到客户端建立websocket通道并保持,然后发送Hello,然后客户端可以向服务器发送消息,服务器一直处于监听状态,保持连接接收数据。

小结

本文到此就结束了,文章其实就讲了websocket是什么,怎么建立,原理是什么,RPC又是什么,怎么与websocket配合使用,文章如有什么问题请及时提出,一起交流,加油加油

相关推荐
白晨并不是很能熬夜1 小时前
【PRC】第 2 篇:Netty 通信层 — NIO 模型 + 自定义协议 + 心跳
java·开发语言·后端·面试·rpc·php·nio
2401_873479403 小时前
固件升级如何按地区分批推送?IP地址查询定位决定升级策略
网络协议·tcp/ip·php
net3m333 小时前
所有esp_websocket_client_send。。。的地方都加锁,就不容易websocket 断线重连
网络·websocket·网络协议
Jiangxl~3 小时前
IP数据云如何为不同行业提供精准IP查询与风险防控解决方案?
网络·网络协议·tcp/ip·算法·ai·ip·安全架构
你觉得脆皮鸡好吃吗3 小时前
HTTP (XSS前简单了解)
网络·网络协议·http·网络安全学习
摸鱼仙人~6 小时前
HTTP 状态码系统拆解
网络·网络协议·http
白晨并不是很能熬夜7 小时前
【RPC】第 1 篇:全景篇 — 一次 RPC 调用的完整旅程
java·网络·后端·网络协议·面试·rpc·java-zookeeper
学编程就要猛7 小时前
JavaEE初阶:网络原理-HTTP(上)
网络·网络协议·http
S1998_1997111609•X8 小时前
滄集/㞯鎩.赫量被恶意篡改?|\^*仺\~:sall,sql=㶏齾bci.ji.app_sql=-heart{TCP.box}‘雧……㞋
网络·数据库·网络协议·百度·微信
菱玖9 小时前
常见 HTTP 状态码详解
网络·网络协议·http