一步步学会Thrift服务搭建和调用

简介: <p><span style="font-size:14px"><span style="white-space:pre"></span></span></p> <p align="left">       Thrift是什么,有什么优势?这里就不阐述了,百度即可。本文旨在于展现Thrift服务搭建和调用的过程,让初学者少走弯路。本文提供完整代码及所需jar和thrift-0.9.3.e

       Thrift是什么,有什么优势?这里就不阐述了,百度即可。本文旨在于展现Thrift服务搭建和调用的过程,让初学者少走弯路。本文提供完整代码及所需jar和thrift-0.9.3.exe。点击此处下载完整工程:https://github.com/zxiaofan/OpenSource_Study/tree/master/Thrift

先来张目录结构图

1、下载所需jar和thrift-0.9.3.exe

              下载地址:thrift-0.9.3.exeThrift开发所需jar

2、解压thrift-0.9.3.exe到本地目录(如:E:\Thrift ),建议全英文目录,并修改名字为thrift.exe(方便敲命令)。

 

3、添加thrift.exe目录到系统环境变量

       在系统变量path后添加“ ;E:\Thrift ”,注意分号哦。

 

4、下载ThriftTest.thrift 到thrift.exe目录点击下载

  这里提供了现成的Thrift文件,相关的编写方法,网络很多,就不赘述。亦可参照我收集的(点击访问我的个人有道云笔记)。

5、CMD定位到E:\Thrift ,执行命令

 cd /d E:\Thrift

      即可。

 

6、生成java文件

      接着在命令行输入:

thrift.exe -r -genjava ./ThriftTest.thrift

,此时会在thrift.exe目录生成gen-java文件夹,里面的就是我们所需的ThriftHelloWorld.java文件了。

 

7、接下来就是编写服务端了。

      ①首先实现我们的接口,注意要实现Iface接口哦。

package service;

import thrift.ThriftHelloWorld.Iface;
/**
 * 服务端实现类
 *
 */
public classHelloServiceImpl implements Iface {
    public String sayHello(String username) {
        return "hello " + username;
    }
 
    public String getRandom() {
        return "random";
    }
}

      ②在src目录下新建thrift包,将先前生成的ThriftHelloWorld.java拷贝进去;

      ③新建startServer用于启动服务,

package service;
 
import org.apache.thrift.protocol.TBinaryProtocol.Factory;
import org.apache.thrift.server.TServer;
import org.apache.thrift.server.TThreadPoolServer;
import org.apache.thrift.server.TThreadPoolServer.Args;
import org.apache.thrift.transport.TServerSocket;
import org.apache.thrift.transport.TTransportException;
 
import thrift.ThriftHelloWorld;
import thrift.ThriftHelloWorld.Processor;
 
/**
 * 启动服务
 *
 */
public classStartServer {
    /**
     * 启动Thrift服务器
     */
    public void startServer() {
 
        try {
            // 定义传输的socket,设置服务端口为6789
            TServerSocket serverTransport = newTServerSocket(6789);
 
            // 设置协议工厂为 TBinaryProtocol.Factory
            Factory proFactory = newFactory(true, true);
 
            // 关联处理器与 Hello服务的实现
            ThriftHelloWorld.Processorprocessor = new Processor(new HelloServiceImpl());
 
            // 定义服务端的参数值
            Args args = newArgs(serverTransport);
            args.processor(processor);
            args.protocolFactory(proFactory);
            TServer server = newTThreadPoolServer(args);
 
            // 服务端开启服务s
            server.serve();
        } catch (TTransportException e) {
            e.printStackTrace();
        }
    }
 
    public static void main(String[] args) {
        System.out.println("ServerStart!");
        StartServer server = new StartServer();
        server.startServer();
    }
}

服务端就此完成,启动main函数,控制台输出Server Start!。

发布的时候只需将此工程导出为可执行jar或将工程稍作修改用tomcat发布。


8、编写客户端,完成服务调用

      ①同样在src目录下新建thrift包,将先前生成的ThriftHelloWorld.java拷贝进去;

      ②创建ClientTest类用于调用服务

package client;
 
import org.apache.thrift.TException;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TProtocol;
import org.apache.thrift.transport.TSocket;
import org.apache.thrift.transport.TTransport;
import org.apache.thrift.transport.TTransportException;
import org.junit.Test;
 
import thrift.ThriftHelloWorld;
 
/**
 * 客户端实现
 *
 */
public classClientTest {
    /**
     * 调用Hello服务
     */
    @Test
    public void startClient() {
        try {
 
            // 设置调用的服务地址为本地,端口为6789
            TTransport transport = newTSocket("localhost", 6789);
            transport.open();
            // 数据传输协议有:二进制协议、压缩协议、JSON格式协议
            // 这里使用的是二进制协议
            // 协议要和服务端一致
            TProtocol protocol = new TBinaryProtocol(transport);
            ThriftHelloWorld.Client client =new ThriftHelloWorld.Client(protocol);
            // 调用服务器端的服务方法
           System.out.println(client.sayHello("zxiaofan"));
            // 关闭
            transport.close();
        } catch (TTransportException e) {
            e.printStackTrace();
        } catch (TException e) {
            e.printStackTrace();
        }
    }
}

启动startClient,控制台输出hello zxiaofan,至此客户端完成。

 



 

 

 


目录
相关文章
|
Ubuntu
虚拟机Ubuntu连接不了网络的解决方法
虚拟机Ubuntu连接不了网络的解决方法
495 0
|
9月前
|
搜索推荐
通义灵码使用反馈
这款工具可根据个人需求生成代码,多次交互后能较好满足需求,输入备注即可获得后续代码提示。其优点在于个性化定制与智能提示,但处理复杂逻辑时需多次输入输出,且实体类编写时提示较为单一,顺序也可能与备注不符,仍有改进空间以提升效率。
|
前端开发 Java 应用服务中间件
一文讲明SpringMVC 【爆肝整理一万五千字】
文章提供了一份全面的SpringMVC教程,涵盖了SpringMVC的简介、创建实例、注解、获取请求参数的不同方式、域对象共享数据、视图渲染、RESTful风格、拦截器使用、异常处理以及文件上传下载等内容,并包含了相应的代码示例和测试结果。
一文讲明SpringMVC 【爆肝整理一万五千字】
|
存储 Java 程序员
汇编语言教程及实例
汇编语言教程及实例
|
Python Windows
在 Windows 平台下打包 Python 多进程代码为 exe 文件的问题及解决方案
在使用 Python 进行多进程编程时,在 Windows 平台下可能会出现将代码打包为 exe 文件后无法正常运行的问题。这个问题主要是由于在 Windows 下创建新的进程需要复制父进程的内存空间,而 Python 多进程机制需要先完成父进程的初始化阶段后才能启动子进程,所以在这个过程中可能会出现错误。此外,由于没有显式导入 Python 解释器,也会导致 Python 解释器无法正常工作。为了解决这个问题,我们可以使用函数。
712 5
|
Java 数据库连接 测试技术
SpringBoot 3.3.2 + ShardingSphere 5.5 + Mybatis-plus:轻松搞定数据加解密,支持字段级!
【8月更文挑战第30天】在数据驱动的时代,数据的安全性显得尤为重要。特别是在涉及用户隐私或敏感信息的应用中,如何确保数据在存储和传输过程中的安全性成为了开发者必须面对的问题。今天,我们将围绕SpringBoot 3.3.2、ShardingSphere 5.5以及Mybatis-plus的组合,探讨如何轻松实现数据的字段级加解密,为数据安全保驾护航。
1328 1
|
前端开发 Java 数据格式
SpringMVC详解
SpringMVC详解
241 0
|
机器学习/深度学习 人工智能 数据处理
AI计算机视觉笔记一:YOLOV5疲劳驾驶行为检测
如何使用云服务器AutoDL进行深度学习模型的训练,特别是针对YOLOV5疲劳驾驶行为训练检测
|
数据可视化 Python
Python中绘制3D曲面图的艺术
【7月更文挑战第4天】使用Python的Matplotlib和mpl_toolkits.mplot3d库,可以轻松绘制3D曲面图。首先安装matplotlib,然后导入numpy和相关模块。通过定义函数和使用numpy的meshgrid生成数据,接着用`plot_surface`绘制曲面,可定制色彩映射、添加标签、标题、色标、透明度和阴影。通过自定义颜色映射和添加网格线,能进一步增强图形的解读性。这些技巧使3D数据可视化更具洞察力和吸引力。
|
缓存 安全 关系型数据库
MySQL sync_binlog配置
MySQL sync_binlog配置