Thrift之java实例
一、java实例
1.下载与安装thrift工具
http://thrift.apache.org/download/
服务Test实现类
package com.zychen.thrift; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import org.apache.thrift.TException; public class TestImpl implements Test.Iface { public void Init(){ int n = 0; for(n=0; n<10; n++){ User user = new User(); user.setId(n+1); user.setName(String.format("name_%d", n+1)); user.setAge(18+n+1); user.setVip(true); listUser.add(user); } } @Override public int add(int a, int b) throws TException { return a+b; } @Override public User getById(long id) throws TException { User userObj = null; Iterator<User> iter = listUser.iterator(); while(iter.hasNext()){ userObj = iter.next(); if(userObj.getId() == id){ return userObj; } } return null; } //插入用户信息 void InsertUser(User user){ listUser.add(user); } protected List<User> listUser = new ArrayList<User>(); }
//服务端代码
package com.zychen.test; import org.apache.thrift.protocol.TBinaryProtocol; import org.apache.thrift.protocol.TBinaryProtocol.Factory; 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.server.TThreadPoolServer.Args; import org.apache.thrift.transport.TFramedTransport; import org.apache.thrift.transport.TNonblockingServerSocket; import org.apache.thrift.transport.TServerSocket; import org.apache.thrift.transport.TTransportException; import com.zychen.thrift.Test; import com.zychen.thrift.Test.Processor; import com.zychen.thrift.TestImpl; public class Server { //阻塞式IO public void startOIOServer() { try { TServerSocket serverTransport = new TServerSocket(1234); TestImpl testImpl = new TestImpl(); testImpl.Init(); Test.Processor process = new Processor(testImpl); Factory portFactory = new TBinaryProtocol.Factory(true, true); Args args = new Args(serverTransport); args.processor(process); args.protocolFactory(portFactory); TServer server = new TThreadPoolServer(args); System.out.println("init..."); server.serve(); } catch (TTransportException e) { e.printStackTrace(); } } //使用非阻塞式IO,服务端和客户端需要指定TFramedTransport数据传输的方式。 public void startNIOServer() { try { TestImpl testImpl = new TestImpl(); testImpl.Init(); Test.Processor tprocessor = new Processor(testImpl); TNonblockingServerSocket tnbServerTransport = new TNonblockingServerSocket(1234); TNonblockingServer.Args tArgs = new TNonblockingServer.Args(tnbServerTransport); tArgs.processor(tprocessor); tArgs.transportFactory(new TFramedTransport.Factory()); tArgs.protocolFactory(new TCompactProtocol.Factory()); TServer server = new TNonblockingServer(tArgs); System.out.println("init..."); server.serve(); }catch(TTransportException e) { e.printStackTrace(); } } /** * @param args */ public static void main(String[] args) { Server server = new Server(); //server.startOIOServer(); server.startNIOServer(); } }
依赖jar包
5、客户端代码
package com.zychen.test; import org.apache.thrift.TApplicationException; 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.TFramedTransport; import org.apache.thrift.transport.TSocket; import org.apache.thrift.transport.TTransport; import org.apache.thrift.transport.TTransportException; import com.zychen.thrift.Test; import com.zychen.thrift.User; public class Client { //阻塞io public void startOIOClient() { TTransport transport; try { transport = new TSocket("localhost", 1234); TProtocol protocol = new TBinaryProtocol(transport); Test.Client client = new Test.Client(protocol); transport.open(); int nResult = client.add(100, 200); String strTemp = String.format("client.add(100, 200) = %d", nResult); System.out.println(strTemp); User u1 = client.getById(1); if(u1 != null){ System.out.println(u1.getName()); } User u2 = client.getById(11); if(u2 == null){ System.out.println("null"); } u2 = client.getById(9); transport.close(); } catch (TTransportException e) { e.printStackTrace(); } catch (TException e) { if(e instanceof TApplicationException && ((TApplicationException) e).getType() == TApplicationException.MISSING_RESULT){ System.out.println("Theresult of Method function is NULL"); }else{ e.printStackTrace(); } } } //非阻塞io public void startNIOClient() { TTransport transport; try { transport = new TFramedTransport(new TSocket("localhost", 1234,30000)); TProtocol protocol = new TCompactProtocol(transport); Test.Client client = new Test.Client(protocol); transport.open(); int nResult = client.add(100, 200); String strTemp = String.format("client.add(100, 200) = %d", nResult); System.out.println(strTemp); User u1 = client.getById(1); if(u1 != null){ System.out.println(u1.getName()); } User u2 = client.getById(11); if(u2 == null){ System.out.println("null"); } u2 = client.getById(9); transport.close(); } catch (TTransportException e) { e.printStackTrace(); } catch (TException e) { if(e instanceof TApplicationException && ((TApplicationException) e).getType() == TApplicationException.MISSING_RESULT){ System.out.println("Theresult of Method function is NULL"); }else{ e.printStackTrace(); } } } /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub Client client = new Client(); //client.startOIOClient(); client.startNIOClient(); } }
依赖jar包
二、Thrift-0.9.3 jar包编译生成。
1、myeclipse新建一个java工程。
2、打开thrift目录,查找到thrift-0.9.3\thrift-0.9.3\lib\java\src,将这个src目录下的代码拷贝到工程目录下。
3、引入httpClient、httpcore、javax.servlet、slf4j.api jar包。如图:
4、编译,导出thrift-0.9.3jar包,导出时选择Exportall output folders for checked projects,否则scheme类无法导出到jar包中。
Thrift之java实例的更多相关文章
- Thrift-java实例
➠更多技术干货请戳:听云博客 Thrift实例1 功能描述:客户端与服务器端分别是两个应用,先启动服务器端,再启动客户端,实现执行客户端运行服务器端的加法方法. 源码截图(源码在附件中): 客户端: ...
- Thrift入门及Java实例演示<转载备用>
Thrift入门及Java实例演示 作者: Michael 日期: 年 月 日 •概述 •下载配置 •基本概念 .数据类型 .服务端编码基本步骤 .客户端编码基本步骤 .数据传输协议 •实例演示(ja ...
- Apache Thrift学习之一(入门及Java实例演示)
目录: 概述 下载配置 基本概念 数据类型 服务端编码基本步骤 客户端编码基本步骤 数据传输协议 实例演示(java) thrift生成代码 实现接口Iface TSimpleServer服务模型 T ...
- Apache Thrift with Java Quickstart(thrift入门及Java实例)
thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Python, PHP, Ruby, Erlang, Perl ...
- Protocol Buffer技术详解(Java实例)
Protocol Buffer技术详解(Java实例) 该篇Blog和上一篇(C++实例)基本相同,只是面向于我们团队中的Java工程师,毕竟我们项目的前端部分是基于Android开发的,而且我们研发 ...
- 吐槽net下没有靠谱的FastDFS的sdk之使用thrift实现JAVA和C#互通
事情是这样的,在一个新项目中引入了fastdfs,用这玩意做一些小数据的存储还是很方便的,然后在nuget上就找一个对接FastDFS的sdk,如下图: 一眼就看到了这个top1的sdk,应该会比较靠 ...
- JAVA实例
JAVA实例1 1 package Demo3; import java.io.File; import java.io.FileReader; import java.io.IOExceptio ...
- Java 实例 - 如何执行指定class文件目录(classpath) Java 实例 J
Java 实例 - 如何执行指定class文件目录(classpath) Java 实例 如果我们 Java 编译后的class文件不在当前目录,我们可以使用 -classpath 来指定class ...
- Java-Runoob-高级教程-实例-方法:15. Java 实例 – 重载(overloading)方法中使用 Varargs
ylbtech-Java-Runoob-高级教程-实例-方法:15. Java 实例 – 重载(overloading)方法中使用 Varargs 1.返回顶部 1. Java 实例 - 重载(ove ...
随机推荐
- c++中的构造函数初始化列表
三种情况下,必须在构造函数初始化列表中初始化成员: 1.const成员 2.引用成员 3.没有默认构造函数的成员
- .net:上传图片并将保存至指定目录下(支持PC端和移动端)
页面: <body> <form id="formid" name="myform" action="Upload" me ...
- 对象序列化与反序列化local class incompatible
无论eclipse还是idea(默认关闭序列化提示,需手动打开),都可以自动生成相应的序列号,分为两类1L,XXXL. 当然如果不指定,系统也会自动生成,但是存在隐性风险 ,不同的编译器对同一个对象可 ...
- EOJ - 3631 Delivery Service 2018.8华师大月赛(树链剖分+贪心)
链接:https://acm.ecnu.edu.cn/contest/103/problem/D/ 题意:给你一棵无向边连接的树,边的权值可以任意互换.有m次运输,每次的花费是点u到v路径上边的权值和 ...
- 自动化测试调查问卷送《QTP自动化测试最佳实践》
自动化测试调查问卷送<QTP自动化测试最佳实践> http://automationqa.com/forum.php?mod=viewthread&tid=2308&fro ...
- PHP memcache扩展模块安装
安装php扩展模块memcache memcache 的工作就是在专门的机器的内存里维护一张巨大的hash表,来存储经常被读写的一些数组与文件,从而极大的提高网站的运行效率,减轻后端数据库的读写压力. ...
- Linux 下的 core dump
core dump 的基本概念 当一个进程要异常终止时 ,可以选择把进程的用户空间内存数据全部保存到磁盘上 ,文件名通常是 core, 这叫做 Core Dump.通常情况下,core文件会 ...
- 20162326 《Java程序设计》第3周学习总结
20162326 <Java程序设计>第3周学习总结 教材学习内容总结 这周我通过课堂学习了VIM的列编辑crtl+v,shift+i shift+a·分别是左侧插入和右侧插入.还学习了使 ...
- 完全理解Android中的RemoteViews
一.什么是RemoteViews RemoteViews翻译过来就是远程视图.顾名思义,RemoteViews不是当前进程的View,是属于SystemServer进程.应用程序与RemoteView ...
- Jar 包 及运行Jar包 - 转载
Eclipse的jar file和Runnable JAR file的区别 - 及bat运行Runnable JAR文件 1.两种jar的区别 jar file是最普通的jar包,即平时我们工程中li ...