客户端请求+返回 服务端之间的请求和返回 实现rpc通信

背景:

1.无论什么类型的游戏,我们都会有rpc通信的需求。

2.由于客户端直连的是游戏服,如果工会,匹配之类的服务是单独的服务的话,必然要进行游戏服到业务服之间的转发,我们是否需要再转发时单独定义Req和Res就是我们考虑到的需求。

3.在vega项目中,我们选择了定义了内部协议的req和res,而不是像热江一样做了统一的封装,看起来麻烦了一点,但是实际上却是非常的清晰。

一个案例如下:

复制代码
 1.发出rpc请求
        // GuildService.java
            getRecommendList方法:

             // 向world服发送请求推荐列表(GuildBizModule.java进行RECOMMEND_LIST协议的处理)
             BinaryMsg msg = buildBinaryMsg(GuildLogicEnum.RECOMMEND_LIST, role.getRid());
             msg.writeInt(role.getLevel());

             // 思考下我们的rpc需要什么参数
             // 1.req  请求类型,这个我们希望是pb这种强类型的
             // 2.rep.class  返回的类型
             // 3.ResponseData<Boolean, Rep> 是否远端处理成功,有时候我们先本地扣东西,用于回滚
             // 4.hashId 远端在哪个线程执行  我们一般采用类似于actor模型,因此需要告知远端到底在哪个线程执行
             S2SHelper.sendMsg2WorldServer(msg, rid, BizType.GUILD,
                     Constants.BIZ_GUILD_DEFAULT_SUBKEY, new RespCacheCallback<>(role) {
                         @Override
                         public void onCallback(BinaryMsg msg) {
                             int result = msg.readInt();
                             if (result < 0) {
                                 handlerError(role, requestId, msg);
                                 return;
                             }
                             JSONObject json = msg.readObject(JSONObject.class);

                             // 这个是要返回给客户端的数据 setData是RespCacheCallback
                             setData(json);
                         }
                     });

     // 其实,我也不太需要知道当前是哪个类,通过消息号范围即可


    2.World进行业务端处理
        GuildBizModule.java
            processMsg方法:
                switch (codeEnum) {
                     case RECOMMEND_LIST:
                         WSGuildService.recommendList(replyTo, rid, msg);
                 }
相关推荐
Johnstons21 分钟前
TCP Reset(RST)异常是什么?一文讲透连接被动中断的识别方法、适用场景、与超时断开的边界及排查清单
网络协议·tcp/ip·php·es·抓包分析
TOWE technology30 分钟前
EN32/G2401FCI——32A大功率,24位国标输出的高密度配电方案
linux·服务器·网络·科技·数据中心·pdu·智能pdu
ACP广源盛1392462567312 小时前
IX8024与科学大模型的碰撞@ACP#筑牢科研 AI 算力高速枢纽分享
运维·服务器·网络·数据库·人工智能·嵌入式硬件·电脑
Empty-Filled13 小时前
AI生成测试用例功能怎么测:一个完整实战案例
网络·人工智能·测试用例
码云数智-大飞13 小时前
本地部署大模型:隐私安全与多元优势一站式解读
运维·网络·人工智能
jinanwuhuaguo14 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
汤愈韬14 小时前
三种常用 NAT 的经典案例
网络协议·网络安全·security
等风来不如迎风去14 小时前
【win11】最佳性能:fix 没有壁纸,一直黑屏
网络·人工智能
Harvy_没救了15 小时前
【网络部署】 Win11 + VMware CentOS8 + Nginx 文件共享服务 Wiki
运维·网络·nginx
汤愈韬15 小时前
NAT Server 与目的Nat
网络·网络协议·网络安全·security