手撕RPC第二天

it2022-05-07  0

前言

今日北京突发大霾,中午看了两个小时的《活着》,活在那个年代是幸运还是不幸,活在这个年代,是幸运还是不幸呢。或许我是幸运的吧。 经过了昨天的疯狂coding和今天上午的疯狂debug,终于完成了我的rpc初号机,虽然它还很简陋,但是已经有了一个伟大框架的雏形。

具体操作

由于代码是拼凑出来的,对具体的流程还没有理清,导致昨天的bug,今天祭出了我的笔和本子,把客户端与服务端的流程都梳理了一遍,找到了问题所在: 因为本人不想加spring,也没打算扫描包,一切都是写死的,于是名字写错了,拿不到函数和接口,就出现了空指针,又修改了一些线程的小问题,终于,小火车呜呜呜的开起来了(狗头.jpg)

优化

群主大大提出了8点建议如下

RPC 客户端和服务端应保持长连接,不用每次 send 进行 connect,此处 需优化所有模块应拆分不应该写在一个工程中,没法引用serialize 可以设计为接口可扩展,而且 JSON 的性能非常低,相当于使用了 HTTP 协议没有对异常做处理需设计 RPC 客户端和服务端的拦截器机制RPC 服务端阻塞在 Netty IO 线程组,代码部分包规划错误,如 RpcHandler 是 RPC 服务端特有的处理,不应放在 common 包需要更多的例子

下午解决了第一个和第二个问题(虽然第一个问题解决了,但是违反了单一指责原则,抱头哭泣),拆工程花费了大量的时间,因为自己对pom直接互相引用不太熟悉,之前写的项目都是架构师把架子做好,填代码就可以了。 最后重构了一下代码。。接下来解决第三个序列化的问题,钢巴鲁,少年!

转载于:https://www.cnblogs.com/BBchao/p/9958832.html


最新回复(0)