RPC框架Thrift例子-PHP调用C++后端程序

更新

  • 2016-02-22: Response对象不用主动创建。

前言

前段时间用了一下Facebook的开源RPC框架Thrift,做PHP客户端调用C++后端程序,真心觉得Thrift不错!

本文项目地址:https://github.com/zekunyan/ThriftDemo_PHP_CPP

先看看本文的例子示意图:

流程

  1. PHP客户端发起请求,请求参数是“Request”类型,里面有studentID参数。
  2. CPP服务端收到请求返回数据,返回类型为“Response”,里面包含了student的信息,此处只是简单的示例。

定义

什么是RPC

远程过程调用(英语:Remote Procedure Call,缩写为 RPC)是一个计算机通信协议。该协议允许运行于一台计算机的程序调用另一台计算机的子程序,而程序员无需额外地为这个交互作用编程。 – 维基百科 - 远程过程调用

通俗点讲,就是跨计算机、跨网络调用。

什么是Thrift

Apache Thrift 是Facebook实现的一种高效的、支持多种编程语言的远程服务调用(RPC)的框架。它采用接口描述语言定义并创建服务,支持可扩展的跨语言服务开发,所包含的代码生成引擎可以在多种语言中,如 C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, Smalltalk 等创建高效的、无缝的服务,其传输数据采用二进制格式,相对 XML 和 JSON 体积更小,对于高并发、大数据量和多语言的环境更有优势。 – Apache Thrift - 可伸缩的跨语言服务开发框架

开发流程

  1. 配置环境。C++的如CMake、make、g++;PHP的如php、php-fpm、Apache(Nginx)。
  2. 根据需求,编写thrift接口定义文件(IDL定义文件)。
  3. 使用thrift程序,为不同的语言生成代码。
  4. 根据需求,修改生成的代码(主要是Server端),编写实际的业务逻辑。
  5. 编译、部署。

Thrift的接口定义文件

在利用Thrift开发的过程中,重点就是编写接口定义文件。
一般来说,接口定义文件决定了RPC过程中的通信数据结构、通信接口定义等。

总的来说,thrift的接口定义语法类似于C语言,包含了struct、enum、map、list等基础数据结构,同时支持大部分基本数据类型,如32位整型“i32”等。

详细的接口定义请参考:

看看本例子中的定义文件“TTG.thrift”:

  1. namespace cpp TTG
    namespace php TTG
    
    enum ResponseState {
        StateOk = 0,
        StateError = 1,
        StateEmpty = 2
    }
    
    struct Request {
        1: i32 studentID = 0
    }
    
    struct Response {
        1: i32 studentID = 0,
        2: string name,
        3: list<string> infos,
        4: ResponseState state
    }
    
    service TTGService {
        Response getStudentInfo(1: Request request);
    }

    生成对应语言的代码!先定义命名空间,尽量减少命名冲突。

  2. Request类型:PHP客户端请求的数据类型。
  3. Response类型:CPP服务端返回的数据类型。
  4. ResponseState枚举:定义返回的状态。
  5. TTGService:服务接口定义。

是的,生成代码!这是我觉得Thrift框架最“神奇”的地方。我们只需要执行几条命令,就可以根据接口定义文件“生成”对应语言的代码。然后我们只需要将对应的业务逻辑加入到生成的代码中即可。

如生成CPP服务端的代码:

thrift --gen cpp TTG.thrift

然后就会生成如下代码。

TTGService.cpp
TTGService.h
TTGService_server.skeleton.cpp
TTG_constants.cpp
TTG_constants.h
TTG_types.cpp
TTG_types.h

生成CPP、PHP端的代码以后,我们就可以根据需要修改、添加业务代码。根据需要修改生成的代码

CPP服务端

在生成CPP的代码时,会生成一个“TTGService_server.skeleton.cpp”文件,这个就是我们的CPP服务端的代码“架子”。其中重点如下:

//实现调用的接口
class TTGServiceHandler : virtual public TTGServiceIf {
public:
TTGServiceHandler() {
    // Your initialization goes here
}

//接口实现部分,实现getStudentInfo这个接口的具体细节,如根据request创建、返回对应的response
void getStudentInfo(Response& _return, const Request& request) {
    // Your implementation goes here
    printf("getStudentInfo\n");
}

};
//...

我们将其改成:

void getStudentInfo(Response &_return, const Request &request) {
    // 输出请求参数
    cout<<"Request: "<<request.studentID<<endl;

    //填充数据,Response对象不用主动创建,进入函数时已经创建好了
    _return.studentID = request.studentID;
    _return.name = "tutuge";
    _return.infos.push_back("Info 1");
    _return.infos.push_back("Info 2");
    _return.state = ResponseState::StateOk;
}

PHP客户端至此,CPP服务端的编写就完成了,接下来我们只需要编译、链接,执行最终生成的可执行文件即可。

PHP客户端的编写比较简单,直接参考代码吧:https://github.com/zekunyan/ThriftDemo_PHP_CPP/blob/master/PHP/client.php

编译、链接,运行

用CMake,或者直接编写makefile均可,保证Thrift装好就行了。

直接运行最后生成的可执行文件TTG.run即可。

从浏览器,或者直接运行client.php,即可看到如下输出:

object(TTG\Response)[9]
  public ‘studentID‘ => int 100
  public ‘name‘ => string ‘tutuge‘ (length=6)
  public ‘infos‘ =>
    array (size=2)
      0 => string ‘Info 1‘ (length=6)
      1 => string ‘Info 2‘ (length=6)
  public ‘state‘ => int 0

Thrift是个好东西!就是文档好少=。=总结

参考

http://tutuge.me/2015/04/19/thrift-example-cpp-and-php/?utm_source=tuicool&utm_medium=referral

时间: 2024-10-10 02:08:07

RPC框架Thrift例子-PHP调用C++后端程序的相关文章

.Net RPC框架Thrift的用法

  关于Thrift 下面是来自百度百科关于Thrift的介绍: thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和引擎,以构建在 C++, Java, Go,Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, JavaScript, Node.js, Smalltalk, and OCaml 这些编程语言间无缝结合的.高效的服务. Apache开源地址:http://thrift.apache.or

飞鸽RPC框架(java远程服务调用)使用介绍

飞鸽RPC是一个非常轻量级,且容易修改整合到实际项目中的远程调用框架,基于NIO框架netty开发,轻松支持高并发,支持服务负载均衡,无缝整合spring 一.provider配置 服务器配置 feige.properties 放在classpath下 #服务绑定的ip,可选 feige.host=127.0.0.1 #服务端口 feige.port=10221 #服务调用时处理线程池线程数量 feige.poolsize=50 feige.host=127.0.0.1 #协议以及对象序列化配置

RPC框架 - thrift 服务端

-------服务端程序 ------ 下载    下载 thrift 源代码包    下载 thrift 的bin包 准备描述文件(使用源代码包的示例文件)    \thrift-0.10.0\tutorial\shared.thrift    \thrift-0.10.0\tutorial\tutorial.thrift 根据描述文件生成代码    thrift-0.10.0.exe -r -o lib_server --gen php:server idl-dir/tutorial.thr

RPC框架 - thrift 客户端

-------客户端程序 ------ 下载    下载 thrift 源代码包    下载 thrift 的bin包 准备描述文件(使用源代码包的示例文件)    \thrift-0.10.0\tutorial\shared.thrift    \thrift-0.10.0\tutorial\tutorial.thrift 根据描述文件生成代码    thrift-0.10.0.exe -r -o lib_client --gen php idl-dir/tutorial.thrift 从th

RPC框架研究(二)Hadoop源代码-1

报名了阿里中间件性能大赛,我来说是一个全新的挑战.一切从空白学起,比赛的过程也是学习的过程 是的.想让自己学好.给自己报一个比赛吧~ 就像当初学围棋,也是报了围棋比赛,为了不至于输的太慘.一个星期里学了好多东西 第二天 Hadoop源代码-1 小雨 天真的以为学了Java回调机制后就能够把原来的RPC框架改为异步调用了,结果对着代码一下午都没想出要怎么去改,怎么入手. 于是决定研究一下Hadoop的源代码,看看别人是怎么实现RPC的,这也是我第一次研究源代码,曾经都是仅仅管用.无论怎样实现. 使

Apache thrift - 使用,内部实现及构建一个可扩展的RPC框架

本文首先介绍了什么是Apache Thrift,接着介绍了Thrift的安装部署及如何利用Thrift来实现一个简单的RPC应用,并简单的探究了一下Thrift的内部实现原理,最后给出一个基于Thrift的可扩展的分布式RPC调用框架,在中小型项目中是一个常见的SOA实践. Thrift介绍 Apache Thrift是Facebook 开发的远程服务调用框架,它采用接口描述语言(IDL)定义并创建服务,支持可扩展的跨语言服务开发,所包含的代码生成引擎可以在多种语言中,如 C++, Java,

RPC框架实践之:Apache Thrift

一.概述 RPC(Remote Procedure Call)即 远程过程调用,说的这么抽象,其实简化理解就是一个节点如何请求另一节点所提供的服务.在文章 微服务调用链追踪中心搭建 一文中模拟出来的调用链:ServiceA ---> ServiceB ---> ServiceC 就是一个远程调用的例子,只不过这篇文章里是通过RestTemplate这种 同步调用方式,利用的是HTTP协议在应用层完成的,这种方法虽然奏效,但有时效率并不高.而RPC可以不依赖于应用层协议,可以直接基于TCP进行远

微博轻量级RPC框架Motan正式开源:支撑千亿调用

支撑微博千亿调用的轻量级 RPC 框架 Motan 正式开源了,项目地址为https://github.com/weibocom/motan. 微博轻量级RPC框架Motan正式开源 Motan 是微博技术团队研发的基于 Java 的轻量级 RPC 框架,已在微博内部大规模应用多年,每天稳定支撑微博上亿次的内部调用.Motan 基于微博的高并发和高负载场景优化,成为一套简单.易用.高可用的 RPC 服务框架. Motan 功能特点:简单.易用.高可用 无侵入集成.简单易用,通过 Spring 配

rpc框架之 thrift连接池实现

接前一篇rpc框架之HA/负载均衡构架设计 继续,写了一个简单的thrift 连接池: 先做点准备工作: package yjmyzz; public class ServerInfo { public String getHost() { return host; } public void setHost(String host) { this.host = host; } public int getPort() { return port; } public void setPort(i