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实现客户端与服务器一问一答
# 小编
# 服务端
# 编程语言
# 是一个
# 目录下
# 在此
# 结构图
# 最重要
# 设为
# 给大家
# 看我
# 所示
# 让它
# 这篇文章
# 说明了
# 介绍一下
# 所述
# 给我留言
# 直接进入
相关文章:
建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南
宿州网站制作公司兴策,安徽省低保查询网站?
做企业网站制作流程,企业网站制作基本流程有哪些?
免费网站制作appp,免费制作app哪个平台好?
为什么Go需要go mod文件_Go go mod文件作用说明
如何通过.red域名打造高辨识度品牌网站?
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
如何快速查询网址的建站时间与历史轨迹?
建站之星体验版:智能建站系统+响应式设计,多端适配快速建站
测试制作网站有哪些,测试性取向的权威测试或者网站?
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
想学网站制作怎么学,建立一个网站要花费多少?
建站DNS解析失败?如何正确配置域名服务器?
高防服务器租用首荐平台,企业级优惠套餐快速部署
制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?
建站上市公司网站建设方案与SEO优化服务定制指南
外贸公司网站制作,外贸网站建设一般有哪些步骤?
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
小型网站建站如何选择虚拟主机?
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
网站微信制作软件,如何制作微信链接?
建站之星安装后如何配置SEO及设计样式?
javascript中的try catch异常捕获机制用法分析
建站OpenVZ教程与优化策略:配置指南与性能提升
如何安全更换建站之星模板并保留数据?
如何快速使用云服务器搭建个人网站?
微信h5制作网站有哪些,免费微信H5页面制作工具?
网站建设设计制作营销公司南阳,如何策划设计和建设网站?
如何通过西部建站助手安装IIS服务器?
清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?
一键制作网站软件下载安装,一键自动采集网页文档制作步骤?
如何高效生成建站之星成品网站源码?
建站之星如何快速解决建站难题?
黑客如何利用漏洞与弱口令入侵网站服务器?
建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略
如何在万网开始建站?分步指南解析
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
如何通过主机屋免费建站教程十分钟搭建网站?
如何用腾讯建站主机快速创建免费网站?
小程序网站制作需要准备什么资料,如何制作小程序?
如何使用Golang table-driven基准测试_多组数据测量函数效率
建站三合一如何选?哪家性价比更高?
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
建站上传速度慢?如何优化加速网站加载效率?
如何快速搭建二级域名独立网站?
如何在景安云服务器上绑定域名并配置虚拟主机?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
如何选择可靠的免备案建站服务器?
广州顶尖建站服务:企业官网建设与SEO优化一体化方案
利用JavaScript实现拖拽改变元素大小
*请认真填写需求信息,我们会在24小时内与您取得联系。