Foreword
RPC는 Google이 주도하는 RPC 프레임워크로, gRPC 프레임워크가 성숙해지고 사용자 수가 증가함에 따라 protobuf를 데이터 전송 형식으로 사용하고 있습니다. PHP 생태계의 경우 관련 ProtoBuf 소개 문서와 사용 자료가 상대적으로 적기 때문에 필요한 학생들에게 도움이 될 수 있도록 간단한 기사를 작성하고 싶습니다.
ProtoBuf(Google Protocol Buffer)는 Google에서 데이터 교환을 위해 사용하는 시퀀스 구조의 데이터 형식으로, 일반적으로 사용되는 XML 및 JSON과 유사하지만 크기가 더 작습니다. 전송 볼륨, 더 높은 인코딩 및 디코딩 기능, 특히 높은 저장 볼륨과 실시간 성능이 필요한 데이터 저장 및 네트워크 데이터 전송과 같은 분야에 적합합니다.
공식 ProtoBuf의 최신 버전인 ProtoBuf3는 이미 여러 언어(C++C#GoJavaPythonRubyObject C JavascriptPHP)를 지원하며, 다양한 언어에 따라 ProtoBuf에 필요한 클래스 라이브러리를 쉽게 생성할 수 있는 도구를 제공합니다.
다음은 PHP 환경에서 ProtoBuf3를 사용하는 방법을 설명하기 위해 Person 데이터 형식을 예로 사용합니다.
1. 메시지 유형을 정의합니다.
Person에 대한 정의 파일(접미사 .proto 사용)을 만듭니다(예: person.proto). 파일 내용은 다음과 같습니다.
syntax="proto3"; package test; message Person{ string name=1;//姓名 int32 age=2;//年龄 bool sex=3;//性别 }
1 구문 ="proto3": proto3 형식을 사용함을 나타냅니다. 지정하지 않으면 proto2
2입니다. 패키지 테스트: 클래스를 생성할 때 디렉터리가 생성됩니다.
3. 메시지 Person: 각 필드의 정의가 포함된 메시지 본문 내용
2. 해당 PHP 클래스 생성
Person의 형식을 정의한 후 형식이 그렇지 않은 경우 필요한 클래스 라이브러리를 생성하는 것은 실제로 의미가 없습니다. Google은 우리가 원하는 클래스 라이브러리를 생성하는 도구 프로토콜도 제공합니다.
1. protoc 설치
설치 주소: protobuf-php-3.5.1.tar.gz, 최신 버전은 3.5.1
공식 출시 주소: https://github.com/google/protobuf/releases /tag/v3.5.1
압축 해제 및 설치:
tar -zxvf protobuf-php-3.5.1.tar.gz cd protobuf-3.5.1 ./configure --prefix=/opt/soft/protobuf make make install
2. 클래스 라이브러리 생성
/opt/soft/protobuf/bin/protoc --php_out=./ person.proto
세대 후 현재 디렉터리에 다음 파일이 생성됩니다:
GPBMetadata/Person.php
Test/Person.php
3. PHP에서 ProtoBuf 사용
PHP에서 ProtoBuf 사용은 protobuf에 의존합니다. Extension 은 현재 이를 사용하는 두 가지 방법을 제공합니다. 1: PHP의 c 확장, 2: PHP의 lib 확장 패키지, 두 가지 모두 지금 다운로드한 패키지에서 찾을 수 있습니다.
또한 작곡가를 사용하여 종속성 확장을 설치할 수도 있습니다. 작곡가는 google/protobuf를 요구합니다
여기에서는 주로 작곡가를 사용하여 설치합니다. 자동 로드를 생성하는 데 도움이 될 것입니다
종속성을 설치한 후 시작할 수 있습니다 PHP 환경에서 protobuf를 사용하면
1, serialization
<?php include 'vendor/autoload.php'; include 'GPBMetadata/Person.php'; include 'Test/Person.php'; $person = new Test\Person(); $person->setName("lailaiji"); $person->setAge("28"); $person->setSex(true); $data = $person->serializeToString(); file_put_contents('data.bin',$data);
2, deserialization
<?php include 'vendor/autoload.php'; include 'GPBMetadata/Person.php'; include 'Test/Person.php'; $bindata = file_get_contents('./data.bin'); $person = new Test\Person(); $person->mergeFromString($bindata); echo $person->getName();
을 사용하면 lailaiji를 정상적으로 출력할 수 있습니다
PHP에서 일반적으로 사용되는 방법:
직렬화:
1, serializeToString: 이진 문자열로 직렬화
2, serializeToJsonString: JSON 문자열로 직렬화
역직렬화:
1, mergeFromString: 이진 문자열 역직렬화
2. mergeFromJsonString: Json 문자열 역직렬화
. 메시지 구문 분석 of proto
1. 정의:
유형 변수 이름 = 위치;
예: int32 age=1;
구분을 위해 변수 이름 뒤의 숫자는 변수의 위치를 의미합니다. 변수 값이 아닌 이진 시퀀스의 내용입니다. 숫자는 고유해야 하며 재사용할 수 없습니다.
2. 현재 지원되는 유형:
double, float, int32, int64, uint32, uint64, sint32, sint64
fixed32,fixed64, sfixed32, sfixed64, bool, bytes
권장 튜토리얼: " PH P 》
위 내용은 PHP 환경에서 ProtoBuf 데이터 형식 사용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!