成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

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

wing324 / 1706人閱讀

摘要:服務(wù)治理治理的絕筆是服務(wù),在一家公司有玩各種語言的程序員,如何去統(tǒng)一管理他們開發(fā)的服務(wù),這是一個(gè)問題。請求程序就是一個(gè)客戶機(jī),而服務(wù)提供者就是一個(gè)服務(wù)器。在服務(wù)器端,進(jìn)程保持睡眠狀態(tài)直到調(diào)用信息到達(dá)為止。

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

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

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

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

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ù)器模式。請求程序就是一個(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)勢很多,現(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ù)是事先約定好的,跟寫對外開放的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}
";
});
$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}
";
});
$server->start();
往期文章

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

鳴謝

周夢康 https://mengkang.net/

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/28327.html

相關(guān)文章

  • PHP序員如何簡單開展服務(wù)治理架構(gòu)(三)

    摘要:是一種使用松耦合的黑盒子服務(wù)構(gòu)建業(yè)務(wù)應(yīng)用的體系架構(gòu),這些服務(wù)可以通過編排連接在一起以實(shí)現(xiàn)特定的功能。在一個(gè)中如何實(shí)現(xiàn)松耦合實(shí)現(xiàn)松耦合一種策略是使用服務(wù)接口中為服務(wù)來限制服務(wù)之間的依賴性,對消費(fèi)者隱藏服務(wù)實(shí)現(xiàn)。 服務(wù)治理所治理的服務(wù)需要合理的部署與管理,本章我們講一下SOA(面向服務(wù)架構(gòu)),本人語言文筆不好,所以本章內(nèi)容使用問答模式,參考了 [SOA面試題(http://www.jdon...

    Dionysus_go 評論0 收藏0
  • PHP序員如何簡單開展服務(wù)治理架構(gòu)(一)

    摘要:管理這些服務(wù)方案則叫服務(wù)治理。協(xié)議假定某些傳輸協(xié)議的存在,如或,為通信程序之間攜帶信息數(shù)據(jù)。請求程序就是一個(gè)客戶機(jī),而服務(wù)提供程序就是一個(gè)服務(wù)器。在服務(wù)器端,進(jìn)程保持睡眠狀態(tài)直到調(diào)用信息到達(dá)為止。 不涉及其他的語言及工具,我們從PHP本身來談如何實(shí)現(xiàn)服務(wù)治理 本猿人已經(jīng)寫好的服務(wù)治理 https://github.com/CrazyCodes... 治理什么? 這個(gè)專業(yè)名詞很容易發(fā)現(xiàn)...

    superPershing 評論0 收藏0
  • 華為數(shù)字化轉(zhuǎn)型,你為什么就學(xué)不會?

    摘要:一引言華為數(shù)字化轉(zhuǎn)型的邏輯和方法,看起來似乎并不非常復(fù)雜。華為在年提出實(shí)現(xiàn)全聯(lián)接的智能華為,成為行業(yè)標(biāo)桿的數(shù)字化轉(zhuǎn)型目標(biāo)。但是,華為的數(shù)字化轉(zhuǎn)型之道真的好學(xué)嗎其實(shí)不然。華為真正提出數(shù)字化轉(zhuǎn)型,是在年。一、引言華為數(shù)字化轉(zhuǎn)型的邏輯和方法,看起來似乎并不非常復(fù)雜。筆者將《華為.數(shù)字化轉(zhuǎn)型必修課》課程的主要內(nèi)容,概括為一個(gè)愿景、三大目標(biāo)、四個(gè)基礎(chǔ)、五大內(nèi)容、三大要求、六大案例,用下圖來表示:?一個(gè)...

    不知名網(wǎng)友 評論0 收藏0
  • 明星分分合合洪荒點(diǎn)擊量,微博Mesh服務(wù)化改造如何支撐?(附PPT下載)

    摘要:為了解決這一系列問題,微博從年開發(fā)了語言的框架,并基于此完成了服務(wù)化改造。這些經(jīng)歷之下微博也積累了一套服務(wù)治理型的服務(wù)化體系。的版,所要解決的是微博平臺內(nèi)部服務(wù)之間的調(diào)用,因此協(xié)議時(shí),其實(shí)并沒有考慮到跨語言的問題,用的是對比較友好的。 showImg(https://segmentfault.com/img/remote/1460000012601596?w=1080&h=606); ...

    ShowerSun 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<