|
|
|
|
|
|
|
# gRPC PHP End-to-End Examples
|
|
|
|
|
|
|
|
This page shows a number of ways to create a PHP gRPC client and connect with
|
|
|
|
a gRPC backend service.
|
|
|
|
|
|
|
|
|
|
|
|
## Run the Server
|
|
|
|
|
|
|
|
For all the following examples, we use a simple gRPC server, written in Node.
|
|
|
|
|
|
|
|
```sh
|
|
|
|
$ git clone https://github.com/grpc/grpc-web
|
|
|
|
$ cd grpc-web
|
|
|
|
$ docker-compose build prereqs node-server
|
|
|
|
$ docker run -d -p 9090:9090 --name node-server grpcweb/node-server
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
## Install the gRPC PECL extension
|
|
|
|
|
|
|
|
All the following commands are assumed to be run from this current directory.
|
|
|
|
|
|
|
|
```sh
|
|
|
|
$ cd grpc/examples/php/echo
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
In order to build a PHP gRPC client, we need to install the `grpc` extension
|
|
|
|
first.
|
|
|
|
|
|
|
|
```sh
|
|
|
|
$ docker build -t grpc-php/base -f ./base.Dockerfile .
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
## CLI
|
|
|
|
|
|
|
|
|
|
|
|
Let's first build a simple CLI gRPC client:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
$ docker build -t grpc-php/echo-client -f ./cli.Dockerfile .
|
|
|
|
$ docker run -it --rm --link node-server:node-server grpc-php/echo-client
|
|
|
|
$ php client.php
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Apache
|
|
|
|
|
|
|
|
|
|
|
|
Now let's see how the gRPC PHP client can run with Apache:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
$ docker build -t grpc-php/apache -f ./apache.Dockerfile .
|
|
|
|
$ docker run -it --rm --link node-server:node-server -p 80:80 grpc-php/apache
|
|
|
|
```
|
|
|
|
|
|
|
|
Open the browser to `http://localhost`.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Nginx + FPM
|
|
|
|
|
|
|
|
|
|
|
|
We can also try running PHP-FPM and put Nginx in front of it.
|
|
|
|
|
|
|
|
|
|
|
|
The PHP-FPM part:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
$ docker build -t grpc-php/fpm -f ./fpm.Dockerfile .
|
|
|
|
$ docker run -it --rm --link node-server:node-server -p 9000:9000 \
|
|
|
|
--name fpm grpc-php/fpm
|
|
|
|
```
|
|
|
|
|
|
|
|
The Nginx part:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
$ docker run -it --rm -v $(pwd)/nginx.conf:/etc/nginx/conf.d/default.conf:ro \
|
|
|
|
--link fpm:fpm -p 80:80 nginx:1.17.4
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
Open the browser to `http://localhost`.
|