资讯专栏INFORMATION COLUMN

php中使用protobuffer

biaoxiaoduan / 3010人阅读

摘要:简介是谷歌出品的跨平台跨语言可扩展的数据传输及存储的协议,是高效的数据压缩编码方式之一。相比于来说,更加小巧,更加快速,更加简单。此外,由于其在内网高效的数据交换效率,是被广泛应用于微服务的,在谷歌的开源框架即是基于此构建起来的。

Protobuf 简介

protobuf(Protocol buffers)是谷歌出品的跨平台、跨语言、可扩展的数据传输及存储的协议,是高效的数据压缩编码方式之一。

Protocol buffers 在序列化数据方面,它是灵活的,高效的。相比于 XML 来说,Protocol buffers 更加小巧,更加快速,更加简单。一旦定义了要处理的数据的数据结构之后,就可以利用 Protocol buffers 的代码生成工具生成相关的代码。甚至可以在无需重新部署程序的情况下更新数据结构。只需使用 Protobuf 对数据结构进行一次描述,即可利用各种不同语言或从各种不同数据流中对你的结构化数据轻松读写。

Protocol buffers 很适合做数据存储或 RPC 数据交换格式。可用于通讯协议、数据存储等领域的语言无关、平台无关、可扩展的序列化结构数据格式。

此外,Protobuf由于其在内网高效的数据交换效率,是被广泛应用于微服务的,在谷歌的开源框架grpc即是基于此构建起来的。

php-protobuf安装

由于protobuf原生并不支持php,所以php如果使用pb则需要安装相应扩展。

pecl install protobuf

环境中需要有protoc编译器,下载安装方式:

$ wget https://github.com/google/protobuf/releases/download/v2.5.0/protobuf-2.5.0.tar.gz
$ tar zxvf protobuf-2.5.0.tar.gz
$ cd protobuf-2.5.0
$ ./configure --prefix=/usr/local/protobuf
$ sudo make 
$ sudo  make install

验证安装成功:

$ /usr/local/protobuf/bin/protoc  --version
libprotoc 2.5.0

php-protobuf安装成功

php --ri protobuf
安装lumen和google/protobuf依赖
lumen new rpc
lumen new rpc命令相当于composer create-project laravel/lumen rpc
composer require google/protobuf

composer.json下添加classmap:

{
    "classmap": [
        "protobuf/"
    ]
}

ok,准备工作都已做好了。

自己做一个demo

在代码目录下创建一个protobuf文件夹mkdir protobuf

进入该目录,创建一个文件searchRequest.proto

syntax = "proto3";
message SearchRequest {
    string query = 1;
    int32 page_number = 2;
    int32 result_per_page = 3;
    enum Corpus {
        UNIVERSAL = 0;
        WEB = 1;
        IMAGES = 2;
        LOCAL = 3;
        NEWS = 4;
        PRODUCTS = 5;
        VIDEO = 6;
    }
    Corpus corpus = 4;
}

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/31753.html

相关文章

  • 从java的序列化和反序列化说起

    摘要:从的序列化和反序列化说起序列化是将对象的状态信息转换为可以存储或传输的形式的过程,而相反的过程就称为反序列化。当使用接口来进行序列化与反序列化的时候需要开发人员重写与方法。 从java的序列化和反序列化说起 序列化 (Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程,而相反的过程就称为反序列化。 在java中允许我们创建可复用的对象,但是这些对象仅仅存在j...

    whlong 评论0 收藏0
  • 前端20个灵魂拷问 彻底搞明白你就是级前端工程师 【下篇】

    摘要:安装后已经完成了安装,并且等待其他的线程被关闭。激活后在这个状态会处理事件回调提供了更新缓存策略的机会。并可以处理功能性的事件请求后台同步推送。废弃状态这个状态表示一个的生命周期结束。 showImg(https://segmentfault.com/img/bVbwWJu?w=2056&h=1536); 不知不觉,已经来到了最后的下篇 其实我写的东西你如果认真去看,跟着去写,应该能有...

    fireflow 评论0 收藏0
  • 基于腾讯开源的msec来进行php开发模块

    摘要:毫秒服务引擎是一个开源框架,适用于在廉价机器组成的集群上开发和运营分布式后台服务。毫秒服务引擎集名字发现服务负载均衡业务监控灰度发布容量管理日志管理存储于一体。 msecphp 毫秒服务引擎(Mass Service Engine in Cluster)是一个开源框架,适用于在廉价机器组成的集群上开发和运营分布式后台服务。 毫秒服务引擎集RPC、名字发现服务、负载均衡、业务监控、灰度发...

    W4n9Hu1 评论0 收藏0
  • 基于腾讯开源的msec来进行php开发模块

    摘要:毫秒服务引擎是一个开源框架,适用于在廉价机器组成的集群上开发和运营分布式后台服务。毫秒服务引擎集名字发现服务负载均衡业务监控灰度发布容量管理日志管理存储于一体。 msecphp 毫秒服务引擎(Mass Service Engine in Cluster)是一个开源框架,适用于在廉价机器组成的集群上开发和运营分布式后台服务。 毫秒服务引擎集RPC、名字发现服务、负载均衡、业务监控、灰度发...

    anRui 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<