游戏中Dubbo类的RPC设计时的注意要点

一.消费方

1.需要使用到动态代理,代理指定的接口,这样子接口被调用时,就可以拿到:"类名+ 方法名+参数+返回值" 这些类型。

2.既然是rpc,那么接口被调用时,肯定在动态代理中会进行网络消息的发送,由于是远程调用,那么必然动态代理的proxy参数其实是用不到的,因为返回的话,是依赖于远程的服务提供者。

3.阻塞,等待消息的返回,支持超时。

二.服务提供者

1.必然要注册到zk中,其实就是本地一个Map,知道了调用者想调用啥时,知道具体的实现。也就是维护了一个Map<String, InterfaceImpl>的map。

2.消费者通过网络 把想要调用的信息传递过来后,服务提供者就找到实现,从而调用,调用后,再返回。

三、请求返回统一封装

RpcRequest

RpcResponse

为啥要封装下呢?

对于Request,这是因为有一些共性,比如:消费者需要存储"类名+ 方法名+参数+返回值"。

对于Response,则要告诉是否调用成功,还是说超时了。

四、序列化

我们这里采用kryo,因为我们希望是二进制级别的,而且是: 在修改签名时,我们不希望再直接生成下proto。

相关推荐
不知名的前端专家1 小时前
uniapp原生插件 TCP Socket 使用文档
网络·tcp/ip·uni-app·netty
siriuuus1 小时前
Linnux IPC通信和RPC通信实现的方式
rpc·网络通信
波波烤鸭1 小时前
Netty 实战应用:从 RPC 到即时通讯,再到 WebSocket
websocket·网络协议·rpc
linux修理工1 小时前
解决 N1 ARMBIAN Prometheus 服务启动失败问题
网络
土星碎冰机2 小时前
数据库开启ssl
数据库·网络协议·ssl
weixin_507847952 小时前
Nginx SSL/TLS 配置
网络·nginx·ssl
Leo来编程2 小时前
七层网络协议-面试
网络·网络协议·面试
北极光SD-WAN组网2 小时前
某光伏电力监控系统网络安全监测项目:智能组网技术优化方案实践
大数据·网络·分布式
新鲜萝卜皮4 小时前
你知道TCP的半连接队列和全连接队列吗?
网络协议
wanhengidc4 小时前
服务器内存不足会造成哪些影响?
运维·服务器·网络·游戏·智能手机