百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

轻量级RPC服务框架 MyThrift(rpc框架应用场景)

ccwgpt 2024-10-15 08:59 24 浏览 0 评论

基于以下组件打造的一款轻量级RPC服务框架:thrift(facebook出品)、commons-pool(socket连接池)、自研服务治理框架(zookeeper).

1-运维组创建maven私服

一般,公司内部代码,如果有别的项目组需要引用的jar包,一般放在公司内部maven私服上,
所以,请先创建一个maven私服。
可以参考网上的文章: http://www.tuicool.com/articles/E7ZBv2
具体过程就不说了,读者自己解决,
最后,我们可以获得一个类似
http://192.168.56.102:8081/nexus网址的就可以了,这里的IP是你自己的实际IP.
后面用到时请自行替换IP.

2-架构组上传common工程jar包

common工程一般是公司的架构组负责维护,业务方不需要关心。
common工程有新的版本替换时,告知业务方使用新的版本打包即可。
1)eclipse单独引入common工程,进行源码修改(有必要的话,比如架构组需要升级).
2)进入common项目工程,开始编译打包 mvn -X clean compile package
3)顺利的话,可以看到2个jar包,一个有依赖,一个不带依赖。
4)请上传其中一个jar包到你的maven私服上,可以选择手动上传,如果对maven熟悉的话也可以命令行自动上传。
这里我选择的是不带依赖包的jar包上传到maven私服。
上传之后,记住相关的maven信息,后面会用到。
这个信息在maven私服里也可以看到的,比如我的就是
com.freedom.rpc
mythrift-common
2.0.1

3-服务提供方上传service工程jar包

好,到了这里
比如公司需要有一个服务,指定了一个团队负责这个微服务,
此时,这个团队需要定义好服务的接口,这样就可以打包上传到maven私服,
让别的团队先用起来,然后自己再慢慢写代码实现,两方都不耽误
所以,这里重点是定义一个空的接口定义文件。
但是在编写接口文件之前,我们需要搭建文件的编译环境。
1)Thrift编译环境搭建
首先,用户需要知道怎么搭建thrift的编译环境
打开 http://thrift.apache.org/download
输入图片说明
红色方框内的网址实际上是: http://mirrors.cnnic.cn/apache/thrift/0.9.3/thrift-0.9.3.tar.gz
下载到你的linux机器上,解压缩,然后依次执行下列命令:
./configure --with-lua=no 这一步时间会比较长
make
sudo make install
}
看到下面的图片表示安装成功
输入图片说明
2)编写接口文件&生成对应的java文件
必须知道的是,thrift需要先定义一个 xx.thrift文件,此文件用来定义类似于interface的若干接口
下面举个例子,我有一个HelloWorldService.thrift文件,内容如下:
输入图片说明
那么,用户会问“我怎么知道有什么类型呢”,别急,见文档 http://thrift.apache.org/docs/types
PS:第一个参数前面就是1,第2个参数就是2,比如
string helloWorldString(1:string content, 2:string param2 , 3:string param3)
好,现在已经有了接口文件,然后如何生成对应的java文件呢?
因为是为了生成java文件,所以执行
thrift --gen java HelloWorldService.thrift
然后就会看到当前文件夹有个gen-java文件夹,如图所示:
输入图片说明
可以看到这个文件很大,这是因为thrift已经帮我们做好了很多额外的工作,比如序列化和反序列化,这样我们才可以很轻松的享受便利!
那么,到这里,我们实际上,已经完成了
1)定义xx.thrift
2) 根据xx.thrift生成接口类
下面就开始使用这2个文件了
3)业务java接口文件融入java框架
工程里已经有了一个service demo工程,模仿它的结构,创建一个你自己的maven工程
把你自己的接口java代码放在src/main/java里,.thrift存根文件放在src/main/resources目录下
这个时候会报错,在pom.xml中加上对mythrift-common的jar包依赖,同时还需要增加别的相关依赖,因为common包里并没有把依赖包打进去。
比如thrift的依赖包就是
<!-- thrift -->
 <dependency>
 <groupId>org.apache.thrift</groupId>
 <artifactId>libthrift</artifactId>
 <version>0.9.3</version>
 </dependency> 
必要的话,修改里面的maven私服地址。
接下来,很重要的一个步骤,加上接口文件的注解,这个非常重要,比如
在类上加上
// 加上注解,才可以被扫描到
@Processor(group = "test", service = "HelloWorldService", edition = "2.0.1")
分别代表组名,服务名,版本号!
Processor找不到的话,加上import com.freedom.rpc.thrift.common.annotation.Processor;
然后,开始打包,打完包后,上传到maven私服,这样别的团队才可以使用接口。

4.1-服务提供方编码实现service

微服务业务团队,模仿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服务就编写完毕,

相关推荐

RACI矩阵:项目管理中的角色与责任分配利器

作者:赵小燕RACI矩阵RACI矩阵是项目管理中的一种重要工具,旨在明确团队在各个任务中的角色和职责。通过将每个角色划分为负责人、最终责任人、咨询人和知情人四种类型,RACI矩阵确保每个人都清楚自己...

在弱矩阵组织中,如何做好项目管理工作?「慕哲制图」

慕哲出品必属精品系列在弱矩阵组织中,如何做好项目管理工作?【慕哲制图】-------------------------------慕哲制图系列0:一图掌握项目、项目集、项目组合、P2、商业分析和NP...

Scrum模式:每日站会(Daily Scrum)

定义每日站会(DailyScrum)是一个Scrum团队在进行Sprint期间的日常会议。这个会议的主要目的是为了应对Sprint计划中的不断变化,确保团队能够有效应对挑战并达成Sprint目标。为...

大家都在谈论的敏捷开发&amp;Scrum,到底是什么?

敏捷开发作为一种开发模式,近年来深受研发团队欢迎,与瀑布式开发相比,敏捷开发更轻量,灵活性更高,在当下多变环境下,越来越多团队选择敏捷开发。什么是敏捷?敏捷是一种在不确定和变化的环境中,通过创造和响应...

敏捷与Scrum是什么?(scrum敏捷开发是什么)

敏捷是一种思维模式和哲学,它描述了敏捷宣言中的一系列原则。另一方面,Scrum是一个框架,规定了实现这种思维方式的角色,事件,工件和规则/指南。换句话说,敏捷是思维方式,Scrum是规定实施敏捷哲学的...

敏捷项目管理与敏捷:Scrum流程图一览

敏捷开发中的Scrum流程通常可以用一个简单的流程图来表示,以便更清晰地展示Scrum框架的各个阶段和活动。以下是一个常见的Scrum流程图示例:这个流程图涵盖了Scrum框架的主要阶段和活动,其中包...

一张图掌握项目生命周期模型及Scrum框架

Mockito 的最佳实践(mock方法)

记得以前面试的时候,面试官问我,平常开发过程中自己会不会测试?我回答当然会呀,自己写的代码怎么不测呢。现在想想我好像误会他的意思了,他应该是想问我关于单元测试,集成测试以及背后相关的知识,然而当时说到...

EffectiveJava-5-枚举和注解(java枚举的作用与好处)

用enum代替int常量1.int枚举:引入枚举前,一般是声明一组具名的int常量,每个常量代表一个类型成员,这种方法叫做int枚举模式。int枚举模式是类型不安全的,例如下面两组常量:性别和动物种...

Maven 干货 全篇共:28232 字。预计阅读时间:110 分钟。建议收藏!

Maven简介Maven这个词可以翻译为“知识的积累”,也可以翻译为“专家”或“内行”。Maven是一个跨平台的项目管理工具。主要服务于基于Java平台的项目构建、依赖管理和项目信息管理。仔...

Java单元测试框架PowerMock学习(java单元测试是什么意思)

前言高德的技术大佬在谈论方法论时说到:“复杂的问题要简单化,简单的问题要深入化。”这句话让我感触颇深,这何尝不是一套编写代码的方法——把一个复杂逻辑拆分为许多简单逻辑,然后把每一个简单逻辑进行深入实现...

Spring框架基础知识-第六节内容(Spring高级话题)

Spring高级话题SpringAware基本概念Spring的依赖注入的最大亮点是你所有的Bean对Spring容器的存在是没有意识的。但是在实际的项目中,你的Bean必须要意识到Spring容器...

Java单元测试浅析(JUnit+Mockito)

作者:京东物流秦彪1.什么是单元测试(1)单元测试环节:测试过程按照阶段划分分为:单元测试、集成测试、系统测试、验收测试等。相关含义如下:1)单元测试:针对计算机程序模块进行输出正确性检验工作...

揭秘Java代码背后的质检双侠:JUnit与Mockito!

你有没有发现,现在我们用的手机App、逛的网站,甚至各种智能设备,功能越来越复杂,但用起来却越来越顺畅,很少遇到那种崩溃、卡顿的闹心事儿?这背后可不是程序员一拍脑袋写完代码就完事儿了!他们需要一套严谨...

单元测试框架哪家强?Junit来帮忙!

大家好,在前面的文章中,给大家介绍了以注解和XML的方式分别实现IOC和依赖注入。并且我们定义了一个测试类,通过测试类来获取到了容器中的Bean,具体的测试类定义如下:@Testpublicvoid...

取消回复欢迎 发表评论: