RPC是什么

article/2025/9/21 17:16:49

什么是rpc框架

先回答第一个问题:什么是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进行扩展重新编译。

 
  1. [root@localhost /]# cd /lamp/php-5.4.11/ext/xxtea
  2. [root@localhost xxtea]# /usr/local/php/bin/phpize
  3. [root@localhost xxtea]# ./configure --enable-xxtea=shared --with-php-config=/usr/local/php/bin/php-config
  4. 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的接口。

 
  1. <?php
  2. include ("phprpc/phprpc_server.php");
  3. function HelloWorld() {
  4. return 'Hello World!';
  5. }
  6. $server = new PHPRPC_Server();
  7. $server->add('HelloWorld');
  8. $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, 看是如何写的?

 
  1. <?php
  2. include ("phprpc/phprpc_client.php");
  3. $client = new PHPRPC_Client('http://127.0.0.1/server.php');
  4. echo $client->HelloWorld();
  5. ?>

我们在执行以下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进行扩展重新编译。

 
  1. [root@localhost yar-1.2.4]# /usr/local/php/bin/phpize
  2. [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 有问题,那用yum 安装一下吧:

yum -y install curl-devel

安装完成curl 后继续编译安装,就没啥问题了:

 
  1. [root@localhost yar-1.2.4]# /usr/local/php/bin/phpize
  2. [root@localhost yar-1.2.4]# ./configure --with-php-config=/usr/local/php/bin/php-config
  3. [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表示服务器端

 
  1. <?php
  2. class API {
  3. public function api($parameter, $option = "foo") {
  4. return $parameter;
  5. }
  6. protected function client_can_not_see() {
  7. }
  8. }
  9. $service = new Yar_Server(new API());
  10. $service->handle();

好,我们在浏览器里运行一下,就会出现如下图所示的输出。很高端啊!!!鸟哥说这样做的用途是可以一目了然的知道我这个rpc提供了多少接口,把api文档都可以省略了

此处输入图片的描述

好,我们开始写yar_client.php 这个是客户端:

 
  1. $client = new Yar_Client("http://127.0.0.1/yar_server.php");
  2. echo $client->api('helo word');

好,像其他的 swoole,hprose等基本都是这个原理,只是看谁的功能更加,用起来更顺手罢了。

done!


http://chatgpt.dhexx.cn/article/W3f4j4kW.shtml

相关文章

一分钟了解什么是RPC

前言 在介绍RPC之前&#xff0c;先介绍另外一个概念&#xff1a;进程间通信&#xff08;IPC&#xff0c;Inter-Process Communication&#xff09; IPC&#xff1a;是指至少两个进程或线程间传送数据或信号的一些技术或方法。 我们知道进程是计算机系统分配资源的最小单位。每…

【网络】什么是RPC?RPC与HTTP有什么关系?

文章目录 RPC是什么RPC和HTTP的关系和区别[附]关于REST论文中提到的"HTTP不是RPC" 重点参考 凤凰架构-远程过程调用 既然有HTTP为什么还要有RPC&#xff1f; RPC是什么 RPC(Remote Procedure Call)&#xff1a;即远程过程调用&#xff0c;目的是为了让计算机能够跟调…

电脑显示RPC服务器不可用是什么意思,rpc服务器不可用怎么办?rpc服务器不可用是什么意思...

很多人在使用打印机会都遇到rpc服务器不可用的问题&#xff0c;一时之间不知道rpc服务器不可用怎么办&#xff0c;无法作出有效的修复&#xff0c;为了解决一问题&#xff0c;我们首先要明白rpc服务器不可用是什么意思。 rpc服务器全称RPCremote procedure call&#xff0c;它是…

【网络】一文带你了解什么是RPC

一文带你了解什么是RPC 为什么要有RPC什么是RPCPRC架构组件RPC和SOA、SOAP、REST的区别RPC框架需要解决的问题?RPC的实现基础?RPC使用了哪些关键技术?主流RPC框架有哪些 为什么要有RPC http接口是在接口不多、系统与系统交互较少的情况下&#xff0c;初期常使用的一种通信手…

什么是RPC框架?

什么是RPC&#xff1f; In distributed computing, a remote procedure call (RPC) is when a computer program causes a procedure (subroutine) to execute in a different address space (commonly on another computer on a shared network), which is coded as if it wer…

什么是RPC

提到RPC&#xff08;Remote Procedure Call&#xff09;&#xff0c;就躲不开提到分布式&#xff0c;这个促使RPC诞生的领域。 假设你有一个Calculator&#xff0c;以及它的实现类CalculatorImpl&#xff0c;那么单体应用时&#xff0c;要调用Calculator的add方法来执行一个加…

证书服务器rpc服务器不可用是什么意思,rpc服务器不可用是什么意思

rpc服务器不可用是什么意思 用户在使用电脑进行时间同步&#xff0c;安装打印机或者其它的操作的时候可能会遇到同样一个问题&#xff0c;那就是提示“RPC服务器不可用”&#xff0c;很多朋友可能对于RPC并不了解&#xff0c;更不知道如何解决&#xff0c;下面就一起来看看这个…

RPC是什么意思?

原文地址&#xff1a;http://baike.baidu.com/link?urlZV6b0T5v04pem1NluXrFwslmhOosGK3YAeKYBfXHF3J-cg96O7CE9j_opGpKCftpBKWqLtY9-LycDAX0ULaLpssX4IIVmK6fSdtZBzz6nbFRsA-vXppB4IV1KBfDu07pY2dgZYTn5A65RkuhPO00bf5ngU6qfujFC14JqgumBPLgqXgt1VnAzQ7xOwSbJbJkqtNcGRdPxt9f…

rpc协议服务器是什么,什么是rpc框架

第五&#xff0c;返回值还要发送回服务器A上的应用&#xff0c;也要经过序列化的方式发送&#xff0c;服务器A接到后&#xff0c;再反序列化&#xff0c;恢复为内存中的表达方式&#xff0c;交给A服务器上的应用 这里写图片描述 为什么RPC呢&#xff1f;就是无法在一个进程内&a…

rpc协议服务器是什么,RPC是什么?

RPC是什么&#xff1f; REST和RPC都常用于微服务架构中。 都是网络交互的协议规范。 通常用于多个微服务之间的通信协议。 RPC就是从一台机器(客户端)上通过参数传递的方式调用另一台机器(服务器)上的一个函数或方法(可以统称为服务)并得到返回的结果。 什么是RPC 远程方法调用…

RPC简介

1. 概述 RPC&#xff08;Remote Procedure Call&#xff09;&#xff0c;即远程过程调用&#xff0c;是一种通过网络从远程计算机程序上请求服务、而不需要了解底层网络技术的协议。RPC协议假定某些传输协议&#xff08;如TCP或UDP&#xff09;的存在&#xff0c;为通信程序之…

【OS笔记 28】处理死锁的四种方法——预防死锁(破坏四个必要条件之一)

前面讲过预防死锁是通过破坏死锁的四个必要条件&#xff0c;所以就有四个预防死锁的方法吗&#xff1f;错&#xff01;只有三种&#xff0c;因为互斥条件是必须的&#xff0c;不仅不能改变&#xff0c;还应该加以保证。因此只能破坏后三个条件。 一、破坏请求和保持条件 • 方…

什么是死锁,产生死锁的必要条件,以及避免死锁的方法

一、死锁的定义 死锁是指&#xff0c;有两个或两个以上的线程在执行的过程中&#xff0c;由于竞争的资源或者彼此通信而造成的一种阻塞状态&#xff0c;若无外力作用&#xff0c;他们将都无法进行下去&#xff0c;从而形成一直阻塞的状态叫死锁。 简单来说就是…

死锁产生的四个必要条件?如何避免和预防死锁产生?

一、什么是死锁&#xff1f; 两个线程或两个以上线程都在等待对方执行完毕才能继续往下执行的时候就发生了死锁。结果就是这些线程都陷入了无限的等待中&#xff0c;这就是死锁。 举个例子&#xff1a;如果线程1锁住了A&#xff0c;然后尝试对B进行加锁&#xff0c;同时线程2已…

死锁产生的原因和必要条件详解

3.5 产生死锁的原因和必要条件 在多道程序系统中&#xff0c;虽借助于多个进程的并发执行&#xff0c;改善了系统的资源利用率&#xff0c;提高了系统的吞吐量&#xff0c;但可能发生一种危险——死锁。 死锁&#xff08;deadlock&#xff09;&#xff1a; 是指多个进程在运…

死锁概念,死锁产生的四个必要条件,如何避免和预防死锁

一、死锁概念 死锁是指两个或多个进程在执行的过程中&#xff0c;因为竞争资源而造成互相等待的现象&#xff0c;若无外力作用&#xff0c;它们都无法推进下去。 1.在等待对方时占有不可抢占的资源 举个例子&#xff0c;假设有P1&#xff0c;P2两个进程&#xff0c;都需要A和…

关于死锁,死锁的四个必要条件的总结

什么是死锁&#xff1f; 死锁&#xff0c;指的是多个进程再运行期间因争夺资源而产生的一种僵局&#xff0c;若无外力作用&#xff08;破坏死锁&#xff09;&#xff0c;程序将无法运行。 死锁产生的四个必要条件 互斥条件&#xff1a; 进程要求对所分配的资源&#xff08;如…

死锁产生的四个必要条件

一、死锁产生的四个必要条件 互斥条件&#xff1a;资源是独占的且排他使用&#xff0c;进程互斥使用资源&#xff0c;即任意时刻一个资源只能给一个进程使用&#xff0c;其他进程若申请一个资源&#xff0c;而该资源被另一进程占有时&#xff0c;则申请者等待直到资源被占有者…

什么是死锁?死锁发生的四个必要条件是什么?如何避免和预防死锁产生?

什么是死锁&#xff1f; 死锁是指两个或两个以上的进程在执行过程中&#xff0c;由于竞争资源或者由于彼此通信而造成的一种阻塞的现象&#xff0c;若无外力作用&#xff0c;它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁&#xff0c;这些永远在互相等待的进程…

死锁和产生死锁的四个必要条件以及如何避免和预防死锁

什么是死锁 如果一组进程中的每一个进程都在等待仅由该组进程中的其它进程才能引发的事件&#xff0c;那么该组进程就是死锁的。 死锁出现的场景 &#xff08;1&#xff09;多个线程&#xff1a;彼此申请对方资源而导致的死锁。A申请B的资源时&#xff0c;因为资源被占用&am…