Apache Thrift入门(安装、测试与java程序编写)
安装Apache Thrift
ubuntu linux运行:
- #!/bin/bash
- #下载
- wget http://mirrors.cnnic.cn/apache/thrift/0.9.1/thrift-0.9.1.tar.gz
- tar zxvf thrift-0.9.1.tar.gz
- cd thrift-0.9.1.tar.gz
- ./configure
- make
- make install
- #编译java依赖包
- cd lib/java
- ant
安装ubuntu依赖
sudo apt-get install libboost-dev libboost-test-dev libboost-program-options-dev libevent-dev automake libtool flex bison pkg-config g++ libssl-dev
编写thrift文件hello.thrift
- namespace java com.micmiu.thrift.demo
- service HelloWorldService {
- string sayHello(1:string username)
- }
运行
thrift -gen java hello.thrift
将在同级目录下生成gen-java/com/micmiu/thrift/demo/HelloWorldService.java文件
编写测试程序
使用maven构建
pom.xml文件
- <?xml version="1.0" encoding="UTF-8"?>
- <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
- <modelVersion>4.0.0</modelVersion>
- <groupId>com.micmiu.thrift.demo</groupId>
- <artifactId>thrift-test</artifactId>
- <version>0.1.0-SNAPSHOT</version>
- <dependencies>
- <strong> <dependency>
- <groupId>org.apache.thrift</groupId>
- <artifactId>libthrift</artifactId>
- <version>0.9.1</version>
- </dependency></strong>
- <dependency>
- <groupId>org.slf4j</groupId>
- <artifactId>slf4j-log4j12</artifactId>
- <version>1.5.8</version>
- </dependency>
- </dependencies>
- <build>
- <plugins>
- <plugin>
- <artifactId>maven-assembly-plugin</artifactId>
- <version>2.2-beta-5</version>
- <configuration>
- <descriptorRefs>
- <descriptorRef>jar-with-dependencies</descriptorRef>
- </descriptorRefs>
- </configuration>
- </plugin>
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-compiler-plugin</artifactId>
- <version>2.3.2</version>
- <configuration>
- <source>1.6</source>
- <target>1.6</target>
- <encoding>UTF-8</encoding>
- </configuration>
- </plugin>
- </plugins>
- </build>
- </project>
以下代码来自:http://www.micmiu.com/soa/rpc/thrift-sample/
HelloClientDemo.java
- package com.micmiu.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;
- /**
- * blog http://www.micmiu.com
- *
- * @author Michael
- *
- */
- public class HelloClientDemo {
- public static final String SERVER_IP = "localhost";
- public static final int SERVER_PORT = 8090;
- public static final int TIMEOUT = 30000;
- /**
- *
- * @param userName
- */
- 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();
- }
- }
- }
- /**
- * @param args
- */
- public static void main(String[] args) {
- HelloClientDemo client = new HelloClientDemo();
- client.startClient("Michael");
- }
- }
HelloServerDemo.java
- package com.micmiu.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;
- /**
- * blog http://www.micmiu.com
- *
- * @author Michael
- *
- */
- public class HelloServerDemo {
- 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();
- }
- }
- /**
- * @param args
- */
- public static void main(String[] args) {
- HelloServerDemo server = new HelloServerDemo();
- server.startServer();
- }
- }
maven工程的src/main/java/com/micmiu/thrift/demo文件夹下有4个文件:
HelloClientDemo.java
HelloServerDemo.java
HelloWorldImpl.java
HelloWorldService.java
其中HelloWorldService.java文件是用上文的thrift命令生成的。
执行测试程序
使用maven编译
mvn package assembly:assembly
运行
在target目录下,运行时需要指定main class
java -cp thrift-test-0.1.0-SNAPSHOT-jar-with-dependencies.jar com.micmiu.thrift.demo.HelloServerDemo
java -cp thrift-test-0.1.0-SNAPSHOT-jar-with-dependencies.jar com.micmiu.thrift.demo.HelloClientDemo
Apache Thrift入门(安装、测试与java程序编写)的更多相关文章
- apache thrift 入门(一)
1.简介 Apache Thrift软件框架,是用来开发可扩展的跨语言的软件服务.通过软件堆栈和代码生成引擎相结合的方式来构建服务,使C++, Java, Python, PHP, Ruby, Erl ...
- JAVA程序编写入门
在任意文件夹下创建一个文本,然后重命名,把文本后缀名改为.java.然后用eclipse打开此文件编写程序内容. public class nihao{ public static void main ...
- centos下apache thrift的安装
参考:http://running.iteye.com/blog/1983463 thrift-0.9.0安装 最好切换到root用户操作,避免不必要的麻烦. 进行例子程序tutorial目录下,通 ...
- Lucene入门-安装和运行Demo程序
Lucene版本:7.1 一.下载安装包 https://lucene.apache.org/core/downloads.html 二.安装 把4个必备jar包和路径添加到CLASSPATH \lu ...
- apache ab工具安装测试
1.安装 安装包下载地址: 将 httpd-2.2.29.tar.gz 解压到目录 /apps/install/httpd-2.2.29 ,这是我放置的位置 cd /apps/install/http ...
- Docker入门-构建第一个Java程序
定制镜像 准备一个没有第三方依赖的java web项目,可能参考示例maven结构项目: session-web.war 把该war上传到安装有docker软件的服务器上宿主目录下.在同级目录创建Do ...
- java 程序编写规则(自己总结)
1.命名规范 (1)所有的标示符都只能用ASCⅡ字母(A-Z或a-z).数字(0-9)和下划线"_". (2)类名是一个名词,采用大小写混合的方式,每个单词的首字母大写.例如:Us ...
- java程序编写需注意的问题
初学java,免不了很多注意事项 加分号 类名与文件名一致 javac fileName而非javac fileName.class ```java System.out.println(" ...
- 阶段5 3.微服务项目【学成在线】_day04 页面静态化_21-页面静态化-静态化测试-静态化程序编写
public String getPageHtml(String pageId){ /** * 静态化程序获取页面的DataUrl * * 静态化程序远程请求DataUrl获取数据模型 * * 静态化 ...
随机推荐
- Python 自动化脚本学习(二)
流程控制 布尔值 temp = True temp = False 比较符号 == != < <= > >= 与或非 and or not 混合布尔的比较 (4<5)an ...
- 关于map与set的一点理解;
set代码: #include<stdio.h> #include<set> using namespace std; int main(){ set<int>m; ...
- JavaScript 运行机制详解:深入理解Event Loop
Philip Roberts的演讲<Help, I'm stuck in an event-loop>,详细.完整.正确地描述JavaScript引擎的内部运行机制. 一.为什么JavaS ...
- Git(一):Git与版本号控制简单介绍
Intro 版本号控制系统是什么 版本号控制系统(Version Control System,VCS)能够帮助我们记录和跟踪项目中各文件内容的改动变化.它能够帮我们保存项目的各个版本号.以 ...
- LINQ 基本子句之二 join
Join子句据说可以实现3中连接关系. 1.内部连接——元素的连接关系必须同时满足被连接的两个数据源 2.分组连接 3.左外连接 1.最基本的,内部连接,类似于sql中inner join. 由于st ...
- ThinkPHP使用Memcached缓存数据
ThinkPHP默认使用文件缓存数据,支持Memcache等其他缓存方式,有两个PHP扩展:Memcache和Memcached,Memcahe官方有说明,主要说一下Memcached. 相对于PHP ...
- Sql语句之查询所有学生所有科目分数及总分
昨天练Sql语句,数据库建了四个表分别是,学生表,课程表,成绩表以及教师表(教师表不在讨论范围),突然想到以前高中时代老师手上的那张成绩表,然后我就寻思着能不能用Sql语句把表打印出来,以下是我的思考 ...
- iOS学习笔记-死锁deadlock理解
1.首先看一下官方文档的解释,这个block的队列是同步执行的,不像异步,这个方法直到block执行完毕才会返回 2.主线程一旦开启,就要先把自己的代码执行完成之后,才去执行加入到主队列中的任务 De ...
- css模板之 web模板一
效果 <html><head><style type="text/css">div.container{width:100%;margin:0p ...
- 解决Deprecated: mysql_connect(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead
因为最近更新的PHP版本,写sql语句,忽然发现不能用了,上网查了一些原因,找到几个方法如下: 1.禁止php报错 display_errors = on 改成 display_errors = of ...