佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > PHP程序員簡(jiǎn)單的開展服務(wù)治理架構(gòu)操作詳解(二)

PHP程序員簡(jiǎn)單的開展服務(wù)治理架構(gòu)操作詳解(二)

熱門標(biāo)簽:電子圍欄 團(tuán)購網(wǎng)站 Linux服務(wù)器 Mysql連接數(shù)設(shè)置 銀行業(yè)務(wù) 阿里云 服務(wù)器配置 科大訊飛語音識(shí)別系統(tǒng)

本文實(shí)例講述了PHP程序員簡(jiǎn)單的開展服務(wù)治理架構(gòu)操作。分享給大家供大家參考,具體如下:

服務(wù)治理 治理的絕筆是服務(wù),在一家公司有玩各種語言的程序員,如何去統(tǒng)一管理他們開發(fā)的服務(wù),這是一個(gè)問題。

上一章主要講了下服務(wù)治理需要什么,如何實(shí)現(xiàn),這章我們?cè)敿?xì)的“肢解”一下服務(wù)治理的一個(gè)非常重要的組員 Thrift

上一章說明他的時(shí)候是這樣寫的

暫時(shí)大可理解為可以通過它去調(diào)用其他開發(fā)語言的方法
本猿人已經(jīng)寫好的服務(wù)治理 https://github.com/CrazyCodes/Service-Govern

名詞解釋

thrift其實(shí)是一個(gè)軟件框架,用來進(jìn)行可擴(kuò)展且跨語言的服務(wù)的開發(fā)。它結(jié)合了功能強(qiáng)大的軟件堆棧和代碼生成引擎,以構(gòu)建在 C++, Java, Go,Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, JavaScript, Node.js, Smalltalk, and OCaml 這些編程語言間無縫結(jié)合的、高效的服務(wù)。

這個(gè)時(shí)候你就疑惑了?,如何跨語言調(diào)用

基本概念

如何調(diào)用這就需要講一下我們強(qiáng)大的通信協(xié)議了。

http (tcp)

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

rpc

遠(yuǎn)程過程調(diào)用協(xié)議,RPC采用客戶機(jī)/服務(wù)器模式。請(qǐng)求程序就是一個(gè)客戶機(jī),而服務(wù)提供者就是一個(gè)服務(wù)器。首先,客戶機(jī)調(diào)用進(jìn)程發(fā)送一個(gè)有進(jìn)程參數(shù)的調(diào)用信息到服務(wù)進(jìn)程,然后等待應(yīng)答信息。在服務(wù)器端,進(jìn)程保持睡眠狀態(tài)直到調(diào)用信息到達(dá)為止。當(dāng)一個(gè)調(diào)用信息到達(dá),服務(wù)器獲得進(jìn)程參數(shù),計(jì)算結(jié)果,發(fā)送答復(fù)信息,然后等待下一個(gè)調(diào)用信息,最后,客戶端調(diào)用進(jìn)程接收答復(fù)信息,獲得進(jìn)程結(jié)果,然后調(diào)用執(zhí)行繼續(xù)進(jìn)行。

rpc的優(yōu)勢(shì)很多,現(xiàn)在你大可理解為rpc通信要比http通信快很多就是了。

這個(gè)時(shí)候facebook和apache就厲害了,它們基于rpc通信協(xié)議開發(fā)出了一套thrift

實(shí)現(xiàn)方法

  • 上面假設(shè)你都沒看懂,這里我們實(shí)戰(zhàn)下。
  • 首先rpc我們通過使用swoole來實(shí)現(xiàn),其他的手碼。
  • 分為客戶端和服務(wù)端做下演示

客戶端

首先我們new一個(gè)client類,去調(diào)用服務(wù)端的UserSerivce這個(gè)類,并且調(diào)用UserService類中的getUserInfo方法。

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

var_dump($userInfo);

Client中我們只需要干這樣的一件事,使用php魔術(shù)方法__call去調(diào)用一個(gè)不存在的方法

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);
  // 我們將要發(fā)送的數(shù)據(jù)是事先約定好的,跟寫對(duì)外開放的Api一樣
  $rpcClient->send(json_encode([
   'service'=>$this->serviceName,
   'action'=>$name,
   'params'=>$arguments[0]
  ]));
  $rpcClient->close();
 }
}

這個(gè)時(shí)候數(shù)據(jù)就通過rpc協(xié)議以json格式發(fā)送到了服務(wù)端

服務(wù)端

$server = new swoole_server("127.0.0.1", 9503);
$server->on('connect', function ($server, $fd){
 echo "connection open: {$fd}\n";
});
$server->on('receive', function ($server, $fd, $reactor_id, $data) {
 // $data 則就是客戶端發(fā)送過來的數(shù)據(jù),我們可以這樣做來做到去調(diào)用類,當(dāng)然你必須遵守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', function ($server, $fd) {
 echo "connection close: {$fd}\n";
});
$server->start();

往期文章

  • PHP程序員如何簡(jiǎn)單的開展服務(wù)治理架構(gòu)(一)

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • PHP程序員簡(jiǎn)單的開展服務(wù)治理架構(gòu)操作詳解(三)
  • PHP程序員簡(jiǎn)單的開展服務(wù)治理架構(gòu)操作詳解(一)
  • PHP數(shù)據(jù)源架構(gòu)模式之表入口模式實(shí)例分析
  • PHP架構(gòu)及原理知識(shí)點(diǎn)詳解
  • thinkPHP5.0框架整體架構(gòu)總覽【應(yīng)用,模塊,MVC,驅(qū)動(dòng),行為,命名空間等】
  • php代碼架構(gòu)的八點(diǎn)注意事項(xiàng)
  • 四種php中webservice實(shí)現(xiàn)的簡(jiǎn)單架構(gòu)方法及實(shí)例
  • php之深入理解架構(gòu)布局講解

標(biāo)簽:廣元 萍鄉(xiāng) 棗莊 江蘇 大理 蚌埠 衡水 衢州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP程序員簡(jiǎn)單的開展服務(wù)治理架構(gòu)操作詳解(二)》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    上高县| 施秉县| 昌乐县| 汝城县| 商水县| 全南县| 唐山市| 方正县| 延庆县| 称多县| 淅川县| 孟村| 沐川县| 庐江县| 且末县| 宜章县| 鄂温| 塔城市| 商河县| 沛县| 特克斯县| 伊金霍洛旗| 越西县| 邻水| 武穴市| 郓城县| 眉山市| 桐梓县| 遵义县| 木兰县| 平陆县| 金昌市| 利川市| 五峰| 尤溪县| 青海省| 北流市| 涿鹿县| 鸡西市| 临沭县| 巴中市|