JAVA RPC (三) 之thrift序列化协议入门杂谈
首先抱歉让大家久等了,最近工作的原因,再加上自己维护koalas rpc利用的大部分时间,一直没腾出空来写这篇文章。
先放出来自研的企业级RPC框架源代码地址,上面有使用方式和部署环境说明,说环境部署,其实只需要傻瓜式的安装一个zookeeper就可以了。
地址:https://gitee.com/a1234567891/koalas-rpc,三分钟一个企业级的RPC框架就诞生了。没有那么多繁杂的API,没有那么多需要踩的坑,拿来即用。完全开源
----------------------------广告到此为止----------切切切----------------我切切切------------------------------------------
关于thrift的基本知识,这里不做太多阐述,先说一下为什么要用thrift。
thrift本身不光是对象序列化协议,它本身封装了java 底层的nio(虽然这里有bug,我在做自定义协议的时候,竟然发现低版本thrift server和client竟然不支持,后面的讲解中我会写出来,这篇文章先不讲),也就是说thrift本身是协议+一套完整的基于java nio Selector rpc框架,如果有时间我会在接下来的时间里简单介绍一下java nio。但是这种点对点模型不适合用于实际生产中,首先对spring的支持需要自己手动去写,对服务的动态发现需要自己通过zk,redis之类的中间件去维护,负载等等。扯多了。想对thrift有一定了解的朋友先移步
https://blog.csdn.net/lk10207160511/article/details/50450541
https://www.cnblogs.com/cyfonly/p/6059374.html
https://blog.csdn.net/sunmenggmail/article/details/46818147
https://www.cnblogs.com/exceptioneye/p/4945073.html
https://blog.csdn.net/hrn1216/article/details/51306395
相信大家看完上面的文章对thrift应该会有一定的认识,虽然现在一定懵逼,这些个server模型到底是什么意思,ractor模型到底是啥东西,netty也在用,thrift的TThreadedSelectorServer模型也在用,之后会为大家一一讲解。
既然thrift 可以序列化,本身也能做RPC服务端,那么我就想到了只要是网络传输,那么服务端怎么少了了netty(主要还是为了折腾),所以服务端打算用thrift 的TThreadedSelectorServer和netty server。
高级java交流群:825199617
欢迎热爱源码志同道合的朋友加入。
koalas rpc源码地址https://gitee.com/a1234567891/koalas-rpc