当前位置:网站首页>Thrift installation configuration
Thrift installation configuration
2022-08-04 17:57:00 【Listen to the wind in the right ear】
thrift的下载与安装
在官网下载安装包 https://thrift.apache.org/download
Thrift是由Facebook开发的,用来进行可扩展且跨语言的服务开发.它结合了功能强大的软件堆栈和代码生成引擎.
ThriftIs a driver layer interface,It provides implementations for clients using multiple languagesAPI.
Supported client languages includeC++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, JavaScript, Node.js, Smalltalk, and OCaml .Its goal is to provide convenience for a variety of popular languagesRPC调用机制,Instead of using those expensive methods.
要使用Thrift,To use a language-neutral service definition file,描述数据类型和服务接口.This file will be used as input to the engine,The compiler generates code for each supported language.This statically generated design makes it very easy to use by developers,And because type verification happens at compile time, not run time,So the code can run very efficiently.
Thriftis designed to provide the following features:
1、Language-independent types
Because types are specified in a language-neutral way using definition files,So they can be shared by different languages.比如,C++The structure can be combined withPythonThe dictionary types exchange data with each other.
2、Universal Transport Interface
Regardless of whether you are using a disk file、Memory data is still theresocket流,Both can use the same application code.
3、协议无关
ThriftData types are encoded and decoded,Can be used across protocols.
4、支持版本
The data type can add version information,to support clientsAPI的更新.
MAC OS下thrift的下载与安装
在shell里面执行:
brew install thrift.
Or download into the root directory:
step1:cd thrift-0.10.0
step2:./configure
step3:make
step4:make install
windows下thrift的下载与安装
到thrift官网下载exe文件,然后将文件重命名为thrift.exe,拷贝到D:\EBOOK\thrift目录下(or any directory),然后就可以在dos环境下使用了
D:\EBOOK\thrift>thrift -gen java D:\work\workspace\thriftworkspace\demo1\demoHello.thrift
输出的javaFiles are output to the current directory by defaultD:\EBOOK\thrift\gen-java,也可以使用-oThe parameter specifies the output path;
maven依赖
创建一个Maven管理的Java项目,pom.xml中添加相关的依赖,并将Hello.java文件复制到项目中:
<dependency>
<groupId>org.apache.thrift</groupId>
<artifactId>libthrift</artifactId>
<version>0.15.0</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.5</version>
</dependency>
基本概念
thrift通过一个中间语言IDL(Interface Description Language接口定义语言)来定义RPCdata types and interfaces,These are written in .thrift结尾的文件中,Codes in different languages are then generated by special compilers,To meet the different needs of developers,比如java开发者,就可以生成java代码,c++Developers can generatec++代码,The generated code contains not only the interface definition of the target language,方法,数据类型,还包含有RPCImplementation code for the protocol layer and the transport layer.
Thrift IDL示例文件
基本类型:
thrift不支持无符号的类型,Unsigned types can be simply understood as not being able to represent negative numbers,Types that can only represent positive numbers,像javaThe basic data types are all signed types.
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
struct User {
1: i32 id;
2: string name;
3: double salary;
4: bool hasCar;
}
容器类型:
Elements in a collection can be exceptservice之外的任意类型
list:有序列表,元素可重复
set:无需集合,元素不可重复
map<K,V>:键值对集合
list:对应Java的ArrayList
set:对应Java的HashSet
map:对应Java的HashMap
异常类型:
exception:对应Java的Exception
exception RequestException {
1:i32 code;
2:string detail;
}
服务类型:
service:对应服务的接口,Various methods can be defined internally,相当于java中创建interface一样,创建的serviceAfter the code generation command will generate the client,Server-side framework code
service Hello{
string helloString(1:string s);
i32 helloInt(1:i32 i);
bool helloBoolean(1:bool b);
void helloVoid();
string helloNull();
}
枚举类型
enum Color{
RED,
BLUE
}
Thrift常量
thriftConstant definitions are also supported,使用const关键字:
const i32 MAX_RETRIES_TIME=10
const string MY_WEBSITE="https://www.apache.org/dyn/closer.cgi?path=/thrift/0.16.0/thrift-0.16.0.tar.gz"
命名空间(namespace)
可以理解成java中的packet,Used to avoid some code conflicts,Each language has its own way of namespaces,比如java语言,就可以使用java语言的格式
namespace java com.wang.project
In addition, some language features and keywords are not introduced one by one,Such as optional parameters and required parameters,required和optional,定义常量const,引入文件include等
服务端编码基本步骤:
0.实现服务处理接口impl,重写接口方法.
1.创建TProcessor(业务处理器)
ProcessorEncapsulates the operations of reading data from the input data stream and writing data to the data stream,与服务相关的Processoris compiled by the compilerIDL文件产生的,它的主要工作是:从连接中读取数据,Leave the processing to the user for implementationimpl,Finally write the result to the connection.
2.创建TServerTransport()
TServerSocket是ServerTransport的阻塞式IO的实现.It implements the role of the listening port,accept到的SocketTypes are client-sideTSocket类型(阻塞式Socket).
3.创建TProtocol(传输协议)
TProtocolBasic protocol information is defined,Including what data to transmit,How to parse the transmitted data.
4.创建TServer
Choose to use different service modes as needed,The code is just the simplest for demonstrationTSimpleServer
5.启动Server
客户端编码基本步骤:
创建Transport
创建TProtocol
基于TTransport和TProtocol创建Client
调用Client的相应方法
数据传输协议
Thrift支持多种传输协议,We can choose the right type according to our needs,总体上来说,Divided into text transmission and binary transmission,Because binary transmission has advantages in transmission rate and saving bandwidth,So in most cases using binary transmission is a better choice.
TBinaryProtocol: 二进制格式,是thriftThe default transport protocol for
TCompactProtocol: 压缩格式
TJSONProtocol: JSON格式
TSimpleJSONProtocol: 提供JSON只写协议, 生成的文件很容易通过脚本语言解析
TDebugProtocol – Transmit in a human-readable text format,以便于debug
客户端和服务端的协议要一致
ThriftSupported transport modes
ThriftA transport layer is encapsulated to support the underlying network communication,在Thrift中称为Transport,不仅提供open,close,flush等方法,还有一些read/write方法.
TSocket:阻塞式IO的Transport实现,用在客户端.
TServerSocket:非阻塞式Socket,用于服务器端,用于监听TSocket.
TNonblockingSocket:非阻塞式IO的实现
TMemoryInputTransport: Encapsulates a byte arraybyte[]to encapsulate the input stream
TFramedTransport- The same non-blocking method is used,按块的大小进行传输,The input stream is encapsulatedTMemoryInputTransport
thrift生成代码
创建Thrift文件,Hello.thrift ,内容如下:
namespace java com.dxz.thrift.demo
service HelloWorldService {
string sayHello(1:string username)
}
thrift-0.15.0.exe是官网提供的windows下编译工具,运用这个工具生成相关代码:
D:\EBOOK\thrift>thrift-0.15.0.exe -r -gen java D:\work\workspace\thriftworkspace\demo1\Hello.thrift
Mac终端进入Hello.thrift所在目录,执行命令:
thrift -r -gen java Hello.thrift
实现接口Iface
java代码:HelloWorldImpl.java
package com.dxz.thrift.demo;
import org.apache.thrift.TException;
public class HelloWorldImpl implements HelloWorldService.Iface {
public HelloWorldImpl() {
}
@Override
public String sayHello(String username) throws TException {
return "Hi," + username + " welcome to thrift world";
}
}
Thrift支持的服务模型
TSimpleServer:
This working mode has only one thread,The loop listens for incoming requests and processes them,After processing, the next request can be accepted,is a blocking typeIO的实现,因为效率比较低,The actual online environment is generally not used.It is generally used to demonstrate the workflow during development.
TNonblockingServer:
这种模式与TsimpleServerThe biggest difference is the usageNIO,That is, non-blocking isIO的方式实现IO的多路复用,It can monitor multiple at the same timesocket的变化,But because the business processing is still a single-threaded mode,Therefore, when some business processing is more complex and time-consuming, the efficiency is still not high,Because multiple request tasks still need to be queued for processing one by one.
TThreadPoolServer:
This pattern introduces a thread pool,主线程只负责accept,即监听Socket,当有新的请求(客户端Socket)来时,A thread will be created in the thread pool to process the business logic,This is when the concurrency is relatively large(But not more than the number of thread pools)Every request can be processed in a timely manner,效率比较高,But once the concurrency is large(Exceeds the number of thread pools),Later requests can only wait in line.
TThreadedSelectorServer:
This is a multi-threaded, semi-synchronous and semi-asynchronous service model,是ThriftThe most complex and advanced service model offered,There is an internal one specifically responsible for handling monitoringSocket的线程,There are multiple networks dedicated to dealing with businessIO的线程,There is a dedicated person responsible for deciding what will be newSocketWhich thread to handle the load balancing thread the connection is assigned to,There is also a pool of worker threads.This model can both respond to a large number of concurrent connection requests and fast to the networkIO进行读写,Can adapt to many scenarios,Therefore, it is a service model that is used more frequently.
TSimpleServer服务端&客户端Client
简单的单线程服务模型,一般用于测试.
编写服务端server代码:HelloServer.java
package com.dxz.thrift.demo;
import org.apache.thrift.TProcessor;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TCompactProtocol;
import org.apache.thrift.protocol.TJSONProtocol;
import org.apache.thrift.protocol.TSimpleJSONProtocol;
import org.apache.thrift.server.TServer;
import org.apache.thrift.server.TSimpleServer;
import org.apache.thrift.transport.TServerSocket;
public class HelloServer {
public static final int SERVER_PORT = 8090;
public void startServer() {
try {
System.out.println("HelloWorld TSimpleServer start ....");
TProcessor tprocessor = new HelloWorldService.Processor<HelloWorldService.Iface>(new HelloWorldImpl());
//HelloWorldService.Processor<HelloWorldService.Iface> tprocessor =
new HelloWorldService.Processor<HelloWorldService.Iface>(new HelloWorldImpl());
// 简单的单线程服务模型,一般用于测试
TServerSocket serverTransport = new TServerSocket(SERVER_PORT);
TServer.Args tArgs = new TServer.Args(serverTransport);
tArgs.processor(tprocessor);
tArgs.protocolFactory(new TBinaryProtocol.Factory());
// tArgs.protocolFactory(new TCompactProtocol.Factory());
// tArgs.protocolFactory(new TJSONProtocol.Factory());
TServer server = new TSimpleServer(tArgs);
server.serve();
} catch (Exception e) {
System.out.println("Server start error!!!");
e.printStackTrace();
}
}
public static void main(String[] args) {
HelloServerDemo server = new HelloServerDemo();
server.startServer();
}
}
编写客户端Client代码:HelloClient.java
package com.dxz.thrift.demo;
import org.apache.thrift.TException;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TCompactProtocol;
import org.apache.thrift.protocol.TJSONProtocol;
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 HelloClient {
public static final String SERVER_IP = "localhost";
public static final int SERVER_PORT = 8090;
public static final int TIMEOUT = 30000;
public 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("Thrify client result =: " + result);
} catch (TTransportException e) {
e.printStackTrace();
} catch (TException e) {
e.printStackTrace();
} finally {
if (null != transport) {
transport.close();
}
}
}
public static void main(String[] args) {
HelloClientDemo client = new HelloClientDemo();
client.startClient("china");
}
}
先运行服务端程序,日志如下:
HelloWorld TSimpleServer start …
再运行客户端调用程序,日志如下:
Thrify client result =: Hi,china welcome to thrift world.
测试成功,和预期的返回信息一致.
TThreadPoolServer 服务模型
线程池服务模型,使用标准的阻塞式IO,预先创建一组线程处理请求.
编写服务端代码:HelloServer2.java
package com.dxz.thrift.demo;
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 HelloServer2 {
public static final int SERVER_PORT = 8090;
public void startServer() {
try {
System.out.println("HelloWorld TThreadPoolServer start ....");
TProcessor tprocessor = new HelloWorldService.Processor<HelloWorldService.Iface>(new HelloWorldImpl());
TServerSocket serverTransport = new TServerSocket(SERVER_PORT);
TThreadPoolServer.Args ttpsArgs = new TThreadPoolServer.Args(serverTransport);
ttpsArgs.processor(tprocessor);
ttpsArgs.protocolFactory(new TBinaryProtocol.Factory());
// 线程池服务模型,使用标准的阻塞式IO,预先创建一组线程处理请求.
TServer server = new TThreadPoolServer(ttpsArgs);
server.serve();
} catch (Exception e) {
System.out.println("Server start error!!!");
e.printStackTrace();
}
}
public static void main(String[] args) {
HelloServerDemo2 server = new HelloServerDemo2();
server.startServer();
}
}
客户端Client代码和之前的一样,只要数据传输的协议一致即可,客户端测试成功,结果如下:
Thrify client result =: Hi,china welcome to thrift world.
TNonblockingServer &Client 服务模型
使用非阻塞式IO,服务端和客户端需要指定TFramedTransport数据传输的方式.
编写服务端代码:HelloServer3.java
package com.dxz.thrift.demo;
import org.apache.thrift.TProcessor;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TCompactProtocol;
import org.apache.thrift.server.TNonblockingServer;
import org.apache.thrift.server.TServer;
import org.apache.thrift.server.TThreadPoolServer;
import org.apache.thrift.transport.TFramedTransport;
import org.apache.thrift.transport.TNonblockingServerSocket;
import org.apache.thrift.transport.TServerSocket;
public class HelloServer3 {
public static final int SERVER_PORT = 8090;
public void startServer() {
try {
System.out.println("HelloWorld TNonblockingServer start ....");
TProcessor tprocessor = new HelloWorldService.Processor<HelloWorldService.Iface>(new HelloWorldImpl());
TNonblockingServerSocket tnbSocketTransport = new TNonblockingServerSocket(SERVER_PORT);
TNonblockingServer.Args tnbArgs = new TNonblockingServer.Args(tnbSocketTransport);
tnbArgs.processor(tprocessor);
tnbArgs.transportFactory(new TFramedTransport.Factory());
tnbArgs.protocolFactory(new TCompactProtocol.Factory());
// 使用非阻塞式IO,服务端和客户端需要指定TFramedTransport数据传输的方式
TServer server = new TNonblockingServer(tnbArgs);
server.serve();
} catch (Exception e) {
System.out.println("Server start error!!!");
e.printStackTrace();
}
}
/** * @param args */
public static void main(String[] args) {
HelloServerDemo3 server = new HelloServerDemo3();
server.startServer();
}
}
编写客户端代码:HelloClient3.java
package com.dxz.thrift.demo;
import org.apache.thrift.TException;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TCompactProtocol;
import org.apache.thrift.protocol.TJSONProtocol;
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.apache.thrift.TException;
import org.apache.thrift.protocol.TCompactProtocol;
import org.apache.thrift.protocol.TProtocol;
import org.apache.thrift.transport.TFramedTransport;
import org.apache.thrift.transport.TSocket;
import org.apache.thrift.transport.TTransport;
import org.apache.thrift.transport.TTransportException;
public class HelloClient3 {
public static final String SERVER_IP = "localhost";
public static final int SERVER_PORT = 8090;
public static final int TIMEOUT = 30000;
public void startClient(String userName) {
TTransport transport = null;
try {
transport = new TFramedTransport(new TSocket(SERVER_IP, SERVER_PORT, TIMEOUT));
// 协议要和服务端一致
TProtocol protocol = new TCompactProtocol(transport);
HelloWorldService.Client client = new HelloWorldService.Client(protocol);
transport.open();
String result = client.sayHello(userName);
System.out.println("Thrify client result =: " + 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) {
HelloClientDemo3 client = new HelloClientDemo3();
client.startClient("HelloClientDemo3");
}
}
客户端的测试成功,结果如下:
Thrify client result =: Hi,HelloClientDemo3 welcome to thrift world.
THsHaServer服务模型
半同步半异步的服务端模型,需要指定为:TFramedTransport数据传输的方式.
编写服务端代码:HelloServer4.java
package com.dxz.thrift.demo;
import org.apache.thrift.TProcessor;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TCompactProtocol;
import org.apache.thrift.server.THsHaServer;
import org.apache.thrift.server.TNonblockingServer;
import org.apache.thrift.server.TServer;
import org.apache.thrift.server.TSimpleServer;
import org.apache.thrift.server.TThreadPoolServer;
import org.apache.thrift.transport.TFramedTransport;
import org.apache.thrift.transport.TNonblockingServerSocket;
import org.apache.thrift.transport.TServerSocket;
public class HelloServer4 {
public static final int SERVER_PORT = 8090;
public void startServer() {
try {
System.out.println("HelloWorld THsHaServer start ....");
TProcessor tprocessor = new HelloWorldService.Processor<HelloWorldService.Iface>(new HelloWorldImpl());
TNonblockingServerSocket tnbSocketTransport = new TNonblockingServerSocket(SERVER_PORT);
THsHaServer.Args thhsArgs = new THsHaServer.Args(tnbSocketTransport);
thhsArgs.processor(tprocessor);
thhsArgs.transportFactory(new TFramedTransport.Factory());
thhsArgs.protocolFactory(new TBinaryProtocol.Factory());
// 半同步半异步的服务模型
TServer server = new THsHaServer(thhsArgs);
server.serve();
} catch (Exception e) {
System.out.println("Server start error!!!");
e.printStackTrace();
}
}
/** * @param args */
public static void main(String[] args) {
HelloServerDemo4 server = new HelloServerDemo4();
server.startServer();
}
}
客户端代码HelloClient4.java
package com.dxz.thrift.demo;
import java.io.IOException;
import org.apache.thrift.TException;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TCompactProtocol;
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 HelloClientDemo4 {
public static final String SERVER_IP = "localhost";
public static final int SERVER_PORT = 8090;
public static final int TIMEOUT = 30000;
public void startClient(String userName) {
TTransport transport = null;
try {
transport = new TFramedTransport(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("Thrify client result =: " + 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) {
HelloClientDemo4 client = new HelloClientDemo4();
client.startClient("HelloClientDemo4");
}
}
结果:Thrify client result =: Hi,HelloClientDemo4 welcome to thrift
world.
异步客户端
编写服务端代码:HelloServer5.java
package com.dxz.thrift.demo;
import org.apache.thrift.TProcessor;
import org.apache.thrift.protocol.TCompactProtocol;
import org.apache.thrift.server.TNonblockingServer;
import org.apache.thrift.server.TServer;
import org.apache.thrift.transport.TFramedTransport;
import org.apache.thrift.transport.TNonblockingServerSocket;
public class HelloServer5 {
public static final int SERVER_PORT = 8090;
public void startServer() {
try {
System.out.println("HelloWorld TNonblockingServer start ....");
TProcessor tprocessor = new HelloWorldService.Processor<HelloWorldService.Iface>(new HelloWorldImpl());
TNonblockingServerSocket tnbSocketTransport = new TNonblockingServerSocket(SERVER_PORT);
TNonblockingServer.Args tnbArgs = new TNonblockingServer.Args(tnbSocketTransport);
tnbArgs.processor(tprocessor);
tnbArgs.transportFactory(new TFramedTransport.Factory());
tnbArgs.protocolFactory(new TCompactProtocol.Factory());
// 使用非阻塞式IO,服务端和客户端需要指定TFramedTransport数据传输的方式
TServer server = new TNonblockingServer(tnbArgs);
server.serve();
} catch (Exception e) {
System.out.println("Server start error!!!");
e.printStackTrace();
}
}
/** * @param args */
public static void main(String[] args) {
HelloServerDemo5 server = new HelloServerDemo5();
server.startServer();
}
}
编写客户端Client代码:HelloAsynClient.java
package com.dxz.thrift.demo;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;
import org.apache.thrift.TException;
import org.apache.thrift.async.AsyncMethodCallback;
import org.apache.thrift.async.TAsyncClientManager;
import org.apache.thrift.protocol.TCompactProtocol;
import org.apache.thrift.protocol.TProtocolFactory;
import org.apache.thrift.transport.TNonblockingSocket;
import org.apache.thrift.transport.TNonblockingTransport;
import com.dxz.thrift.demo.HelloWorldService.AsyncClient.sayHello_call;
public class HelloAsynClient {
public static final String SERVER_IP = "localhost";
public static final int SERVER_PORT = 8090;
public static final int TIMEOUT = 30000;
public void startClient(String userName) {
try {
TAsyncClientManager clientManager = new TAsyncClientManager();
TNonblockingTransport transport = new TNonblockingSocket(SERVER_IP, SERVER_PORT, TIMEOUT);
TProtocolFactory tprotocol = new TCompactProtocol.Factory();
HelloWorldService.AsyncClient asyncClient = new HelloWorldService.AsyncClient(tprotocol, clientManager,
transport);
System.out.println("Client start .....");
CountDownLatch latch = new CountDownLatch(1);
AsynCallback callBack = new AsynCallback(latch);
System.out.println("call method sayHello start ...");
asyncClient.sayHello(userName, callBack);
System.out.println("call method sayHello .... end");
boolean wait = latch.await(30, TimeUnit.SECONDS);
System.out.println("latch.await =:" + wait);
} catch (Exception e) {
e.printStackTrace();
}
System.out.println("startClient end.");
}
public class AsynCallback implements AsyncMethodCallback<sayHello_call> {
private CountDownLatch latch;
public AsynCallback(CountDownLatch latch) {
this.latch = latch;
}
@Override
public void onComplete(sayHello_call response) {
System.out.println("onComplete");
try {
// Thread.sleep(1000L * 1);
System.out.println("AsynCall result =:" + response.getResult().toString());
} catch (TException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
} finally {
latch.countDown();
}
}
@Override
public void onError(Exception exception) {
System.out.println("onError :" + exception.getMessage());
latch.countDown();
}
}
/** * @param args */
public static void main(String[] args) {
HelloAsynClientDemo client = new HelloAsynClientDemo();
client.startClient("HelloAsynClientDemo");
}
}
先运行服务程序,再运行客户端程序,测试结果如下:
Client start .....
call method sayHello start ...
call method sayHello .... end
onComplete
AsynCall result =:Hi,HelloAsynClientDemo welcome to thrift world.
latch.await =:true
startClient end.
边栏推荐
猜你喜欢
随机推荐
R语言ggpubr包的ggline函数可视化折线图、设置add参数为mean_se和dotplot可视化不同水平均值的折线图并为折线图添加误差线(se标准误差)和点阵图、设置折线和数据点边框颜色
Cholesterol-PEG-Maleimide,CLS-PEG-MAL,胆固醇-聚乙二醇-马来酰亚胺一种修饰性PEG
关于大学生内卷的文献综述
Flutter实战-请求封装(四)之gzip报文压缩
linux下Mysql的简单操作
Codeforces积分系统介绍
解决错误:The package-lock.json file was created with an old version of npm
"No title"
Fork/Join框架
Cholesterol-PEG-DBCO,CLS-PEG-DBCO,胆固醇-聚乙二醇-二苯基环辛炔科研试剂
静态iP与权限更改[通俗易懂]
哈夫曼树(暑假每日一题 15)
使用bash语句,清空aaa文件夹下的所有文件
OpenInfra Days China 2022|SelectDB与你共享 Apache Doris 在互联网广告业务中的实践
信息系统项目管理师必背核心考点(六十)项目集管理
字节二面被问到mysql事务与锁问题,我蚌埠住了
我的大一.
LVS+Keepalived群集
报道称任天堂在2023年3月前不会推出任何新硬件产品
JWT主动校验Token是否过期