0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

RPC如何在遠(yuǎn)程過(guò)程中調(diào)用?

汽車電子技術(shù) ? 來(lái)源: 工控碼農(nóng) ? 作者:工控碼農(nóng) ? 2023-02-07 09:52 ? 次閱讀

RPC(Remote Procedure Call Protocol)即遠(yuǎn)程過(guò)程調(diào)用,也就是調(diào)用的函數(shù)是在其它的控制板上運(yùn)行的,不需要理會(huì)底層的通訊協(xié)議?,F(xiàn)在大型設(shè)備通常有超過(guò)5塊控制板,這些控制板通過(guò)485/CAN/以太網(wǎng)組成一個(gè)局域網(wǎng)。通訊協(xié)議可以使用Modbus或者自定義。。。

多模塊組網(wǎng),實(shí)現(xiàn)模塊化,減少電氣布線便于維護(hù):

圖片

遠(yuǎn)程調(diào)用數(shù)據(jù)流:

圖片

這些控制板的硬件基本都一樣(電機(jī),傳感器。。),底層驅(qū)動(dòng)程序也一樣,只是上層的業(yè)務(wù)邏輯的差別,在驅(qū)動(dòng)層封裝一層rpc,能進(jìn)一步簡(jiǎn)化業(yè)務(wù)邏輯開(kāi)發(fā),使得控制從機(jī)的電機(jī) 動(dòng)作和本機(jī)的函數(shù)接口一樣.

動(dòng)作 傳感器映射

映射是把本地動(dòng)作編號(hào) 傳感器編號(hào)映射到從機(jī)模塊的動(dòng)作編號(hào)和傳感器編號(hào),這個(gè)是在上電初始化時(shí)完成.

enum
{
  HOST=0,//本機(jī)編號(hào)
  SLAVE1,
  SLAVE2,
};


l->MapRemoteAction(201,SLAVE1,1);  //動(dòng)作201映射到從機(jī)1的1號(hào)動(dòng)作
l->MapRemoteAction(301,SLAVE2,1);  //動(dòng)作301映射到從機(jī)2的1號(hào)動(dòng)作


l->MapRemoteSensor(X201,SLAVE1,X01);//把傳感器X201映射到從機(jī)的X01

SLAVE1,SLAVE2是從機(jī)模塊編號(hào),通常是電路板上的撥碼開(kāi)關(guān)決定的.RPC組包時(shí)會(huì)把這些模塊編號(hào)放在頭部.

業(yè)務(wù)代碼:

start(App):
l->WaitAction(201,STEP2,STEP_ERROR);  //執(zhí)行從機(jī)1動(dòng)作201,動(dòng)作正確完成就跳到step2,錯(cuò)誤step_error
step2:
if(l->IsSenorOn(X201))  //從機(jī)1號(hào)傳感器感應(yīng)
{
  l->WaitAction(301,STEP_OK,STEP_ERROR);  //執(zhí)行從機(jī)2的動(dòng)作
}
else
{
  l->SetActionOk();
}
step_ok:
l->SetActionOk();
step_error:
l->SetSubError();
end

上面的業(yè)務(wù)代碼是沒(méi)有任何通訊相關(guān)的流程,只是一些簡(jiǎn)單的函數(shù)調(diào)用和本地函數(shù)調(diào)用一模樣

RPC層

RPC層主要完成數(shù)據(jù)組包,實(shí)時(shí)數(shù)據(jù)通訊,從機(jī)的動(dòng)作 電機(jī)運(yùn)動(dòng)都是耗時(shí)過(guò)程,需要一定的時(shí)間才能完成,那么主機(jī)端的rpc層就需要不斷查詢從機(jī)的狀態(tài).App調(diào)用從機(jī)的動(dòng)作時(shí)就同步等待從機(jī)的狀態(tài)變化后繼續(xù)向下執(zhí)行.軟件實(shí)現(xiàn)上需要單獨(dú)一個(gè)線程或者類似于switch-case實(shí)時(shí)處理rpc的工作流程.

圖片

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • RPC
    RPC
    +關(guān)注

    關(guān)注

    0

    文章

    110

    瀏覽量

    11477
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4237

    瀏覽量

    61969
  • 通訊協(xié)議
    +關(guān)注

    關(guān)注

    10

    文章

    263

    瀏覽量

    20271
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    嵌入式遠(yuǎn)程過(guò)程調(diào)用組件--eRPC

    概述 RPC(Remote Procedure call)遠(yuǎn)程過(guò)程調(diào)用。其分為兩部分:遠(yuǎn)程過(guò)程過(guò)程調(diào)用
    的頭像 發(fā)表于 04-06 14:15 ?2121次閱讀

    TSMaster RPC 基礎(chǔ)入門:編程指導(dǎo)和使用說(shuō)明

    介紹RPC模塊前,我們先淺聊一下RPC的相關(guān)說(shuō)明,以及在什么樣的情況下需要了解本文。1.RPC說(shuō)明遠(yuǎn)程過(guò)程調(diào)用RPC,RemoteProc
    的頭像 發(fā)表于 07-13 08:21 ?606次閱讀
    TSMaster <b class='flag-5'>RPC</b> 基礎(chǔ)入門:編程指導(dǎo)和使用說(shuō)明

    如何手搓一個(gè)自定義的RPC 遠(yuǎn)程過(guò)程調(diào)用框架

    1、RPC遠(yuǎn)程過(guò)程調(diào)用概述) 遠(yuǎn)程過(guò)程調(diào)用RPC, Remote Procedure Call)是一種通過(guò)網(wǎng)絡(luò)從遠(yuǎn)程計(jì)算機(jī)程序上請(qǐng)求服務(wù)
    的頭像 發(fā)表于 07-22 12:17 ?741次閱讀
    如何手搓一個(gè)自定義的<b class='flag-5'>RPC</b> <b class='flag-5'>遠(yuǎn)程過(guò)程調(diào)用</b>框架

    Linux rpc編程過(guò)程

    通過(guò)rpcgen的man手冊(cè)看到此工具的作用是把RPC源程序編譯成C語(yǔ)言源程序,從而輕松實(shí)現(xiàn)遠(yuǎn)程過(guò)程調(diào)用。
    發(fā)表于 07-24 07:25

    RPC的結(jié)構(gòu)原理是什么?

    遠(yuǎn)程過(guò)程調(diào)用RPC)是一個(gè)協(xié)議,程序可以使用這個(gè)協(xié)議請(qǐng)求網(wǎng)絡(luò)另一臺(tái)計(jì)算機(jī)上某程序的服務(wù)而不需知道網(wǎng)絡(luò)細(xì)節(jié)。(過(guò)程調(diào)用有時(shí)也稱作函數(shù)
    發(fā)表于 10-12 10:43

    【學(xué)習(xí)打卡】OpenHarmony的RPC連接介紹

    遠(yuǎn)程過(guò)程調(diào)用 (RPC)是一種用于構(gòu)建基于客戶端-服務(wù)器的分布式應(yīng)用程序的強(qiáng)大技術(shù)。它基于對(duì)傳統(tǒng)本地過(guò)程調(diào)用的擴(kuò)展,因此被調(diào)用過(guò)程不必與
    發(fā)表于 07-28 18:13

    什么是RPC

    什么是RPC   英文原義:Remote Procedure Call Protocol 中文釋義:(RFC-1831)遠(yuǎn)過(guò)程調(diào)用協(xié)議 注  解:一種通過(guò)
    發(fā)表于 02-23 11:48 ?898次閱讀

    OpenMV Cam上的RPC模塊

    OpenMV Cam 上的rpc模塊允許您將 OpenMV Cam 連接到另一臺(tái)微控制器或計(jì)算機(jī),并在 OpenMV Cam 上執(zhí)行遠(yuǎn)程 Python(或過(guò)程調(diào)用。
    的頭像 發(fā)表于 10-08 10:28 ?1314次閱讀

    HTTP和RPC的區(qū)別與聯(lián)系

    HTTP和RPC的相同點(diǎn):底層通訊都是基于socket,都可以實(shí)現(xiàn)遠(yuǎn)程調(diào)用,都可以實(shí)現(xiàn)服務(wù)調(diào)用服務(wù)。
    的頭像 發(fā)表于 11-23 08:55 ?1704次閱讀
    HTTP和<b class='flag-5'>RPC</b>的區(qū)別與聯(lián)系

    OpenDaylightRPC &amp; Notification是什么

    我們將介紹RPC和Notification,并從進(jìn)程內(nèi)外的通信開(kāi)始,著重介紹遠(yuǎn)程過(guò)程調(diào)用和發(fā)布-訂閱機(jī)制,然后分析MD-SAL的通信交互過(guò)程。
    的頭像 發(fā)表于 02-14 15:15 ?820次閱讀
    OpenDaylight<b class='flag-5'>中</b>的<b class='flag-5'>RPC</b> &amp; Notification是什么

    RPC接口與HTTP接口哪一個(gè)更好?

    HTTP接口和RPC接口都是生產(chǎn)上常用的接口,顧名思義,HTTP接口使用基于HTTP協(xié)議的URL傳參調(diào)用,而RPC接口則基于遠(yuǎn)程過(guò)程調(diào)用。
    發(fā)表于 06-13 09:18 ?1010次閱讀
    <b class='flag-5'>RPC</b>接口與HTTP接口哪一個(gè)更好?

    基于Client/Server架構(gòu)的HTTP接口和RPC接口

    HTTP接口和RPC接口都是生產(chǎn)上常用的接口,顧名思義,HTTP接口使用基于HTTP協(xié)議的URL傳參調(diào)用,而RPC接口則基于遠(yuǎn)程過(guò)程調(diào)用。
    發(fā)表于 06-13 09:18 ?654次閱讀
    基于Client/Server架構(gòu)的HTTP接口和<b class='flag-5'>RPC</b>接口

    RPC接口和HTTP接口的區(qū)別與聯(lián)系

    基于遠(yuǎn)程過(guò)程調(diào)用。 RPC(即Remote Procedure Call,遠(yuǎn)程過(guò)程調(diào)用)和HTTP(HyperText Transfer Protocol,超文本傳輸協(xié)議),兩者前者是一種方法,后者則是一種
    的頭像 發(fā)表于 06-17 14:54 ?1670次閱讀
    <b class='flag-5'>RPC</b>接口和HTTP接口的區(qū)別與聯(lián)系

    什么是遠(yuǎn)程過(guò)程調(diào)用

    開(kāi)發(fā)環(huán)境:Ubuntu VS Code 編譯器:g++ 編程語(yǔ)言:C++ 框架源碼下載:GitHub 認(rèn)識(shí)RPC RPC的全稱是遠(yuǎn)程過(guò)程調(diào)用(Remote Procedure Call
    的頭像 發(fā)表于 11-10 10:10 ?826次閱讀
    什么是<b class='flag-5'>遠(yuǎn)程過(guò)程調(diào)用</b>

    Dubbo源碼淺析(一)—RPC框架與Dubbo

    一、什么是RPC 1.1 RPC概念 RPC,Remote Procedure Call 即遠(yuǎn)程過(guò)程調(diào)用,與之相對(duì)的是本地服務(wù)調(diào)用,即LPC
    的頭像 發(fā)表于 08-16 15:18 ?273次閱讀
    Dubbo源碼淺析(一)—<b class='flag-5'>RPC</b>框架與Dubbo