thrift 泛化客户端

thrift 泛化客户端

一、痛点

在使用thrift时,必须要根据IDL文件编译生成支持thrift协议的客户端代码。一旦有新服务添加,客户端程序必须重新编译并更新线上服务,无法动态调用新服务。

二、解决方案

2.1主要解决两个问题:

1.数据结构的描述信息
2.一个可以通用的thrift客户端

2.2数据结构的描述信息

众所周知thrift是跨平台的,无法像dubbo那样提供一个泛化客户端和服务端,必须要根据IDL定义的格式来转换。所以,要实现一个类泛化客户端,我们需要将描述信息抽象,并存在中间介质(我使用的是mysql),一旦有新的服务,只需要结构描述信息写入中间介质,泛化客户端便可以调用了。

描述信息实体:
GenericTree

如图,用来描述一个thrift对象。且这个树状结构可以将这个对象的层级关系描述清楚(比如说一个struct,就可能有多层关系)。

GenericNode

它是一个总的结构体,用来描述该服务相关的所有信息。调用具体方法的方法名、入参数据以及入参、出参描述信息

2.3一个可以通用的thrift客户端

我们知道,thrift底层传输协议虽然有多种,但是它都是将数据按顺序排列构造成一个数据包,我们只要清楚这个数据包的顺序,并动态获取描述信息,就可以自己构造和解析传输数据了。
thrift数据包描述(比较简单,里面还有一些细节)
这里写图片描述

一旦可以获取描述信息 并且摸清解析规则,这样我们便可以构造一个泛化客户端了。
write:
基于java的泛化客户端,一切传输数据都是Object,根据描述信息转换成具体的thrift类型数据,按照一定的传输协议发送到客户端
read:
按照描述信息遍历获取的数据包,并最终构造一个json对象,返回给调用方。
本项目同时支持同步和异步调用
github地址:https://github.com/waj89757/generic-thrift-client

Nifty是facebook公司开源的,基于netty的thrift服务端和客户端实现。 然后使用此包就可以快速发布出基于netty的高效的服务端和客户端代码。 示例: public void startServer() { // Create the handler MyService.Iface serviceInterface = new MyServiceHandler(); // Create the processor TProcessor processor = new MyService.Processor<>(serviceInterface); // Build the server definition ThriftServerDef serverDef = new ThriftServerDefBuilder().withProcessor(processor) .build(); // Create the server transport final NettyServerTransport server = new NettyServerTransport(serverDef, new NettyConfigBuilder(), new DefaultChannelGroup(), new HashedWheelTimer()); // Create netty boss and executor thread pools ExecutorService bossExecutor = Executors.newCachedThreadPool(); ExecutorService workerExecutor = Executors.newCachedThreadPool(); // Start the server server.start(bossExecutor, workerExecutor); // Arrange to stop the server at shutdown Runtime.getRuntime().addShutdownHook(new Thread() { @Override public void run() { try { server.stop(); } catch (InterruptedException e) { Thread.currentThread().interrupt(); } } }); } Or the same thing using guice: public void startGuiceServer() { final NiftyBootstrap bootstrap = Guice.createInjector( Stage.PRODUCTION, new NiftyModule() { @Override protected void configureNifty() { // Create the handler MyService.Iface serviceInterface = new MyServiceHandler(); // Create the processor TProcessor processor = new MyService.Processor<>(serviceInterface); // Build the server definition ThriftServerDef serverDef = new ThriftServerDefBuilder().withProcessor(processor) .build(); // Bind the definition bind().toInstance(serverDef); } }).getInstance(NiftyBootstrap.class); // Start the server bootstrap.start(); // Arrange to stop the server at shutdown Runtime.getRuntime().addShutdownHook(new Thread() { @Override public void run() { bootstrap.stop(); } }); } 标签:Nifty
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值