搜尋
首頁後端開發php教程php中流行的rpc框架詳解
php中流行的rpc框架詳解Mar 19, 2018 pm 02:31 PM
php框架詳解

什麼是RPC框架? 如果用一句話概括RPC就是:遠端呼叫框架(Remote Procedure Call)那什麼是遠端呼叫?通常我們呼叫一個php中的方法,例如這樣一個函數方法: localAdd(10, 20),localAdd方法的具體實作要不是使用者自己定義的,就是php函式中自帶的,也就說在localAdd方法的程式碼實作在本地,它是一個本地呼叫!遠端呼叫意思是:被呼叫方法的具體實作不在程式運行本地,而是在別的某個遠端地方。

遠端呼叫原則

例如A (client) 呼叫B (server) 提供的remoteAdd方法:

  1. 首先A與B之間建立一個TCP連線;

  2. 然後A把需要呼叫的方法名稱(這裡是remoteAdd)以及方法參數(10,20)序列化成位元組流發送出去;

  3. #B接受A發送過來的位元組流,然後反序列化得到目標方法名,方法參數,接著執行對應的方法呼叫(可能是localAdd)並把結果30回傳;

  4. A接受遠端呼叫結果,輸出30。

RPC框架就是把我剛才說的這幾點些細節給封裝起來,給用戶暴露簡單友好的API使用。

遠端呼叫的好處

解耦:當server需要對方法內實作修改時,client完全感知不到,不用做任何變更;這種方式在跨部門,跨公司合作的時候經常用到,並且方法的提供者我們通常稱為:服務的暴露。

RPC與Socket有什麼差別?

透過上面的簡單闡述,好像RPC與Socket 好像啊。都是呼叫遠端的方法,都是client/server模式,我之前也寫了一篇文章: 細說socket 那他們有啥區別呢?

RPC(遠端過程呼叫)採用客戶機/伺服器模式實現兩個進程之間相互通訊。 socket是RPC經常採用的通訊手段之一,RPC是在Socket的基礎上實現的,它比socket需要更多的網路和系統資源。除了Socket,RPC還有其他的通訊方法,例如:http、作業系統自帶的管道等技術來實現對於遠端程式的呼叫。微軟的Windows系統中,RPC就是採用命名管道進行通訊。

RPC與REST有什麼不同?

透過了解RPC後,我們知道是RPC是client/server模式的,呼叫遠端的方法,REST也是我們熟悉的一套API呼叫協定方法,它也是基於client/server模式的,呼叫遠端的方法的,那他兩個又有啥差別呢?

REST API 和RPC 都是在 Server端 把一個個函數封裝成介面暴露出去,以供 Client端 調用,不過REST API 是基於HTTP協定的,REST致力於透過http協定中的POST/ GET/PUT/DELETE等方法和一個可讀性強的URL來提供一個http請求。而 RPC 則可以不基於 HTTP協定 
因此,如果是後端兩種語言互相調用,用 RPC 可以獲得更好的效能(省去了 HTTP 標頭等一系列東西),應該也更容易配置。如果是前端透過 AJAX 呼叫後端,那麼用 REST API 的形式比較好(因為無論如何也避不開 HTTP 這道坎)。

php中流行的rpc框架有哪些

既然php是全世界最好的語言,那麼php中流行的RPC框架有哪些呢?

先列舉: phprpc,yar, thrift, gRPC, swoole, hprose

因為時間和精力有限,不可能一個一個的去學習和使用,我選幾個世面上用的最多的幾個用下吧。因為RPC原理是一樣的,都是Client/Server模式,只是每個框架的使用方式不一樣而已。

主要講解 phprpc 和 yar 是我目前聽說和接觸最多的了。

phprpc

先從官網下載最新穩定版的phprpc:下載連結 解壓縮。

安裝

我們會發現裡面有許多檔案和資料夾,結構如下:

  • dhparams/

  • pecl/

  • bigint.php

  • #compat.php

  • ## phprpc_date.php

  • xxtea.php

  • #dhparams.php

  • phprpc_server.php

  • phprpc_client.php

#其中有dhparams和pecl是資料夾,pecl中的是php的xxtea擴展,依照官網的描述,可以安裝也可以不安裝,不安裝phprpc也是可以運作的。但是如果你需要更快的加密處理能力,可以安裝下。

我還是安裝吧。畢竟加密能力更快,是好事:

安裝步驟如下,先將pecl下的xxtea資料夾複製到php原始碼的etx目錄:/lamp/php-5.4.11/ext下。然後用phpize進行擴充重新編譯。

[root@localhost /]# cd /lamp/php-5.4.11/ext/xxtea
[root@localhost xxtea]# /usr/local/php/bin/phpize
[root@localhost xxtea]# ./configure --enable-xxtea=shared --with-php-config=/usr/local/php/bin/php-config
make && make install

OK ,編譯完成,提示我們xxtea.so已經在/usr/local/php/lib/php/extensions/no-debug-zts-20100525/xxtea.so 下了。

下面,我們就需要在php.ini的最後將這個xxtea.so加上:

[root@localhost /]# vi /usr/local/php/etc/php.ini 
[xxtea]
extension=xxtea.so

好。加好了後,我們需要重新啟動下apache或php-fpm

重启apache
[root@localhost /]# /usr/local/apache/bin/apachectl restart
平滑重启php-fpm
kill -USR2 `cat /usr/local/php/var/run/php-fpm.pid`

重啟後,打開phpinfo()頁面,搜尋一下,應該就能夠看到xxtea了。

開始使用

先來個簡單的例子,phprpc也是分成伺服器端和客戶端的。所以資料夾中對應的就是phprpc_server.php 和phprpc_client.php

我們參考官網的幾個例子,練習下:

server.php 服務端:這樣寫就完成了一個最簡單的helloword的介面。

<?php
include ("phprpc/phprpc_server.php");
function HelloWorld() {
   return &#39;Hello World!&#39;;
}
$server = new PHPRPC_Server();
$server->add(&#39;HelloWorld&#39;);
$server->start();

運行下server.php,我擦,居然報錯了! ! !

PHP Strict Standards:  Non-static method PHPRPC_Server::initSession()....
Cannot redeclare gzdecode().....

google了下,說是先把phprpc_server.php的413行的initSession()改成static function

 static function initSession() {
    ****
 }

PS. 我了個擦,這麼大的錯誤,phprpc是怎麼發布的! ! !

在把compat.php 的第 71行的 gzdecode()函數,php5.4已經實現了這個函數了。這樣函數就被重寫了,就報錯了,所以加個判斷:

if (!function_exists('gzdecode')) {
    //将gzdecode函数包括进来
}

好。改完,保存。再運行下server.php 。 ok 了。不報錯了。輸出:

phprpc_functions="YToxOntpOjA7czo5OiJoZWxsb3dvcmQiO30=";

我們接下來寫客戶端 client.php, 看是如何寫的?

<?php
include ("phprpc/phprpc_client.php");
$client = new PHPRPC_Client(&#39;http://127.0.0.1/server.php&#39;);
echo $client->HelloWorld();
?>

我們在執行以下client.php,如願以償的輸出了:

Hello Word!

這樣簡單的Server/Clent交付就搞定了。雖然中間出了點差錯,但是總體來說還是蠻簡單易懂的!

其他的更高級的用法可以參考官網的。

yar

yar 是國內著名的php大神鳥哥惠新宸的大作,在微博產品中已經開始使用。它也是一款rpc框架。它由於使用純C編寫的用於php的擴展,所以,效率應該是蠻高的,而且支援非同步並行,這點還是讚的。

下載安裝

官網下載:http://pecl.php.net/package/yar 最新的版本yar-1.2.4.tgz

然後解壓縮複製到php源碼的etx目錄:/lamp/php-5.4.11/ext下。然後用phpize進行擴充重新編譯。

[root@localhost yar-1.2.4]# /usr/local/php/bin/phpize
[root@localhost yar-1.2.4]# ./configure --with-php-config=/usr/local/php/bin/php-config

但是出現了點問題:提示,curl 有問題:

configure: error: Please reinstall the libcurl distribution - easy.h should be in <curl-dir>/include/curl/</curl-dir>

#猜是我本機curl 有問題,那用yum 安裝一下吧:

yum -y install curl-devel

安裝完成curl 後繼續編譯安裝,就沒啥問題了:

[root@localhost yar-1.2.4]# /usr/local/php/bin/phpize
[root@localhost yar-1.2.4]# ./configure --with-php-config=/usr/local/php/bin/php-config
[root@localhost yar-1.2.4]# make && make install

成功之後,提示我們yar.so 擴充在已經在/usr/local/php/lib/php/extensions/no-debug-zts -20100525/ 下了。

我們vi編輯一下 php.ini ,最後面加上yar.so擴展,然後重啟 apache 或者php-pfm就可以了。

[root@localhost /]# vi /usr/local/php/etc/php.ini 
[yar]
extension=yar.so

好。加好了後,我們需要重新啟動下apache或php-fpm

重启apache
[root@localhost /]# /usr/local/apache/bin/apachectl restart
平滑重启php-fpm
kill -USR2 `cat /usr/local/php/var/run/php-fpm.pid`

重啟後,打開phpinfo()頁面,搜尋一下,應該就能夠看到yar了。

開始使用

和其他的rpc框架一樣,yar也是server/client模式,所以,我們也一樣,開始寫一個簡單的例子來說如何呼叫。

yar_server.php表示伺服器端

<?php
class API {
   public function api($parameter, $option = "foo") {
       return $parameter;
   }
   protected function client_can_not_see() {
   }
}
$service = new Yar_Server(new API());
$service->handle();

好,我們在瀏覽器裡運行一下,就會出現如下圖所示的輸出。很高端啊! ! !鳥哥說這樣做的用途是可以一目了然的知道我這個rpc提供了多少接口,把api文檔都可以省略了。

php中流行的rpc框架詳解

好,我們開始寫yar_client.php 這個是客戶端:

$client = new Yar_Client("http://127.0.0.1/yar_server.php");
echo $client->api(&#39;helo word&#39;);

好,像其他的swoole,hprose等基本上都是這個原理,只是看誰的功能更加,用起來更順手罷了。

相關建議:

PHP中RPC框架基於Redis實作流量控制系統

RPC框架的實例詳解

PHP遠端呼叫以及RPC框架的程式碼詳解(圖)

以上是php中流行的rpc框架詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
php怎么把负数转为正整数php怎么把负数转为正整数Apr 19, 2022 pm 08:59 PM

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

php怎么实现几秒后执行一个函数php怎么实现几秒后执行一个函数Apr 24, 2022 pm 01:12 PM

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php怎么除以100保留两位小数php怎么除以100保留两位小数Apr 22, 2022 pm 06:23 PM

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

php怎么根据年月日判断是一年的第几天php怎么根据年月日判断是一年的第几天Apr 22, 2022 pm 05:02 PM

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php怎么替换nbsp空格符php怎么替换nbsp空格符Apr 24, 2022 pm 02:55 PM

方法:1、用“str_replace("&nbsp;","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\&nbsp\;||\xc2\xa0)/","其他字符",$str)”语句。

php怎么判断有没有小数点php怎么判断有没有小数点Apr 20, 2022 pm 08:12 PM

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php字符串有没有下标php字符串有没有下标Apr 24, 2022 am 11:49 AM

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php怎么设置implode没有分隔符php怎么设置implode没有分隔符Apr 18, 2022 pm 05:39 PM

在PHP中,可以利用implode()函数的第一个参数来设置没有分隔符,该函数的第一个参数用于规定数组元素之间放置的内容,默认是空字符串,也可将第一个参数设置为空,语法为“implode(数组)”或者“implode("",数组)”。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),