zoukankan      html  css  js  c++  java
  • 手撕RPC第二天

    前言

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

    具体操作

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

    优化

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

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

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

  • 相关阅读:
    位运算的简单简要
    Date()函数详细参数
    Android画图之Matrix(二)
    图像渐变特效的简单介绍
    Android MotionEvent中getX()和getRawX()的区别
    Timer计时器
    android中raw文件夹和asset文件夹的共同点和区别
    Selector、shape详解
    select语句后以for update结尾
    Openfire(原来的Wildfire) 在 Web 2.0 中的作用
  • 原文地址:https://www.cnblogs.com/BBchao/p/9958832.html
Copyright © 2011-2022 走看看