Java thrift服务器和客户端创建实例代码

发布时间 - 2026-01-11 00:29:04    点击率:

Thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发。它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, JavaScript, Node.js, Smalltalk, and OCaml 等等编程语言间无缝结合的、高效的服务。

Thrift最初由facebook开发,07年四月开放源码,08年5月进入apache孵化器。thrift允许你定义一个简单的定义文件中的数据类型和服务接口。以作为输入文件,编译器生成代码用来方便地生成RPC客户端和服务器通信的无缝跨编程语言。

首先环境介绍一下:

1.IntelliJ IDEA 2017.1

2.thrift-0.9.3

相信大家在看我这篇文章的时候已经对thrift通信框架已有所调研,这里就不再赘述了,直接进入正题:

<1>创建HelloWorld.thrift

namespace java com.thrift.demo

service HelloWorldService{
string sayHello(1:string username)
}

 <2>利用thrift生成HelloWorld.java文件,cmd指令下进入thrift当前目录下输入命令

thrift.exe -gen java HelloWorld.thrift

java为要生成文件的类型,HelloWorld.thrift为前面的文件。

<3>创建IDEA 下的maven项目,其中的好处就不一一说明了,最重要的一条就是可以在pom.xml文件中添加dependency,能够在项目中自行下载库文件,方便协同开发中出现的开发包不对应的情况。

<dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>javax.servlet-api</artifactId>
      <version>3.1.0</version>
    </dependency>
    <dependency>
      <groupId>jstl</groupId>
      <artifactId>jstl</artifactId>
      <version>1.2</version>
    </dependency>
    <dependency>
      <groupId>org.apache.thrift</groupId>
      <artifactId>libthrift</artifactId>
      <version>0.9.3</version>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-log4j12</artifactId>
      <version>1.7.5</version>
    </dependency>

上述pom引入相应的依赖项就可以让它自行下载。

<4>项目的结构图当前如下所示:

File--Project Structure--Modules,在main文件夹下新建java文件夹并设为Soueces类型(因为在Sources文件下可以新建java class文件)

同时将thrift生成的HelloWorld.java文件复制到该目录下

<5>实现接口Iface

java代码:HelloWorldImpl.java

package com.jmust.thrift.demo;
import org.apache.thrift.TException;
/**
 * Created by Administrator on 2017/3/31.
 */
public class HelloWorldImpl implements HelloWorldService.Iface {
  public HelloWorldImpl() {
  }
  @Override
  public String sayHello(String username) throws TException {
    return "Hi,"+username+"Welcome to my blog http://www.cnblogs.com/zfygiser";
  }
}

<6>服务端TSimpleServer

java代码:HelloServer.java

/**
 * Created by Administrator on 2017/3/31.
 */
package com.jmust.thrift.demo;
import org.apache.thrift.TProcessor;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.server.TServer;
import org.apache.thrift.server.TSimpleServer;
import org.apache.thrift.transport.TServerSocket;
public class HelloServer {
  public final static int SERVER_PORT = 7099;
  private static String SERVER_IP = "localhost";
  public void startServer() {
    try {
      System.out.println("HelloWorld Server start...");
      TServerSocket serverTransport = new TServerSocket(SERVER_PORT);
      TServer.Args args = new TServer.Args(serverTransport);
      TProcessor process = new HelloWorldService.Processor(new HelloWorldImpl());
      TBinaryProtocol.Factory portFactory = new TBinaryProtocol.Factory(true, true);
      args.processor(process);
      args.protocolFactory(portFactory);
      TServer server = new TSimpleServer(args);
      server.serve();
    } catch (Exception e) {
      System.out.println("Server start error");
      e.printStackTrace();
    }
  }
  public static void main(String[] args) {
    HelloServer server = new HelloServer();
    server.startServer();
  }
}

<7>编写客户端代码

java代码:Client.java

package com.jmust.thrift.demo;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TProtocol;
import org.apache.thrift.transport.TSocket;
import org.apache.thrift.transport.TTransport;
/**
 * Created by Administrator on 2017/4/1.
 */
public class Client {
  public static final int SERVER_PORT = 7099;
  public static final String SERVER_IP = "localhost";
  public void startClient(String username) {
    TTransport tTransport = null;
    try {
      tTransport = new TSocket(SERVER_IP, SERVER_PORT);
      //协议要和服务端一致
      TProtocol protocol = new TBinaryProtocol(tTransport);
      HelloWorldService.Client client = new HelloWorldService.Client(protocol);
      tTransport.open();
      String result = client.sayHello(username);
      System.out.println("Thrift client result=" + result);
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
  public static void main(String[] args) {
    Client client = new Client();
    client.startClient("zfy");
  }
}

客户端测试成功,截图如下:

以上所述是小编给大家介绍的Java thrift服务器和客户端创建实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# java  # thrift  # 服务器和客户端  # 客户端  # Vue+Java 通过websocket实现服务器与客户端双向通信操作  # Java利用TCP协议实现客户端与服务器通信(附通信源码)  # Java实现UDP通信过程实例分析【服务器端与客户端】  # java UDP通信客户端与服务器端实例分析  # java Tcp通信客户端与服务器端实例  # java模拟TCP通信实现客户端上传文件到服务器端  # java模拟客户端向服务器上传文件  # java实现客户端向服务器发送文件  # Java实现文件上传服务器和客户端  # java实现上传文件到服务器和客户端  # Java Socket编程服务器响应客户端实例代码  # java多线程实现服务器端与多客户端之间的通信  # 教你怎么用java实现客户端与服务器一问一答  # 小编  # 服务端  # 编程语言  # 是一个  # 目录下  # 在此  # 结构图  # 最重要  # 设为  # 给大家  # 看我  # 所示  # 让它  # 这篇文章  # 说明了  # 介绍一下  # 所述  # 给我留言  # 直接进入 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 奇安信“盘古石”团队突破 iOS 26.1 提权  Laravel模型关联查询教程_Laravel Eloquent一对多关联写法  如何在不使用负向后查找的情况下匹配特定条件前的换行符  打开php文件提示内存不足_怎么调整php内存限制【解决方案】  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  Laravel如何使用Blade模板引擎?(完整语法和示例)  如何为不同团队 ID 动态生成多个非值班状态按钮  Laravel怎么使用Intervention Image库处理图片上传和缩放  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  利用JavaScript实现拖拽改变元素大小  Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】  Android Socket接口实现即时通讯实例代码  Laravel如何优化应用性能?(缓存和优化命令)  bing浏览器学术搜索入口_bing学术文献检索地址  如何快速搭建二级域名独立网站?  Laravel storage目录权限问题_Laravel文件写入权限设置  魔毅自助建站系统:模板定制与SEO优化一键生成指南  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  EditPlus中的正则表达式 实战(4)  微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  java ZXing生成二维码及条码实例分享  html5的keygen标签为什么废弃_替代方案说明【解答】  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南  Laravel用户密码怎么加密_Laravel Hash门面使用教程  简单实现Android文件上传  html文件怎么打开证书错误_https协议的html打开提示不安全【指南】  js实现获取鼠标当前的位置  如何在建站之星绑定自定义域名?  Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程  Laravel如何为API生成Swagger或OpenAPI文档  Laravel如何配置Horizon来管理队列?(安装和使用)  轻松掌握MySQL函数中的last_insert_id()  如何用狗爹虚拟主机快速搭建网站?  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  Laravel模型事件有哪些_Laravel Model Event生命周期详解  Laravel中的Facade(门面)到底是什么原理  Laravel如何自定义错误页面(404, 500)?(代码示例)  Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程  如何快速搭建高效WAP手机网站?  香港服务器租用每月最低只需15元?  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  Laravel怎么在Controller之外的地方验证数据  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  JavaScript如何实现倒计时_时间函数如何精确控制  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程