Apache Thrift 官方JAVA教程

简介: 本文所使用的开发环境是windows环境,利用的资源是官网给出的,只是网上搜了很多文章,都不是很明白,我把我自己的经历写出来分享给大家,大家互相学习,有好的建议,希望不吝赐教1.

本文所使用的开发环境是windows环境,利用的资源是官网给出的,只是网上搜了很多文章,都不是很明白,我把我自己的经历写出来分享给大家,大家互相学习,有好的建议,希望不吝赐教

1.下载需要的文件
地址:http://thrift.apache.org/download
exe和tg文件都要下载

2.设置自己的环境变量
2.1将下载的exe文件改名改成thrift.exe放在一个目录下(不是必须的,只是这样用起来比较方便)
2.2设置环境,在path这个里面加入刚才exe文件放的目录位置,比我的D:\thrift
2.3 打开cmd输入thrift,显示如下:


3.编译接口文件
把刚才下载的那个thrift-0.10.0.tar.gz文件解压
找到你需要用到的语言,我用的是java, 我的路径是"D:\thrift\thrift-0.10.0\lib\java"
生成thrift文件,在此目录下执行语法:thrift -r --gen java tutorial.thrift
注意 他的第二个参数-gen java可以换成你的语言 ,而我们测试用的文件名字叫tutorial.thrift (官网给了一个example:http://thrift.apache.org/tutorial/java,将里面的shared.thrift和tutorial.thrift都下载到本地),如果自己写也可以换成自己文件名字 只是后缀必须是.thrift
执行后会出现一个gen-Java文件夹,里面包含两个包,每个包都有几个生成的Java文件,文件结构如下:

现在我们可以利用生成的java文件创建java项目了
4.client和server
client和server代码都来自官网地址:
这里还涉及到另一个类——CalculatorHandler,但是并没有在同一个界面,我们在下面的界面可以找到:http://thrift.apache.org/
如果不知道怎么办,也可以直接从官方源码地址获取:

5.编译需要的jar包
需要使用ant和ivy两个软件,ant配置不说了,将ivy解压后,将ivy-xx.jar拷贝到ant的lib目录下,然后在“D:\thrift\thrift-0.10.0\lib\java”(这是我的解压路径)下执行:
ant
java文件夹内会多出build文件夹,里面会包含一些jar包和class文件,以后就可以直接使用在build文件夹里的生成的jar包:libthrift-xx.jar,以及lib下的关联jar包
我们创建好java项目后就把需要的jar导入就行了。

6.生成TSSL的私钥和公钥
官方教程中启动服务器提供了两种方式,一般方式(simple)和TSSL方式(secure)。
simple方式很简单就能运行,但是TSSL方式需要用到安全证书。
你可以看看官方教程源码,其中服务端有下面一行代码
params .setKeyStore( "../../lib/java/test/.keystore" , "thrift" , null, null ) ;
这里的.keystore是私钥,"thrift"是私钥的口令。
在客户端中:
params .setTrustStore( "../../lib/java/test/.truststore" , "thrift" , "SunX509" , "JKS" ) ;
这里的.truststore是公钥,"SunX509"是公钥的口令,我们需要通过key-tool工具来生成私钥和公钥。
整个使用key-tool工具的过程如下:
输入下面的命令生成私钥,这里的私钥名字是.keystore,名字可以随便写,但是整个过程都要保持名字一致
keytool -genkeypair -alias certificatekey -keyalg RSA -validity 365 -keystore .keystore
输入上面的命令后按照提示进行操作。这里需要注意,最后一步的certificatekey的口令最好和上面的口令一致,否则可能会遇到其他问题。
输入下面的命令生成server.cer证书
keytool -export -alias certificatekey -keystore .keystore -rfc -file server.cer
输入下面的命令生成.truststore
keytool -import -alias certificatekey -file server.cer -keystore .truststore
上面的过程仅仅是为了生成我们需要的.keystore和.truststore,更多的细节可以自己查询。
为了帮助大家理解,我把我输入的三句命令列出来
keytool -genkeypair -alias thrift -keyalg RSA -validity 365 -keystore .keystore
keytool -export -alias thrift -keystore .keystore -rfc -file server.cer
keytool -import -alias thrift -file server.cer -keystore .truststore
生成后将这两个文件分别放到server和client中,修改路径和密码,做好这些之后,程序就能启动了。
看下我现在的项目结构:

相关文章
|
8月前
|
Java 关系型数据库 数据库
Java 项目实战教程从基础到进阶实战案例分析详解
本文介绍了多个Java项目实战案例,涵盖企业级管理系统、电商平台、在线书店及新手小项目,结合Spring Boot、Spring Cloud、MyBatis等主流技术,通过实际应用场景帮助开发者掌握Java项目开发的核心技能,适合从基础到进阶的学习与实践。
1133 3
|
7月前
|
安全 Java
Java之泛型使用教程
Java之泛型使用教程
441 10
|
6月前
|
Oracle Java 关系型数据库
Java 简单教程
Java是跨平台、面向对象的编程语言,广泛用于企业开发、Android应用等。本教程涵盖环境搭建、基础语法、流程控制、面向对象、集合与异常处理,助你快速入门并编写简单程序,为进一步深入学习打下坚实基础。
461 0
|
JavaScript NoSQL Java
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
723 96
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
|
9月前
|
缓存 安全 Java
Java 并发新特性实战教程之核心特性详解与项目实战
本教程深入解析Java 8至Java 19并发编程新特性,涵盖CompletableFuture异步编程、StampedLock读写锁、Flow API响应式流、VarHandle内存访问及结构化并发等核心技术。结合电商订单处理、缓存系统、实时数据流、高性能计数器与用户资料聚合等实战案例,帮助开发者高效构建高并发、低延迟、易维护的Java应用。适合中高级Java开发者提升并发编程能力。
391 0
|
10月前
|
Oracle Java 关系型数据库
java 编程基础入门级超级完整版教程详解
这份文档是针对Java编程入门学习者的超级完整版教程,涵盖了从环境搭建到实际项目应用的全方位内容。首先介绍了Java的基本概念与开发环境配置方法,随后深入讲解了基础语法、控制流程、面向对象编程的核心思想,并配以具体代码示例。接着探讨了常用类库与API的应用,如字符串操作、集合框架及文件处理等。最后通过一个学生成绩管理系统的实例,帮助读者将理论知识应用于实践。此外,还提供了进阶学习建议,引导学员逐步掌握更复杂的Java技术。适合初学者系统性学习Java编程。资源地址:[点击访问](https://pan.quark.cn/s/14fcf913bae6)。
1122 2
|
消息中间件 Java 数据库
自研Java框架 Sunrays-Framework使用教程「博客之星」
### Sunrays-Framework:助力高效开发的Java微服务框架 **Sunrays-Framework** 是一款基于 Spring Boot 构建的高效微服务开发框架,深度融合了 Spring Cloud 生态中的核心技术组件。它旨在简化数据访问、缓存管理、消息队列、文件存储等常见开发任务,帮助开发者快速构建高质量的企业级应用。 #### 核心功能 - **MyBatis-Plus**:简化数据访问层开发,提供强大的 CRUD 操作和分页功能。 - **Redis**:实现高性能缓存和分布式锁,提升系统响应速度。 - **RabbitMQ**:可靠的消息队列支持,适用于异步
自研Java框架 Sunrays-Framework使用教程「博客之星」
|
移动开发 前端开发 Java
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
JavaFX是Java的下一代图形用户界面工具包。JavaFX是一组图形和媒体API,我们可以用它们来创建和部署富客户端应用程序。 JavaFX允许开发人员快速构建丰富的跨平台应用程序,允许开发人员在单个编程接口中组合图形,动画和UI控件。本文详细介绍了JavaFx的常见用法,相信读完本教程你一定有所收获!
13889 5
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
914 26
|
Java 数据库连接 数据处理
探究Java异常处理【保姆级教程】
Java 异常处理是确保程序稳健运行的关键机制。它通过捕获和处理运行时错误,避免程序崩溃。Java 的异常体系以 `Throwable` 为基础,分为 `Error` 和 `Exception`。前者表示严重错误,后者可细分为受检和非受检异常。常见的异常处理方式包括 `try-catch-finally`、`throws` 和 `throw` 关键字。此外,还可以自定义异常类以满足特定需求。最佳实践包括捕获具体异常、合理使用 `finally` 块和谨慎抛出异常。掌握这些技巧能显著提升程序的健壮性和可靠性。
307 4