Hyperf (建議學習:PHP影片教學)
對於Java 開發者來說,有技術相當成熟的微服務框架可供選擇:
[Dubbo](https://dubbo.apache.org/zh-cn/) [Spring Cloud](https://www.springcloud.cc/)
作為一名PHPer,我用Google 查了一下“PHP 微服務”,發現有用的相關內容少之又少,沒有什麼實質性的參考價值,無限惆悵。
幸好,有大神在基於Swoole 擴展的基礎上,實現了高性能、高靈活性的PHP 協程框架[Hyperf](https://www.hyperf.io/) ,並提供了微服務架構的相關元件。
Hyperf 是基於`Swoole 4.3 ` 實現的高效能、高靈活性的PHP 協程框架,內建協程伺服器及大量常用的元件,效能較傳統基於`PHP-FPM` 的框架有質的提升,提供超高性能的同時,也保持著極其靈活的可擴展性,標準組件均基於[PSR 標準](https://www.php-fig.org/psr) 實現,基於強大的依賴注入設計,保證了絕大部分組件或類別都是`可替換` 與`可重複用` 的。
於是,我在學習了微服務架構相關的基礎知識之後,使用Hyperf 框架構建了一個基於PHP 的微服務集群,這是項目源碼地址:
https://github.com/Jochen-z/php-microservice-demo
該專案使用Dokcer 搭建,`docker-compose.yml` 程式碼如下:
version:"3" services: consul-server- leader: image:consul:latest container_name:consul-server-leader command:"agent -server -bootstrap -ui -node=consul-server-leader -client=0.0.0.0" environment: - CONSUL_BIND_INTERFACE=eth 0 ports: - "8500:8500" networks: - microservice microservice- 1: build: context:. container_name:"microservice-1" command:"php bin/hyperf.php start" depends_on: - "consul-server-leader" volumes: - ./www/microservice- 1:/var/www networks: - microservice tty:true microservice- 2: build: context:. container_name:"microservice-2" command:"php bin/hyperf.php start" depends_on: - "consul-server-leader" volumes: - ./www/microservice- 2:/var/www networks: - microservice tty:true app: build: context:. container_name:"app" command:"php bin/hyperf.php start" depends_on: - "microservice-1" volumes: - ./www/ web:/var/www ports: - "9501:9501" networks: - microservice tty:true networks: microservice: driver:bridge volumes: microservice: driver:local
這裡啟動了一個Consul 容器`consul-server-leader` 作為服務註冊和服務發現的元件,容器`microservice-1` 和`microservice-2` 分別提供了加法運算和除法運算的服務。
容器`app` 作為服務呼叫方,配置了`consul-server-leader` 容器的URL,透過存取`consul-server-leader` 取得`microservice-1` 和`microservice-2` 服務的IP 位址和端口,然後`app` 透過RPC 協定調用加法運算和除法運算的服務取得結果並返回給使用者。
`app` 容器為 Web 應用,部署了一個 Hyperf 專案並對外提供 HTTP 服務。
例如,在`AppControllerIndexController` 控制器裡有`add` 方法:
publicfunctionadd(AdditionService $addition) { $a = (int) $this->request->input( 'a', 1); # 接受前端用户参数 $b = (int) $this->request->input( 'b', 2); return[ 'a'=> $a, 'b'=> $b, 'add'=> $addition->add($a, $b) # RPC调用 ]; } 在 `AppJsonRpcAdditionService` 中 `add` 的实现: classAdditionServiceextendsAbstractServiceClient { /** * 定义对应服务提供者的服务名称 * @varstring */ protected$serviceName = 'AdditionService'; /** * 定义对应服务提供者的服务协议 * @varstring */ protected$protocol = 'jsonrpc-http'; publicfunctionadd(int $a, int $b): int { return$this->__request( __FUNCTION__, compact( 'a', 'b')); } }
繼承了`AbstractServiceClient` 即可建立一個微服務客戶端請求類, Hyperf 在底層幫我們實作了與Consul 和服務提供者互動的細節,我們只要`AdditionService` 類別裡的`add` 方法即可遠端呼叫`microservice-1` 和`microservice-2` 提供的服務。
至此,PHP 微服務叢集搭建就完成了!
以上是php如何搭建微服務的詳細內容。更多資訊請關注PHP中文網其他相關文章!