1. 程式人生 > 程式設計 >PHP程式設計師簡單的開展服務治理架構操作詳解(二)

PHP程式設計師簡單的開展服務治理架構操作詳解(二)

本文例項講述了PHP程式設計師簡單的開展服務治理架構操作。分享給大家供大家參考,具體如下:

服務治理 治理的絕筆是服務,在一家公司有玩各種語言的程式設計師,如何去統一管理他們開發的服務,這是一個問題。

上一章主要講了下服務治理需要什麼,如何實現,這章我們詳細的“肢解”一下服務治理的一個非常重要的組員 Thrift

上一章說明他的時候是這樣寫的

暫時大可理解為可以通過它去呼叫其他開發語言的方法
本猿人已經寫好的服務治理 https://github.com/CrazyCodes/Service-Govern

名詞解釋

thrift其實是一個軟體框架,用來進行可擴充套件且跨語言的服務的開發。它結合了功能強大的軟體堆疊和程式碼生成引擎,以構建在 C++,Java,Go,Python,PHP,Ruby,Erlang,Perl,Haskell,C#,Cocoa,JavaScript,Node.js,Smalltalk,and OCaml 這些程式語言間無縫結合的、高效的服務。

這個時候你就疑惑了?,如何跨語言呼叫

基本概念

如何呼叫這就需要講一下我們強大的通訊協議了。

http (tcp)

超文字傳輸協議,正常訪問瀏覽器啥看新聞、購物的時候必定使用,需要客戶端和服務端握手?成功才可以正常顯示,這中間握手的流出很複雜,執行各種各樣的解碼編碼(為了方便理解,暫時這麼想吧)

rpc

遠端過程呼叫協議,RPC採用客戶機/伺服器模式。請求程式就是一個客戶機,而服務提供者就是一個伺服器。首先,客戶機呼叫程序傳送一個有程序引數的呼叫資訊到服務程序,然後等待應答資訊。在伺服器端,程序保持睡眠狀態直到呼叫資訊到達為止。當一個呼叫資訊到達,伺服器獲得程序引數,計算結果,傳送答覆資訊,然後等待下一個呼叫資訊,最後,客戶端呼叫程序接收答覆資訊,獲得程序結果,然後呼叫執行繼續進行。

rpc的優勢很多,現在你大可理解為rpc通訊要比http通訊快很多就是了。

這個時候facebook和apache就厲害了,它們基於rpc通訊協議開發出了一套thrift

實現方法

  • 上面假設你都沒看懂,這裡我們實戰下。
  • 首先rpc我們通過使用swoole來實現,其他的手碼。
  • 分為客戶端和服務端做下演示

客戶端

首先我們new一個client類,去呼叫服務端的UserSerivce這個類,並且呼叫UserService類中的getUserInfo方法。

$client = new Client('UserSerivce');
$userInfo = $client->getUserInfo(1);

var_dump($userInfo);

Client中我們只需要幹這樣的一件事,使用php魔術方法__call去呼叫一個不存在的方法

class Client{
 protected $serviceName;
   
 public function __construct($serviceName){
  $this->serviceName = $serviceName;
 }
 public function __call($name,$arguments){
  $rpcClient = new \swoole_client(SWOOLE_SOCK_TCP);
  $rpcClient->connect('127.0.0.1',9503,0.5);
  // 我們將要傳送的資料是事先約定好的,跟寫對外開放的Api一樣
  $rpcClient->send(json_encode([
   'service'=>$this->serviceName,'action'=>$name,'params'=>$arguments[0]
  ]));
  $rpcClient->close();
 }
}

這個時候資料就通過rpc協議以json格式傳送到了服務端

服務端

$server = new swoole_server("127.0.0.1",9503);
$server->on('connect',function ($server,$fd){
 echo "connection open: {$fd}\n";
});
$server->on('receive',$fd,$reactor_id,$data) {
 // $data 則就是客戶端傳送過來的資料,我們可以這樣做來做到去呼叫類,當然你必須遵守PSR-4 Autoloader
 $request = json_decode ($data,true);
 $className = $request['service'];
 $app  = new $className;
 $response = $app->{$request['action']}($request['params']);
 
 $server->send($fd,"Swoole: {$data}");
 $server->close($fd);
});
$server->on('close',$fd) {
 echo "connection close: {$fd}\n";
});
$server->start();

往期文章

  • PHP程式設計師如何簡單的開展服務治理架構(一)

更多關於PHP相關內容感興趣的讀者可檢視本站專題:《php面向物件程式設計入門教程》、《PHP陣列(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運算與運算子用法總結》、《php字串(string)用法總結》、《php+mysql資料庫操作入門教程》及《php常見資料庫操作技巧彙總》

希望本文所述對大家PHP程式設計有所幫助。