‘壹’ thrift不是一种rpc框架吗,为什么看到有人也用它做序列化
Apache Thrift 跨语言服务框架,本质RPC;我发service需要放候,遇跨语言调用问题,java语言发UserService用提供获取用户信息服务,服务消费端php/python/C++等,我能所语言都适配相应调用式,候我奈使用Http作访问协议;服务消费端能使用HTTP,且更加倾向于 操作本API式 使用服务,我需要Thrift提供支持.
本文UserService例,描述使用thrift式,及其原理..
. service.thrift
struct User{
1:i64 id,
2:string name,
3:i64 timestamp,
4:bool vip
}
service UserService{
User getById(1:i64 id)
}
二. API文件
首先载安装thrift客户端,比windows平台,载thrift.exe,处需要提醒,同thrift客户端版本API能兼容.本例使用thrift-0.9.0.exe;通"--gen"指定API所适配语言.本实例java客户端API.
//windows平台,API文件输service目录(目录需要存)
> thrift.exe --gen java -o service service.thrift
三. UserService实现类
public class UserServiceImpl implements UserService.Iface {
@Override
public User getById(long id){
System.out.println("invoke...id:" + id);
return new User();//for test
}
}
四.原理简析
1. User.java : thriftAPI能力非限,比struct能使用简单数据类型(支持Date,Collection等),我能User看,类实现"Serializable"接口"TBase"接口.
其Serializable接口表明类实例需要序列化网络传输,干扰JAVA本身序列化反序列化机制,重写readObjectwriteObject.thrift本身并没帮助.
TBase接口thrift序列化反序列化使用,两核:readwrite.述thrift文件,struct定义每属性都序号,比:1:id,thrift序列化,根据序号顺序依属性"名称 + 值"写入inputStream,反序列化.(具体参见readwrite实现).
thrift序列化反序列化实例数据,根据"属性序号"进行,保证数据inputstreamoutputstream顺序严格.点要求API发者,更改thrift文件struct定义,需要重新客户端API,否则服务继续使用(能报错,能数据错误).thrift序列化/反序列化程JAVA自带序列化机制同,携带额外class结构,外thrift种序列化机制更加适合网络传输,且性能更加高效.
2. UserService.Client: UserService,Client静态类,类典型代理类,类已经实现UserService所.发者需要使用Client类API与Thrift server端交互,负责与Thrift serverSocket链接,发送请求接收响应.
‘贰’ thrift封装了一个java的服务,可以使用python的客户端访问吗
最近用Python做网页的抓取,因为想得到JS解释后的HTML,先后尝试了selenium,windmill,htmlunit等web测试框架,因为只要得到html不需要界面展现,最后选择了htmlunit,而htmlunit只有Java的实现,所以考虑用RPC来进行python与JAVA的连接
最开始试用了一下ICE,JAVA端无问题,在用python做client的时候,发现ICE现在还不支持python2.7,放弃,再来看看thrift!
‘叁’ 怎样写thrift接口 java
要编写Thrift定义文件,肯定要熟悉Thrift常见的数据类型:
1.基本类型(括号内为对应的Java类型):
bool(boolean): 布尔类型(TRUE or FALSE)
byte(byte): 8位带符号整数
i16(short): 16位带符号整数
i32(int): 32位带符号整数
i64(long): 64位带符号整数
double(double): 64位浮点数
string(String): 采用UTF-8编码的字符串
2.特殊类型(括号内为对应的Java类型):
binary(ByteBuffer):未经过编码的字节流
3.Structs(结构):
struct定义了一个很普通的OOP对象,但是没有继承特性。
struct UserProfile {
1: i32 uid,
2: string name,
3: string blurb
}
如果变量有默认值,可以直接写在定义文件里:
struct UserProfile {
1: i32 uid = 1,
2: string name = "User1",
3: string blurb
}
4.容器,除了上面提到的基本数据类型,Thrift还支持以下容器类型:
list(java.util.ArrayList):
set(java.util.HashSet):
map(java.util.HashMap):
用法如下:
struct Node {
1: i32 id,
2: string name,
3: list<i32> subNodeList,
4: map<i32,string> subNodeMap,
5: set<i32> subNodeSet
}
包含定义的其他Object:
struct SubNode {
1: i32 uid,
2: string name,
3: i32 pid
}
struct Node {
1: i32 uid,
2: string name,
3: list<subNode> subNodes
}
5.Services服务,也就是对外展现的接口:
service UserStorage {
void store(1: UserProfile user),
UserProfile retrieve(1: i32 uid)
然后实现这个接口就好了啊。
‘肆’ java thrift 检测是否有效
java 和 python 属于不同的进程,你这个是进程间通信。进程间通信的常见方法是通过网络,比如用 tcp 。 目前常见的跨语言 RPC 方案有 ZeroMQ protobuf 、Thrift 等。 如果你是新手,我只能说不同的语言之间是不能随便互相调用的。
‘伍’ thrift1.0支持异构容器吗,想用它定义Java的一个Object数组,不知道怎么实现啊
publicclassObjectArray{
publicstaticvoidmain(String[]args){
Object[]array=newObject[5];
Rectrect=newRect(3,4);//矩形
array[0]=rect;
Circlecircle=newCircle(7,3.14);//圆
array[1]=circle;
Doubled=newDouble(5.2);//双精度小数
array[2]=d;
Floatf=newFloat(5.2);//单精度小数
array[3]=f;
Integeri=newInteger(7);//整数
array[4]=i;
for(Objecto:array){
System.out.println(o);
}
}
}
classRect{
privatedoublelength;//长
privatedoublewidth;//宽
publicRect(){
super();
}
publicRect(doublelength,doublewidth){
super();
this.length=length;
this.width=width;
}
publicdoublegetLength(){
returnlength;
}
publicvoidsetLength(doublelength){
this.length=length;
}
publicdoublegetWidth(){
returnwidth;
}
publicvoidsetWidth(doublewidth){
this.width=width;
}
//计算面积
publicdoublegetArea(){
returnthis.length*this.width;
}
@Override
publicStringtoString(){
return"Rect[length="+length+",width="+width+"]";
}
}
classCircle{
privatedoubler;//半径
privatedoublepi;
publicdoublegetR(){
returnr;
}
publicvoidsetR(doubler){
this.r=r;
}
publicCircle(){
}
publicCircle(doubler){
this.r=r;
}
publicdoublegetPi(){
returnpi;
}
publicvoidsetPi(doublepi){
this.pi=pi;
}
publicCircle(doubler,doublepi){
this.r=r;
this.pi=pi;
}
//计算面积
publicdoublegetArea(){
returnpi*Math.pow(r,2);
}
//计算周长
publicdoublegetZhouChang(){
return2*pi*r;
}
@Override
publicStringtoString(){
return"Circle[r="+r+",pi="+pi+"]";
}
}
‘陆’ thrift java 只能在linux环境下安装吗
纯java开发的软件在linux下面也可以应用自如。那么首先就需要配置好linux下的java环境,具体说来,就是配置jdk环境变量。 介绍在linux下配置jdk环境变量的几种常用方法。 首先在linux下安装jdk,如果出现提示权限不够(且root下也提示权限不够),...
‘柒’ 找一下怎么根据thrift文件生成java需要使用的类
提供一种命令行的方式,利用axis——下载一个axis,假设2-1.5版本,解压运行cmd,进入axis的bin目录,执行如下命令:axis2-1.5\bin>wsdl2java.bat-uriD:\wsdl.xml-oD:\output-pcom.bd.zd-uri:wsdl文件-o:Java文件输出路径-p:生成的Java文件包名
‘捌’ thrift异步客户端怎么结束调用
首先创建thrift文件
namespace Java thriftservice Hello{ string helloString(1:string para)}
执行thrift -gen Java test.thrift会生成一个Hello.java文件
将Hello.java文件拷贝至IDE
server端代码:
[java] view plain
[java] view plain
package com.thrift.test.thrift;
import org.apache.thrift.TProcessorFactory;
import org.apache.thrift.protocol.TCompactProtocol;
import org.apache.thrift.server.THsHaServer;
import org.apache.thrift.server.TServer;
import org.apache.thrift.transport.TFramedTransport;
import org.apache.thrift.transport.TNonblockingServerSocket
‘玖’ thrift c++ 服务端的异步怎么实现
仰望明天
thrift服务端的c++语言实现
1.thrift 概念1
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客户端和服务器通信的无缝跨编程语言。
2.生成c++语言的thrift服务端
利用thrift软件框架进行开发要首先进行环境的搭建,安装thrift运行库。
基本流程如下:
1)定义数据类型和服务接口文件:test.thrift;
2)利用代码生成引擎生成服务端框架,thrift --gen cpp test.thrift;
3)在./gen-cpp/test_server.skeleton.cpp文件中添加定制的服务;
4)编写客户端程序向服务端请求服务。
详细过程可以参加注释2给出的链接地址。
thrift定义了自己的数据类型,从而实现了跨语言平台之间的数据交换,关于thrift数据类型的详细说明可以参加注释3给出的链接地址。
3.php客户端
基于c++语言实现的thrift服务端程序经常被用在网站的后台提供实时且高效的服务,通常客户端程序是php语言的实现版本。只要根据数据类型和服务接口文件test.thrift生成php语言的接口文件即可用来调用。方法是thrift --gen php test.thrift,调用该命令后会在工作目录下生成./gen-php目录,里面有php语言的接口文件。
注释: