因为工作需要使用gRPC,本人使用的是windows10,不过linux的操作流程基本一样。

直接进入主题,分为了几部分

1、下载Protoc

下载地址:https://github.com/google/protobuf/releases

这里采用的二进制文件,选择对应的平台,下载
https://github.com/protocolbuffers/protobuf/releases/download/v3.7.1/protoc-3.7.1-win64.zip

解压后得到,在bin文件夹下的 protoc.exe。我放到 D:\Program Files\protoc-3.7.1-win64\bin 下,并加入到系统环境变量 Path 中,就可以使用 protoc 命令了,可以用 protoc --version 来查看是否成功。(这一步很重要用于生成 protobuf 文件对应的 PHP代码 用的)

2、编写 protocol buffers 文件

如何编写请看 Protobuf3语言指南 写得不错,首先创建一个为 testgrpc_com 项目,我这的位置是 E:\www\testgrpc_com ,在项目下简单写了一个 xuexitest.proto

syntax = "proto3";  // 指定proto版本package xuexitest; // 指定包名//定义 Xuexitest 服务
service Xuexitest {//定义 SayTest 方法rpc SayTest(TestRequest) returns (TestReply) {}
}//TestRequest 请求结构
message TestRequest {int64 typeid = 1;
}//TestReply 响应结构
message TestReply {//返回数据类型message GetData {int64 id = 1;string name = 2;}repeated GetData getdataarr = 1;
}

3、下载 PHP的gRPC扩展和protobuf扩展

PHP的gRPC扩展:http://pecl.php.net/package/gRPC

PHP的protobuf扩展: http://pecl.php.net/package/protobuf

注:1、PHP的protobuf扩展没有windows版本的,但不影响使用无非就是运行速度慢点。(使用 composer 加载 protobuf 类库,请看下面的 composer.json 配置文件)

注:2、如何安装PHP扩展,这里就不讲了。

4、编译 protocol buffers 文件

编译 xuexitest.proto 使用 protoc --php_out=. xuexitest.proto 会生成得到:

5、使用 PHP 的 composer

首先 安装 composer 来管理和加载PHP的类库,如何安装这里就不讲了。(这一步也很重要用于解决 Grpc和 protobuf 的PHP类库依赖)

在项目下编写 composer.json 放到刚刚编译 protocol buffers 文件同级下

{"name": "grpc-go-php","require": {"grpc/grpc": "^v1.3.0","google/protobuf": "^v3.3.0"},"autoload":{"psr-4":{"GPBMetadata\\":"GPBMetadata/","Xuexitest\\":"Xuexitest/"}}
}

6、使用 Composer 下载 PHP 代码

1.进入到项目的目录,如:E:\www\testgrpc_com 中在地址栏输入cmd回车即可

2.在命令提示符(黑窗口)下输入 composer install 回车,等待下载完成。

7、定义PHP的gRPC端户端

在项目的 Xuexitest 文件夹中,新建 XuexitestClient.php 文件

<?php
namespace Xuexitest;/*** service Xuexitest{}* 编写 (gprc 定义 Xuexitest 服务)的客户端*/
class XuexitestClient extends \Grpc\BaseStub{public function __construct($hostname, $opts, $channel = null) {parent::__construct($hostname, $opts, $channel);}/*** rpc SayTest(TestRequest) returns (TestReply) {}* 方法名尽量和 (gprc 定义 Xuexitest 服务)的方法一样* 用于请求和响应该服务*/public function SayTest(\Xuexitest\TestRequest $argument,$metadata=[],$options=[]){// (/xuexitest.Xuexitest/SayTest) 是请求服务端那个服务和方法,基本和 proto 文件定义一样// (\Xuexitest\TestReply) 是响应信息(那个类),基本和 proto 文件定义一样return $this->_simpleRequest('/xuexitest.Xuexitest/SayTest',$argument,['\Xuexitest\TestReply', 'decode'],$metadata, $options);}}

8、编写PHP执行文件

在项目下 新建 xuexitest.php

?php
//引入 composer 的自动载加
require __DIR__ . '/vendor/autoload.php';//用于连接 服务端
$client = new \Xuexitest\XuexitestClient('127.0.0.1:50052', ['credentials' => Grpc\ChannelCredentials::createInsecure()
]);//实例化 TestRequest 请求类
$request = new \Xuexitest\TestRequest();
$request->setTypeid(1);//调用远程服务
$get = $client->SayTest($request)->wait();//返回数组
//$reply 是 TestReply 对象
//$status 是数组
list($reply, $status) = $get;//数组
$getdata = $reply->getGetdataarr();foreach ($getdata as $k=>$v){echo $v->getId(),'=>',$v->getName(),"\n\r";
}

9、赶快执行下

这是源代码:https://github.com/laixhe/php_grpc

PHP中使用gRPC客户端相关推荐

  1. go语言入门经典_Go 语言中的 gRPC 基础入门

    01 为什么使用 gRPC? 借助 gRPC,我们可以在 .proto 文件中一次定义我们的服务,并以 gRPC 支持的任何语言生成客户端和服务器代码,无论是在大型数据中心内的服务器,还是在个人的电脑 ...

  2. gRPC客户端创建和调用原理解析

    1. gRPC客户端创建流程 1.1. 背景 gRPC是在HTTP/2之上实现的RPC框架,HTTP/2是第7层(应用层)协议,它运行在TCP(第4层 - 传输层)协议之上,相比于传统的REST/JS ...

  3. python grpc 并发_在Python中使用gRPC的方法示例【h】

    本文介绍了在Python中使用gRPC的方法示例,分享给大家,具体如下: 使用Protocol Buffers的跨平台RPC系统. 安装 使用 pip gRPC由两个部分构成,grpcio 和 gRP ...

  4. python中使用grpc方法示例_在Python中使用gRPC的方法示例

    本文介绍了在Python中使用gRPC的方法示例,分享给大家,具体如下: 使用Protocol Buffers的跨平台RPC系统. 安装 使用 pip pip install grpcio pip i ...

  5. 在python中使用grpc和protobuf

    简介 在python中使用grpc和protobuf,比java和c#中使用要简单一些.只需要先安装grpcio包,然后就可以应用了. 安装 使用pip安装grpcio依赖包: $ pip insta ...

  6. 在C#中使用gRPC及protobuf简介

    简介 gRPC提供了很多的语言开发包,C#也可以很容易使用.结合使用protobuf及其编译器,很容易地生成了gRPC的服务stub和proxy. 在CSharp中使用gRPC和Protobuf,可以 ...

  7. 如何在.NET Core中为gRPC服务设计消息文件(Proto)

    如何在.NET Core中为gRPC服务设计消息 使用协议缓冲区规范定义gRPC服务非常容易,但从需求转换为.NET Core,然后管理服务的演变时,需要注意几件事. 创建gRPC服务的核心是.pro ...

  8. 【gRPC】 在.Net core中使用gRPC

    最近在学习.net core的微服务体系架构.微服务之间的通信常常通过gRPC进行同步通信,但是需要注意的是,大多数微服务之间的通信是通过事件总线进行异步通信.在微软介绍.net微服务体系架构的项目e ...

  9. 推荐两款超实用的 gRPC 客户端调试工具

    图片拍摄于2021年7月10日,湖州安吉. 介绍 正好看到董泽润老哥一篇关于使用WireShark分析gRPC流量的文章,学到了.原文地址:小技巧!Wireshark 让调试 grpc 不再困难 那我 ...

  10. 使用ASP.NET Core开始使用gRPC客户端和服务器

    目录 介绍 GRPC Protobuf文件 背景 先决条件 使用代码 第1步--创建gRPC服务应用程序 gRPC项目结构 构建并运行应用程序 第2步:创建客户端控制台.NET核心应用程序 添加必需的 ...

最新文章

  1. TabSpec和TabHost实例
  2. [Python] Window机器上同时安装Python 2 和 Python 3,如何兼容切换使用?
  3. [maven]maven插件 tomcat7-maven-plugin 的使用
  4. go int 转切片_「快学 Go 语言」第 4 课——低调的数组
  5. 【C语言进阶深度学习记录】二十六 C语言中的字符串与字符数组的详细分析
  6. 苦等8个月!华为最令人期待的手机终于要来了:最快月底开卖
  7. ram自己写?用IP?
  8. (二)surging 微服务框架使用系列之surging 的准备工作consul安装(转载 https://www.cnblogs.com/alangur/p/8377977.html)...
  9. 在IDEA中实战Git-branch入门
  10. Pytorch模型量化介绍
  11. 织梦php 文章采集规则,如何正确写DedeCms采集规则
  12. 华为_ensp_vlan接口模式
  13. C++的虚函数表指针vptr
  14. 解决word中Mathtype按钮灰色问题(亲测有效)
  15. 安卓手机便签怎么快速修改重复提醒设置?
  16. 成都中忻嘉业:抖音怎样查看直播回放
  17. 区块链零知识证明:zkSNARKs与zcash
  18. 读书笔记16 《傅雷家书》 傅雷傅敏
  19. NameValuePair和BasicNameValuePair的关系
  20. 在IP网络中,P、PE、CE代表意思

热门文章

  1. 微型计算机中的rom跟ram关系,STC单片机内部扩展RAM的应用
  2. Android Studio开发手机APP(二)-利用MQTT通信开发物联网程序
  3. Android 百度地图api 问题 汇总
  4. 42条风景优美至今基本完整的宁波古道(转)
  5. python条件句格式_python条件语句是什么?条件语句的一般格式是什么样的?
  6. 美团技术委员会前端通道主席洪磊:爱折腾的斜杠青年
  7. linux连ftp超时,ftp上传超时的一种解决方案
  8. 金三银四:蚂蚁金服JAVA后端面试题及答案之二面
  9. python 手机号码_Python手机号码归属地查询代码
  10. 流浪者(rover)