轻量级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目标。为...
- 大家都在谈论的敏捷开发&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...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 框架图 (58)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- jpa框架 (47)
- springmvc框架 (49)
- 分布式事务框架 (65)
- scrapy框架 (56)
- shiro框架 (61)
- 定时任务框架 (56)
- java日志框架 (61)
- JAVA集合框架 (47)
- mfc框架 (52)
- abb框架断路器 (48)
- ui自动化框架 (47)
- beego框架 (52)
- java框架spring (58)
- grpc框架 (65)
- ppt框架 (48)
- 内联框架 (52)
- cad怎么画框架 (58)
- ps怎么画框架 (47)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)
- oracle提交事务 (47)