基于以下组件打造的一款轻量级RPC服务框架:thrift(facebook出品的RPC框架)、commons-pool2(socket连接池). 服务治理(Zookeeper)、注解自动扫描(Reflections) 、AOP(Spring) 、GC优化 已经实现;即将移植智能负载均衡(Ribbon); 目前采用轮询算法作为client端的负载均衡算法。
#MyThrift
分析问题:
RPC框架:对网络模块非常熟悉,并在实际生产环境中使用过,thrift性能不错。
TCP/IP:有过2年的TCP/IP报文分析经验,从链路层到应用层都很熟悉。
ZooKeeper:在MySQL-Binlog项目中攒出了一些使用经验,同时积极吸收 Motan 等兄弟软件的优秀理念部分。
连接池:使用commons-pool连接池组件。
解决问题:
糅合thrift,zookeeper,commons-pool打造一款轻量级、性能高、上手容易的rpc调用框架,
使得架构师和后台开发人员可以将各种复杂存储的IO访问对外暴露为服务(其实就是跨机器的普通函数调用)
这样web开发人员可以专注于业务逻辑,加速产品迭代,对企业带来的好处不用多说!
1-运维组创建maven私服
一般,公司内部代码,如果有别的项目组需要引用的jar包,一般放在公司内部maven私服上,所以,请先创建一个maven私服。可以参考网上的文章: 包
common工程一般是公司的架构组负责维护,业务方不需要关心。common工程有新的版本替换时,告知业务方使用新的版本打包即可。1)eclipse单独引入common工程,进行源码修改(有必要的话,比如架构组需要升级).2)进入common项目工程,开始编译打包 mvn -X clean compile package3)顺利的话,可以看到2个jar包,一个有依赖,一个不带依赖。4)请上传其中一个jar包到你的maven私服上,可以选择手动上传,如果对maven熟悉的话也可以命令行自动上传。这里我选择的是不带依赖包的jar包上传到maven私服。上传之后,记住相关的maven信息,后面会用到。这个信息在maven私服里也可以看到的,比如我的就是com.freedom.rpcmythrift-common2.0.13-服务提供方上传service工程jar包
好,到了这里比如公司需要有一个服务,指定了一个团队负责这个微服务,此时,这个团队需要定义好服务的接口,这样就可以打包上传到maven私服,让别的团队先用起来,然后自己再慢慢写代码实现,两方都不耽误所以,这里重点是定义一个空的接口定义文件。但是在编写接口文件之前,我们需要搭建文件的编译环境。1)Thrift编译环境搭建首先,用户需要知道怎么搭建thrift的编译环境打开
微服务业务团队,模仿demo中的server工程,创建一个类似的工程
比如包含接口文件的具体实现,还有自己的主类调用RpcServer.start(args);
注意:接口文件实现类和service接口文件的定义必须在同一个包里
比如:
接口文件在service的a.b.c
那么实现类你可以放在server里的a.b.c.impl目录下
研究下pom文件,看看需要修改的自行修改
比如需要加上service的maven依赖,还有common工程的maven依赖,其它缺失的依赖自己补上。
然后,实现接口实现文件里面的每个接口函数就可以了。
最后就可以打包,打包的时候,注意不要把log4j.properties和server.properties打包进去。
打完包后,
将二进制文件thrift-server-binary-[版本号].tar.gz解压缩在linux下某个目录下
然后mythrift-server/target/mythrift-server-[版本号]-jar-with-dependencies.jar
替换之前解压缩的目录/lib/对应的jar包,注意,是替换,老的jar包需要删除。
同时替换log4j.properties{在common工程里}和server.properties文件{server工程里}
原有的压缩包里的配置文件比较老了,务必用最新的工程里的配置文件代替它,并修改相应的参数信息。
然后审查linux环境下的conf目录里的各个配置文件-log4j.properties ,server.properties的配置是否正确
修改下run.sh里面的主类为你自己的主类
然后启动./run.sh即可。
在linux上发布,启动run.sh脚本即可。
4.2-业务调用方编码调用service
请自行研究下demo里的client工程代码,在你自己的业务代码里调用即可。(实际中,是在你的web工程/其它工程 中调用的)注意配置文件的参数。将二进制文件thrift-client-binary-[版本号].tar.gz解压缩在linux下某个目录下然后将编译好的mythrift-client/target/mythrift-client-[版本号]-jar-with-dependencies.jar替换之前解压缩的目录/lib/对应的jar包,注意,是替换,老的jar包需要删除。同时替换log4j.properties{在common工程里}和client.properties文件{client工程里}原有的压缩包里的配置文件比较老了,务必用最新的配置文件代替它,并修改相应的参数信息。然后审查linux环境下的conf目录里的各个配置文件-log4j.properties ,client.properties的配置是否正确修改下run.sh里面的主类为你自己的主类然后启动./run.sh即可,然后查看日志文件(logs目录下)的输出,确认是否成功执行!这样,一个简单的RPC服务就编写完毕,