【RPC】基础

基本概念

RPC是一个计算机通信协议,允许运行在一台计算机的程序调用另一台计算机的子程序,允许调用远程服务,是一个C/S模式。下图是百度百科的信息,可以看到,它的作用就是我想用到的。main.go里面的计算部分,我希望可以放到服务器上,而服务器获得数据进行计算之后把结果再返还回来,然后本地就可以继续执行下面的代码。
RPC
详解看了知乎的一篇文章:
链接: RPC详解

组成

文章中提到了很多的概念
客户端:也就是所说的调用方,发起调用
客户端存根:类似客户进程,客户端是无法区分的,将参数打包成消息,然后调用本地操作系统,来将消息发送给服务器操作系统
服务器存根:接收来自服务器操作系统的消息,并从里面提取出参数,然后调用服务器。另外一个作用就是接收来自服务器端的消息,打包调用操作系统然后传给客户的本地操作系统
服务器端:执行相应的操作,并将结果返回给服务器存根

具体步骤如下:
RPC原理

调用例子

存在的问题

普通参数的传递是简单的,但是如果是引用参数,比如指针,由于不同的存储,可能引用会失效,这样就需要将参数的副本也传送过去,传递一个指向服务器函数的指针,然后将对象发送回客户端,复制它的引用。
不同的系统的数据格式也可能有区别,所以需要进行标准统一。可以选取一个类型作为参数进行传递来完成统一。

python实现

因为远程暂时用不了go语言,所以先采用python来实现一下
具体是参考了下面的博客。
链接: RPC例子

因为也是C/S模式,所以一个客户端,一个服务器端。但是如果在本机上就可以连接成功,如果放到平台上的话,就没有连接成功,ping也没有办法ping通。尝试了很多种不同的方法,都没有办法。所以最后只能再换一个了。

相关推荐

  1. <span style='color:red;'>RPC</span><span style='color:red;'>基础</span>

    RPC基础

    2023-12-06 04:40:04      37 阅读
  2. RPA基础知识学习清单

    2023-12-06 04:40:04       25 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-06 04:40:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-06 04:40:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-06 04:40:04       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-06 04:40:04       20 阅读

热门阅读

  1. vue elementUI message提示框封装

    2023-12-06 04:40:04       40 阅读
  2. HarmonyOS通过OpenGL渲染显示yuv数据

    2023-12-06 04:40:04       27 阅读
  3. 域名和ip的关系

    2023-12-06 04:40:04       36 阅读
  4. 设计模式_策略模式 更改激光雷达类型

    2023-12-06 04:40:04       33 阅读
  5. spring boot spring-retry重试机制

    2023-12-06 04:40:04       34 阅读
  6. php许愿墙代码包括前端和后端部分

    2023-12-06 04:40:04       34 阅读
  7. 生命周期标注

    2023-12-06 04:40:04       40 阅读
  8. pywin32后台键鼠

    2023-12-06 04:40:04       29 阅读
  9. 机器人算法——costmap膨胀层InflationLayer

    2023-12-06 04:40:04       39 阅读