IBM-Apache Thrift - 可伸缩的跨语言服务开发框架
POM:
<dependency> <groupId>org.apache.thrift</groupId> <artifactId>libthrift</artifactId> <version>0.9.2</version> </dependency>
Thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发。
thrift允许你定义一个简单的定义文件中的数据类型和服务接口。以作为输入文件,编译器生成代码用来方便地生成RPC客户端和服务器通信的无缝跨编程语言。
支持多种语言之间的RPC方式的通信:
php语言client可以构造一个对象,调用相应的服务方法来调用java语言的服务 ,跨越语言的C/S RPC调用 。
thrift可以用来快速的开发基于Socket的接口工具。简单的说,就是可以让人快速的写Socket Server和Client。其实不用thrift开发socket也不难,
那么为什么要用thrift开发呢?主要有两个原因,一个是因为thrift本身帮你封装了很多基本的东西,你不需要自己去写socket里面的bind,accept之类的,以及他们的逻辑。可以很快速的开发基于进程的,线程的,SSL的socket。第二个理由是标准化,跨语言和跨平台,windows不算在其中。主要是在各种Posix兼容的操作系统中都可以不需要改造基本直接可用,支持的语言种类也很多,基本你会写的,他都支持。你不会写的,他也支持。
Thrift与其他传输方式的比较
xml与JSON相比体积太大,但是xml传统,也不算复杂。
json 体积较小,新颖,但不够完善。
thrift 体积超小,使用起来比较麻烦,不如前两者轻便,但是对于1.高并发、2.数据传输量大、3.多语言环境, 满足其中2点使用 thrift还是值得的。
建立一个java rmi的流程 :
1、定义一个服务调用接口 。
2、server端:接口实现---impl的实例---注册该服务实现(端口)---启动服务。
3、client端:通过ip、端口、服务名,得到服务,通过接口来调用 。
4、rmi数据传输方式:java对象序列化 。
Thrift:
thrift --gen <language> <Thrift filename>
To recursivly generate source code from a Thrift file and all other Thrift files included by it, run
thrift -r --gen <language> <Thrift filename>
thrift-0.7.0.exe -r -gen java TestThrift.thrift 生成java 代码
thrift-0.7.0.exe -r -gen php TestThrift.thrift 生成php代码
thrift-0.7.0.exe -r -gen py TestThrift.thrift 生成python代码
thrift-0.7.0.exe -r -gen as3 TestThrift.thrift 生成as3代码
thrift-0.7.0.exe -r -gen cpp TestThrift.thrift 生成C++代码
基本概念
1.数据类型
基本类型:
bool:布尔值,true 或 false,对应 Java 的 boolean
byte:8 位有符号整数,对应 Java 的 byte
i16:16 位有符号整数,对应 Java 的 short
i32:32 位有符号整数,对应 Java 的 int
i64:64 位有符号整数,对应 Java 的 long
double:64 位浮点数,对应 Java 的 double
string:utf-8编码的字符串,对应 Java 的 String
结构体类型:
struct:定义公共的对象,类似于 C 语言中的结构体定义,在 Java 中是一个 JavaBean
容器类型:
list:对应 Java 的 ArrayList
set:对应 Java 的 HashSet
map:对应 Java 的 HashMap
异常类型:
exception:对应 Java 的 Exception
服务类型:
service:对应服务的类
2.服务端编码基本步骤:
实现服务处理接口impl
创建TProcessor
创建TServerTransport(TServerSocket)
创建TProtocol
创建TServer
启动Server
3.客户端编码基本步骤:
创建Transport
创建TProtocol
基于TTransport和TProtocol创建 Client
调用Client的相应方法
4.数据传输协议
TBinaryProtocol : 二进制格式.
TCompactProtocol : 压缩格式
TJSONProtocol : JSON格式
TSimpleJSONProtocol : 提供JSON只写协议, 生成的文件很容易通过脚本语言解析
tips:客户端和服务端的协议要一致
服务端类型:
TSimpleServer
简单的单线程服务模型,一般用于测试。
TThreadPoolServer
线程池服务模型,使用标准的阻塞式IO,预先创建一组线程处理请求。
TNonblockingServer:
使用非阻塞式IO,服务端和客户端需要指定 TFramedTransport 数据传输的方式。
例子:
1、thrift生成代码
使用thrift需要先定义接口文件demo.thrift,在thrift里简称叫IDL,全称叫Interface Description Language,接口描述语言。接口描述语言里面需要定义接口中所使用的数据类型,方法等等。
使用 Thrift 工具编译 demo.thrift,就会生成相应的 HelloWorldService.java 文件。该文件包含了在 demo.thrift 文件中描述的服务 HelloWorldService 的接口定义,即 HelloWorldService.Iface 接口,以及服务调用的底层通信细节,包括客户端的调用逻辑 HelloWorldService.Client 以及服务器端的处理逻辑 HelloWorldService.Processor,用于构建客户端和服务器端的功能。
创建一个简单的服务 HelloWordService。首先根据 Thrift 的语法规范编写脚本文件 demo.thrift:
namespace java com.service.demo service HelloWorldService{ string sayHello(1:string username) i32 helloInt(1:i32 para) bool helloBoolean(1:bool para) void helloVoid() string helloNull() }
thrift-0.9.2.exe 是官网提供的windows下编译工具,运用这个工具生成相关代码:
thrift-0.9.2.exe -r -gen java demo.thrift
生成文件目录:\gen-java\com\service\demo\HelloWorldService.java
将架包导入工程中,并将生成的HelloWordService.java拷入
2、 实现接口Iface
import org.apache.thrift.TException; public class HelloWorldServiceImpl implements HelloWorldService.Iface{ @Override public String sayHello(String username) throws TException { return "Hi," + username + " this is my first thrift demo."; } @Override public boolean helloBoolean(boolean para) throws TException { // TODO Auto-generated method stub return false; } @Override public int helloInt(int para) throws TException { // TODO Auto-generated method stub return 0; } @Override public String helloNull() throws TException { // TODO Auto-generated method stub return null; } @Override public void helloVoid() throws TException { // TODO Auto-generated method stub } }
3、创建服务端实现代码:
package com.common.test; import org.apache.thrift.TProcessor; import org.apache.thrift.protocol.TBinaryProtocol; import org.apache.thrift.server.TServer; import org.apache.thrift.server.TThreadPoolServer; import org.apache.thrift.transport.TServerSocket; public class HelloServiceServer { public static final int SERVER_PORT = 8090; public static void startServer() { try { System.out.println("HelloWorld TThreadPoolServer start ...."); TProcessor processor = new HelloWorldService.Processor(new HelloWorldServiceImpl()); TServerSocket serverTransport = new TServerSocket(SERVER_PORT); //TServerTransport serverTransport = new TServerSocket( new InetSocketAddress("0.0.0.0",9813)); TThreadPoolServer.Args ttpsArgs = new TThreadPoolServer.Args(serverTransport); ttpsArgs.processor(processor); ttpsArgs.protocolFactory(new TBinaryProtocol.Factory()); // 线程池服务模型,使用标准的阻塞式IO,预先创建一组线程处理请求。 TServer server = new TThreadPoolServer(ttpsArgs); server.serve(); /* 或者: Args trArgs=new Args(serverTransport); trArgs.processor(processor); //使用二进制来编码应用层的数据 trArgs.protocolFactory(new TBinaryProtocol.Factory(true, true)); //使用普通的socket来传输数据 //trArgs.transportFactory(new TTransportFactory()); TServer server = new TThreadPoolServer(trArgs); */ System.out.println("Start server on port "+SERVER_PORT+"..."); } catch (Exception e) { System.out.println("Server start error!!!"); e.printStackTrace(); } } /** * @param args */ public static void main(String[] args) { startServer(); } }
HelloWorld TThreadPoolServer start ....
4、创建客户端实现代码:
package com.common.test; 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; public class HelloServiceClient { public static final String SERVER_IP = "192.168.3.76"; public static final int SERVER_PORT = 8090; public static final int TIMEOUT = 30000; /** * * @param userName */ public static void startClient(String userName) { TTransport transport = null; try { transport = new TSocket(SERVER_IP, SERVER_PORT, TIMEOUT); // 协议要和服务端一致 TProtocol protocol = new TBinaryProtocol(transport); // TProtocol protocol = new TCompactProtocol(transport); // TProtocol protocol = new TJSONProtocol(transport); HelloWorldService.Client client = new HelloWorldService.Client(protocol); transport.open(); String result = client.sayHello(userName); System.out.println(result); } catch (TTransportException e) { e.printStackTrace(); } catch (TException e) { e.printStackTrace(); } finally { if (null != transport) { transport.close(); } } } /** * @param args */ public static void main(String[] args) { startClient("Michael"); } }
Hi,Michael this is my first thrift demo.
相关推荐
Thrift则是一个跨语言的服务框架,由Facebook开源,用于实现高性能、可扩展的服务通信。Thrift-Laravel项目是将Thrift与Laravel框架结合,使得在Laravel应用中可以轻松地实现Thrift服务的创建和消费。 一、Thrift...
在软件开发中,Thrift是一种高效的跨语言服务开发框架,由Facebook开发并开源。它允许定义数据类型和服务接口,然后自动生成各种编程语言的代码,使得不同语言的系统之间可以进行无缝通信。Maven作为Java项目管理...
总结来说,"thrift-0.13.0在Windows上exe程序.rar"提供了一个方便的工具,让用户在Windows环境中利用Thrift框架开发跨语言的分布式服务。无论是开发新项目还是集成到现有的系统中,这个.exe文件都能帮助开发者快速...
总结来说,Thrift是一个强大的工具,它简化了多语言服务开发,提高了通信效率,降低了跨语言、跨平台服务之间的复杂性。通过理解Thrift的基本原理和使用方法,开发者可以更有效地构建高效、可扩展的分布式系统。
Thrift是一种开源的跨语言服务开发框架,由Facebook于2007年创建,并于2008年贡献给了Apache基金会。它通过定义一种中间语言(IDL,Interface Definition Language)来描述服务接口,允许开发者在不同的编程语言之间...
Thrift是一种开源的软件框架,由Facebook在2007年开发,用于构建高效、可扩展的跨语言服务。它的核心在于提供了一种接口描述语言(IDL)和一种高效的二进制通讯协议,使得开发者可以方便地定义服务,并在多种编程...
通过定义Thrift IDL文件,可以生成跨语言的代码,简化了服务端和客户端的开发。结合Spring的IoC和AOP特性,我们可以方便地管理服务实例和事务处理,提高代码的可维护性和复用性。在实际开发中,还需要注意网络环境、...
Thrift是一种开源的跨语言服务开发框架,由Facebook于2007年设计并发布,其主要目的是解决大规模分布式系统中的通信问题。Thrift通过定义一种中间表示(IDL,Interface Definition Language),允许开发者在多种编程...
Thrift 是一个跨语言的 RPC 框架,由 Facebook 开发,用于建立高性能的服务之间的远程过程调用。为了使用 Thrift,需要配置好相关的环境,这篇文章将介绍 Thrift 环境配置的方法。 Thrift 环境配置的重要性 -------...
这种跨语言的能力使得开发多语言服务变得简单,同时Thrift还提供了一种轻量级的二进制协议,确保了通信效率。 二、Thrift IDL Thrift接口定义语言(IDL)是一种简单的结构化语言,用于定义服务、数据结构和常量。...
Thrift是一种跨语言的服务开发框架,它通过定义数据类型和服务接口,生成相应的客户端和服务器端代码,实现不同语言之间的通信。BSON(Binary JSON)是Thrift的一种序列化格式,类似于JSON但以二进制形式存储,更...
Thrift是Facebook开源的一款高性能、跨语言的服务框架,其核心理念是通过定义一种中间...总结起来,Thrift-0.11.0是一个强大的服务框架,提供了高效的跨语言通信能力,适用于各种分布式和微服务场景。通过其完善的ID
Thrift 是一个高效的跨语言服务开发框架,由Facebook开源,主要用于构建可扩展且跨平台的服务。它通过定义一种中间表示(IDL,Interface Description Language)来描述数据结构和服务接口,然后自动生成各种目标语言...
总结来说,Thrift 提供了一种高效、简洁的方式来构建分布式系统,通过定义服务接口和数据类型,自动生成跨语言的客户端和服务器端代码。在 Java 平台上,你可以利用这些生成的类创建服务器,处理客户端请求,并通过...
在IT行业中,Thrift是一种高性能、可扩展的跨语言服务开发框架,由Facebook开源,用于构建分布式服务。它通过定义一种中间表示(IDL,接口定义语言)来描述服务,然后自动生成不同编程语言的代码,使得不同语言之间...
总结来说,Thrift在阿里云和UC浏览器内核团队的应用展示了其在跨语言服务集成中的强大实力,尤其是在处理高并发和大数据量场景时的高效性。通过结合Node.js和RPC,Thrift成为了解决前端和后端耦合问题的有效工具,...
Thrift是由Facebook开发的一款跨语言的服务开发框架,旨在支持可扩展的跨平台服务。它通过定义一套简单的数据类型和接口来描述服务,然后自动生成所需的语言绑定代码和服务实现骨架。这使得开发者可以在不同的编程...