Thrift 基础教程(二)编码篇

上接Thrift 基础教程(一)安装篇,今天来介绍下Thrift的编码过程,首先通过命令行生成框架代码。

命令格式如下:

thrift —gen language xxx.thrift

1、首先介绍下那个xxx.thrift文件,我们需要先创建myserver.thrift文件,这个接口主要定义服务接口和数据格式。

介绍一下thrift文件的语法格式,以我写的myserver.thrift说明。

/**
*  thrift中的数据类型
*  bool        布尔类型
*  byte        同java里的byte
*  i16         短整型,同short int
*  i32         整型,同int
*  i64         长整型,同long
*  double      64位浮点数
*  string      同java的string
*  binary      字节数组
*  map<t1,t2>  同java的hashmap泛型
*  list<t1>    同java的arraylist,存储的数据是已排序的
*  set<t1>     同java的hashset,存储不重覆的数据
*/

/*
*这里定义各语言的namespace
*/
namespace java com.lzf.thrift.demo1
namespace php Demo

/**
*定义服务,格式为 service 服务名{},这里也可以继承其它的thrift文件里的service,格式如下
* service 服务名 extends aaa.aaaservice{},需要在当前文件头部加上
* include "aaa.thrift"
* 这里定义一个简单的服务
*/

/*
*可以定义结构体,用于交换对象等数据
*/
struct User{
    1:string name,
    2:i32 age
}

service HelloServe{
    /*
    *在服务里面可以定义方法
    *格式:返回值 方法名(参数位置:参数类型 参数名)
    */
    i32 adduser(1:i32 age,2:string name),
    map<string,i32> getusers()
}

服务端

2、生成服务端java代码

thrift --gen java myserver.thrift  生成java代码。

为了方便测试和编译,我使用了idea创建了一个项目,正常流程一般使用ant或maven

创建完成后,把thrift-0.9.0/lib/java/build/libthrift-0.9.0.jar,thrift-0.9.0/lib/java/build/lib/*.jar拷备到你的工程里,并且要导入。

3、实现方法

我们在配置文件中定义了adduser和getusers两个方法,thrift帮我们生成了HelloServe.java,这里面有个接口,所以我们新建一个DemoHandler类,实现HelloServe.java里的Iface,代码如下:

package com.lzf.thrift.demo1;
import org.apache.thrift.TException;

import java.util.HashMap;

public class DemoHandler implements HelloServe.Iface{
    public DemoHandler(){}
    private static HashMap<String,Integer> users = new HashMap<>();

    public int adduser(int age, String name) throws TException{
        users.put(name,age);
        return 1001;
    }

    public HashMap<String,Integer> getusers(){
        return users;
    }
}

新建DemoServer类,主要用于建立服务,代码如下:

package com.lzf.thrift.demo1;

import org.apache.thrift.server.TServer;
import org.apache.thrift.server.TServer.Args;
import org.apache.thrift.server.TSimpleServer;
import org.apache.thrift.server.TThreadPoolServer;
import org.apache.thrift.transport.TSSLTransportFactory;
import org.apache.thrift.transport.TServerSocket;
import org.apache.thrift.transport.TServerTransport;
import org.apache.thrift.transport.TSSLTransportFactory.TSSLTransportParameters;

import java.lang.Exception;
import java.lang.Override;
import java.lang.Runnable;

public class DemoServer{
    public static DemoHandler handler;
    public static HelloServe.Processor processor;

    public static void main(String[] args){
        try{
            handler = new DemoHandler();
            processor = new HelloServe.Processor(handler);
            simple(processor);
        }catch (Exception x){
            x.printStackTrace();
        }
    }

    public static void simple(HelloServe.Processor processor) {
        try {
            TServerTransport serverTransport = new TServerSocket(9090);
            TServer server = new TSimpleServer(new Args(serverTransport).processor(processor));

            System.out.println("Starting the simple server...");
            server.serve();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

服务端代码编写完成。

客户端

1、生成php客户端代码

thrift --gen php myserver.thrift生成php框架代码,创建一个新项目把gen-php拷备到项目中,并把thrift-0.9.0/lib/php/lib/Thrift复制到你的项目中去,这是基础库。

2、创建客户端

在项目根目录新建index.php,代码如下:

<?php
/**
 * author: lzf
 * createTime: 15/8/3 22:13
 * description:
 */

require_once 'Thrift/ClassLoader/ThriftClassLoader.php';

use Thrift\ClassLoader\ThriftClassLoader;

$GEN_DIR = realpath(dirname(__FILE__)).'/gen-php';

$loader = new ThriftClassLoader();
$loader->registerNamespace('Thrift', __DIR__);
$loader->registerDefinition('Demo', $GEN_DIR);
$loader->register();

use Thrift\Protocol\TBinaryProtocol;
use Thrift\Transport\TSocket;
use Thrift\Transport\THttpClient;
use Thrift\Transport\TBufferedTransport;
use Thrift\Exception\TException;

try {

    $socket = new TSocket('localhost', 9090);
    $transport = new TBufferedTransport($socket, 1024, 1024);
    $protocol = new TBinaryProtocol($transport);
    $client = new \Demo\HelloServeClient($protocol);

    $transport->open();

    echo $client->adduser(23,"lzf");
    echo $client->adduser(23,"lzf001");
    echo $client->adduser(23,"lzf002");
    echo '执行了<br />';
    $userlist = $client->getusers();
    print_r($userlist);

    $transport->close();

} catch (TException $tx) {
    print 'TException: '.$tx->getMessage()."\n";
}

3、测试

运行Java服务端代码,从IDE里直接运行

然后访问index.php,结果如下

至此,Thrift基础教程介绍完了,如有问题欢迎批评指证:)

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-10-13 21:38:24

Thrift 基础教程(二)编码篇的相关文章

Thrift 基础教程(一)安装篇

1.Thrift简介 Thrift是一款由Fackbook开发的可伸缩.跨语言的服务开发框架,该框架已经开源并且加入的Apache项目.Thrift主要功能是:通过自定义的Interface Definition Language(IDL),可以创建基于RPC的客户端和服务端的服务代码.服务代码的生成是通过Thrift内置的代码生成器来实现的.Thrift 的跨语言性体现在,它可以生成C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#,

DataVeryLite入门教程(二) Entity篇

DataVeryLite 是基于.net 4.0的数据库持久化ORM框架. 目前支持的数据库有Sqlserver,Mysql,Oracle,Db2,PostgreSql,Sqlite和Access. 最好先阅读DataVeryLite入门教程(一) 配置篇,然后再阅读本篇.如果你觉得麻烦也可以跳过. Entity是ORM中的核心对象之一,一个继承Entity的对象对应于数据库中的一个表. Entity提供丰富的API对表中的单条数据进行操作. 比如根据id或其他条件,加载,删除,插入,更新和部分

HTML/CSS基础教程 二

表 表是十分有用的,用它存储表状的数据更易于阅读.当你想用行列来显示信息时---你猜到了,<table>标签正是你需要的,有许多和表有关的标签,它们都以<table>开始. 表就是将一组数据用行列的形式排列,我们用<tr>标签创建一个表行(table row),<td>标签表示表数据(table date) <!DOCTYPE html> <html> <head> <title>Table Time</

Daydream从入门到精通——快速入门开发基础教程二:Android端开发环境配置二

开始部署 上篇介绍了开发Daydream Android VR需要的基本环境,这篇我们来看看如何部署和运用官方示例. -------------------------------------------------------------------------------------------------------------------- Daydream快速入门开发基础教程一:Android端开发环境配置一 http://blog.csdn.net/jaikydota163/arti

SpringCloud 基础教程(二) 服务注册(Eureka Client)

1.创建[服务提供者],即 Eureka Client 1.1.新建 Spring Boot 工程,工程名称:springcloud-eureka-client 2.2.工程 pom.xml 文件添加如下依赖: <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependen

MongoDB基础教程系列--第二篇 MongoDB基本操作(一)

1.安装环境 在官网上下载MongoDB的最新版本,根据自身Windows版本下载正确的MongoDB版本.下载后,双击32位或者64位.msi文件,按操作提示安装就可以了. 说明: 32 位版本的 MongoDB 只支持 2G 以下的数据库,只适用于测试及评估. 在 MongoDB 2.2 版本后已经不再支持 Windows XP 系统.最新版本也已经没有了 32 位系统的安装文件. 创建数据目录 安装完MongoDB以后,我们需要创建数据目录.注意,数据目录应该放在根目录下(如: C:\ 或

JavaScript基础教程(二)

一.JavaScript语法 1.JavaScript语句:JavaScript语句向浏览器发出的命令.语句的作用是告诉浏览器该做什么. 2.分号:语句之间用分号分割.分号是可选项,可以不加.建议加上. 3.JavaScript代码:按照编写顺序依次执行. 4.标识符:JavaScript标识符必须以字母.下划线或美元符号开始.JS关键字不能使用(如document). 5.JS对大小写敏感. 6.加空格不影响执行. 7.代码换行:不要再代码的字母之间换行 8.保留字:使用的时候注意 <!DOC

MongoDB基础教程系列--第九篇 MongoDB 分片

1.分片介绍 分片(sharding)是将数据拆分,将其分散存到不同机器上的过程.MongoDB 支持自动分片,可以使数据库架构对应用程序不可见.对于应用程序来说,好像始终在使用一个单机的 MongoDB 服务器一样,另一方面,MongoDB 自动处理数据在分片上的分布,也更容易添加和删除分片. 请记住:复制是让多台服务器拥有同样的数据副本,每一台服务器都是其他服务器的镜像,而每一个分片都与其他分片拥有不同的数据子集. 通常,分片可以用来: 增加可用的内存 增加可用的磁盘空间 减轻单台服务器的负

Apache Shiro 快速入门教程,shiro 基础教程 (这篇文章非常好)

第一部分 什么是Apache Shiro     1.什么是 apache shiro :   Apache Shiro是一个功能强大且易于使用的Java安全框架,提供了认证,授权,加密,和会话管理 如同 Spring security 一样都是是一个权限安全框架,但是与Spring Security相比,在于他使用了和比较简洁易懂的认证和授权方式. 2.Apache Shiro 的三大核心组件:   1.Subject :当前用户的操作 2.SecurityManager:用于管理所有的Sub