Thrift对多接口服务的支持

Thrift在0.9.1版本之前,一直只提交了对单一接口服务的支持,即一个RPC服务器(对应一个端口)支持一个服务接口的实现。

但是很多时候,我们的服务不能实现在一个接口里,一是接口里的方法越来越多,不好管理和使用;二是根据职责的单一要求,不能类型的方法,不能放在同一接口里。

在 Thrift-0.9.1之前,我们要解决上面的问题,一是通过多个RPC服务器来实现,这个方法必然导致了我们RPC服务器越来越多,管理上麻烦;二是通过其他的一些途径,如使用netty作为RPC服务器等,这个方法实现上相对麻烦一些,需要去了解netty的知识。

这些方法在这里就不再详述了。

从Thrift-0.9.1开始,thrift开始提供对多接口服务的支持,使得我们开发多接口RPC服务相对简单多了。

这里还是给出例子来说明。

首先,我们做了两个接口定义文件来定义两个接口:

namespace javacom.eli.test.service

struct Topic

{

1: i32 uid,

2: string name,

3: string content

}

service TopicService

{

void store(1: Topic topic),

Topic retrieve(1: i32 uid)

}

namespace javacom.eli.test.service

struct User

{

1: i32 uid,

2: string name,

3: string blurb

}

service UserService

{

void store1(1: User user),

User retrieve1(1: i32 uid)

}

然后使用Thrift-0.9.1.exe生成相应的JavaBean及接口:

然后,我们写两个接口的实现类:

import org.apache.thrift.TException;

import com.eli.test.service.Topic;

import com.eli.test.service.TopicService;

public class TopicImpl implements TopicService.Iface{

public void store(Topic topic)throws TException

{

System.out.println("theinput topic: ");

System.out.println("id:"+topic.getUid());

System.out.println("name:"+topic.getName());

System.out.println("content:"+topic.getContent());

}

public Topic retrieve(int uid)throws TException

{

System.out.println("theinput uid: "+uid);

return newTopic(uid,"test","test");

}

}

import org.apache.thrift.TException;

import com.eli.test.service.User;

import com.eli.test.service.UserService;

public class UserImpl implements UserService.Iface{

public void store1(User user)throws TException

{

System.out.println("theinput user: ");

System.out.println("uid:"+user.getUid());

System.out.println("name:"+user.getName());

System.out.println("blur:"+user.getBlurb());

}

public User retrieve1(int uid)throws TException

{

System.out.println("theinput uid: "+uid);

return newUser(uid,"tom","123");

}

}

上述工作完成以后,就可以写服务器代码了。

服务器代码与单一接口的服务器代码最大的不同是使用了“TMultiplexedProcessor”类,通过该类,可以注册多个接口的服务实现类:

TMultiplexedProcessor processor = new TMultiplexedProcessor();

processor.registerProcessor("TopicService", newTopicService.Processor<TopicService.Iface>(new TopicImpl()));

processor.registerProcessor("UserService", new UserService.Processor<UserService.Iface>(new UserImpl()));

其他代码就跟以前的服务器代码一样了。

完整的服务器代码如下:

TMultiplexedProcessor processor = newTMultiplexedProcessor();

TServerTransport t = new TServerSocket(9090);

TServer server = new TThreadPoolServer(newTThreadPoolServer.Args(t).processor(processor));

processor.registerProcessor("TopicService", newTopicService.Processor<TopicService.Iface>(new TopicImpl()));

processor.registerProcessor("UserService", newUserService.Processor<UserService.Iface>(new UserImpl()));

//         TSimpleServer server = new TSimpleServer(new Args(t).processor(processor));

System.out.println("the serveris started and is listening at 9090...");

server.serve();

最后是客户端代码了,客户端代码的不同之处是引入了“TMultiplexedProtocol”类,它来帮助客户端区别调用哪个接口:

TMultiplexedProtocol mp1 = new TMultiplexedProtocol(protocol,"TopicService");

TopicService.Clientservice1 = new TopicService.Client(mp1);

完整的客户端测试代码如下:

TSocket transport = new TSocket("localhost",9090);

TBinaryProtocol protocol = new TBinaryProtocol(transport);

TMultiplexedProtocolmp1 = new TMultiplexedProtocol(protocol,"TopicService");

TopicService.Client service1 = newTopicService.Client(mp1);

TMultiplexedProtocolmp2 = new TMultiplexedProtocol(protocol,"UserService");

UserService.Client service2 = newUserService.Client(mp2);

transport.open();

service1.store(new Topic(668,"test topic","just a test!"));

service2.store1(new User(888,"tom","haha"));

System.out.println(service1.retrieve(168));

System.out.println(service2.retrieve1(999));

transport.close();

运行服务器代码和客户端代码,则客户端会打印如下结果:

Topic(uid:168, name:test, content:test)

User(uid:999, name:tom, blurb:123)

服务器端会打印如下的信息:

the server is started and is listening at 9090...

the input topic:

id: 668

name: test topic

content: just a test!

the input user:

uid: 888

name: tom

blur: haha

the input uid: 168

the input uid: 999

通过上面的例子,可以看到,Thrift-0.9.1版本很简单的解决了多接口服务的问题,随便说一下,该版本并没有解决所有语言的多接口实现问题,只是解决了Java和其他几个语言。请大家在使用的时候,查清楚您使用的语言是否解决了这个问题。

Thrift对多接口服务的支持的更多相关文章

  1. Thrift搭建分布式微服务1

    Thrift搭建分布式微服务 一.Thrift是什么? 关于Thrift的基本介绍,参看张善友的文章Thrift简介. 二.为什么使用微服务? 在公司的高速发展过程中,随着业务的增长,子系统越来越多. ...

  2. Thrift搭建分布式微服务(四)

      第一篇 <连接配置> 第二篇 <连接池> 第三篇 <标准通信> 第四篇 快速暴露接口 之前的文章,我们介绍了如何使用连接池管理Thrift节点,以及使用Thri ...

  3. Thrift搭建分布式微服务(二)

    第二篇 连接池  连接池配置,请前往Thrift搭建分布式微服务(一)  下面要介绍的其实不是单一的连接池,应该说是连接池集合.因为它要管理多个Tcp Socket连接节点,每个服务节点都有设置了自己 ...

  4. SpringBoot接口服务处理Whitelabel Error Page(转)

    To switch it off you can set server.error.whitelabel.enabled=false http://stackoverflow.com/question ...

  5. dotnet core 开发无缝兼容Http和Websocket协议的接口服务

    在应用接口开发中往往要针对不同协义开发相应的代理服务,但对于Websocket和http这两种协议来说就有些不同,从实现上来看Websocket可以说是Http的升级子协议, 两者在协议处理上基本一致 ...

  6. ASP.NET WebAPI构建API接口服务实战演练

    一.课程介绍 一.王小二和他领导的第一次故事 有一天王小二和往常一下去上早班,刚吃完早餐刚一打开电脑没一会儿.王小二的领导宋大宝走到他的面前,我们现在的系统需要提供服务给其他内部业务系统,我看你平时喜 ...

  7. SpringBoot接口服务处理Whitelabel Error Page

    转载请注明来源:http://blog.csdn.net/loongshawn/article/details/50915979 <SpringBoot接口服务处理Whitelabel Erro ...

  8. Thrift写RPC接口

    Thrift总结(二)创建RPC服务 前面介绍了thrift 基础的东西,怎么写thrift 语法规范编写脚本,如何生成相关的语言的接口.不清楚的可以看这个<Thrift总结(一)介绍>. ...

  9. PHP laravel+thrift+swoole打造微服务框架

    Laravel作为最受欢迎的php web框架一直广受广大互联网公司的喜爱. 笔者也参与过一些由laravel开发的项目.虽然laravel的性能广受诟病但是业界也有一些比较好的解决方案,比如堆机器, ...

随机推荐

  1. XSS CSRF

    XSS CSRF XSS 参考 https://zh.wikipedia.org/wiki/%E8%B7%A8%E7%B6%B2%E7%AB%99%E6%8C%87%E4%BB%A4%E7%A2%BC ...

  2. JAVA泛型-擦除

    package com.xt.thinks15_7; import java.util.Arrays; class EraseObject1<A> { } class EraseObjec ...

  3. openstack中iptables的使用

    openstack中nova使用了iptables实现其网络相关功能,乍看openstack的iptables表比较复杂,整理了一下iptables的filter表和nat表的结构,以一个all in ...

  4. SPOJ 1812 Longest Common Substring II(后缀自动机)

    [题目链接] http://www.spoj.com/problems/LCS2/ [题目大意] 求n个串的最长公共子串 [题解] 对一个串建立后缀自动机,剩余的串在上面跑,保存匹配每个状态的最小值, ...

  5. java 获取随机数的三种方法

    方法1(数据类型)(最小值+Math.random()*(最大值-最小值+1))例:(int)(1+Math.random()*(10-1+1))从1到10的int型随数 方法2获得随机数for (i ...

  6. fastDFS同步问题讨论

    一.文件同步延迟问题 前面也讲过fastDFS同组内storage server数据是同步的, Storage server中由专门的线程根据binlog进行文件同步.为了最大程度地避免相互影响以及出 ...

  7. 如何在windows server 2012 R2 部署WEB项目

    tip: 今天发布项目到windows server 2012 R2上面. 没有接触过,其实很简单,看图: 这是安装IIS成功后显示的总图: 二.点击Manage ,选择Add Roles and F ...

  8. 使用python抓取知乎日报的API数据

    使用 urllib2 抓取数据时,最简单的方法是: import urllib2, json def getStartImage(): stream = urllib2.urlopen('http:/ ...

  9. ASP.NET之电子商务系统开发-1(数据列表)

    一.前言 首先声明的是,这是我第一个与别人合作的.net项目,另一个人做的是后台管理,我做的前台,这是一个电子商务的系统,主要实现的功能是查看商品以及购物功能. 二.开始 首先看一下我截取的项目部分商 ...

  10. ftp读取txt数据并插入数据库

    去官网下载http://enterprisedt.com/ .netftp组件 目前最新版本为2.2.3,下载后在bin目录中找到edtFTPnet.dll,在项目中添加引用. using Enter ...