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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

節(jié)點是如何調用XMLRPC的

麥辣雞腿堡 ? 來源:古月居 ? 作者:古月居 ? 2023-09-14 17:52 ? 次閱讀

節(jié)點間通過XMLRPC建立連接

在一個節(jié)點剛啟動的時候,它并不知道其它節(jié)點的存在,更不知道它們在交談什么,當然也就談不上通信。

所以,它要先與master對話查詢其它節(jié)點的狀態(tài),然后再與其它節(jié)點通信。

而節(jié)點與master對話使用的就是XMLRPC。

從這一點來看,master叫節(jié)點管理器確實名副其實,它是一個大管家,給剛出生的節(jié)點提供服務。

下面我們以兩個節(jié)點:talker和listener為例,介紹其通過XMLRPC建立通信連接的過程,如下圖所示。

圖片

  1. talker注冊

假設我們先啟動talker。啟動后,它通過1234端口使用XMLRPC向master注冊自己的信息,包含所發(fā)布消息的話題名。master會將talker的注冊信息加入注冊列表中;

2.listener注冊

listener啟動后,同樣通過XMLRPC向master注冊自己的信息,包含需要訂閱的話題名;

3.master進行匹配

master根據(jù)listener的訂閱信息從注冊列表中查找,如果沒有找到匹配的發(fā)布者,則等待發(fā)布者的加入,如果找到匹配的發(fā)布者信息,則通過XMLRPC向listener發(fā)送talker的地址信息。

4.listener發(fā)送連接請求

listener接收到master發(fā)回的talker地址信息,嘗試通過XMLRPC向talker發(fā)送連接請求,傳輸訂閱的話題名、消息類型以及通信協(xié)議(TCP或者UDP);

5.talker確認連接請求

talker接收到listener發(fā)送的連接請求后,繼續(xù)通過XMLRPC向listener確認連接信息,其中包含自身的TCP地址信息;

6.listener嘗試與talker建立連接

listener接收到確認信息后,使用TCP嘗試與talker建立網(wǎng)絡連接。

7.talker向listener發(fā)布消息

成功建立連接后,talker開始向listener發(fā)送話題消息數(shù)據(jù),master不再參與。

從上面的分析中可以發(fā)現(xiàn),前五個步驟使用的通信協(xié)議都是XMLRPC,最后發(fā)布數(shù)據(jù)的過程才使用到TCP。

master只在節(jié)點建立連接的過程中起作用,但是并不參與節(jié)點之間最終的數(shù)據(jù)傳輸。

節(jié)點在請求建立連接時會通過master.cpp文件中的execute()函數(shù)調用XMLRPC庫中的函數(shù)。

我們舉個例子,加入talker節(jié)點要發(fā)布消息,它會調用topic_manager.cpp中的TopicManager::advertise()函數(shù),在函數(shù)中會調用execute()函數(shù),該部分代碼如下。

XmlRpcValue args, result, payload;
  args[0] = this_node::getName();
  args[1] = ops.topic;
  args[2] = ops.datatype;
  args[3] = xmlrpc_manager_- >getServerURI();
  master::execute("registerPublisher", args, result, payload, true);

其中,registerPublisher就是一個遠程過程調用的方法(或者叫函數(shù))。節(jié)點通過這個遠程過程調用向master注冊,表示自己要發(fā)布發(fā)消息了。

你可能會問,registerPublisher方法在哪里被執(zhí)行了呢?我們來到ros_comm-noetic-develtoolsrosmastersrcrosmaster路徑下,打開master_api.py文件,然后搜索registerPublisher這個方法,就會找到對應的代碼,如下。

匆匆掃一眼就知道,它在通知所有訂閱這個消息的節(jié)點,讓它們做好接收消息的準備。

你可能注意到了,這個被調用的XMLRPC是用python語言實現(xiàn)的。

也就是說,XMLRPC通信時只要報文的格式是一致的,不管C++還是python語言,都可以實現(xiàn)遠程調用的功能。

def registerPublisher(self, caller_id, topic, topic_type, caller_api):
        try:
            self.ps_lock.acquire()
            self.reg_manager.register_publisher(topic, caller_id, caller_api)
            # don't let '*' type squash valid typing
            if topic_type != rosgraph.names.ANYTYPE or not topic in self.topics_types:
                self.topics_types[topic] = topic_type
            pub_uris = self.publishers.get_apis(topic)
            sub_uris = self.subscribers.get_apis(topic)
            self._notify_topic_subscribers(topic, pub_uris, sub_uris)
            mloginfo("+PUB [%s] %s %s",topic, caller_id, caller_api)
            sub_uris = self.subscribers.get_apis(topic)            
        finally:
            self.ps_lock.release()
        return 1, "Registered [%s] as publisher of [%s]"%(caller_id, topic), s
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 節(jié)點
    +關注

    關注

    0

    文章

    220

    瀏覽量

    24466
  • 管理器
    +關注

    關注

    0

    文章

    247

    瀏覽量

    18565
  • MASTER
    +關注

    關注

    0

    文章

    104

    瀏覽量

    11302
  • ROS
    ROS
    +關注

    關注

    1

    文章

    279

    瀏覽量

    17042
收藏 人收藏

    評論

    相關推薦

    屬性節(jié)點調用節(jié)點的使用教程

    很多朋友對于屬性節(jié)點的使用表示有些不明白,但是其作用又是相當強大的,所以必須明白怎么使用屬性節(jié)點以及如何調用的問題,下面就來為大家解迷。在獲得對象的reference之后,就可以使用屬性節(jié)點
    發(fā)表于 01-05 16:05

    調用庫函數(shù)節(jié)點

    如圖,調用出來后的庫函數(shù)節(jié)點,怎樣配置其輸入輸出函數(shù)???
    發(fā)表于 05-13 16:35

    布爾控件觸發(fā)調用節(jié)點

    大神們,怎么用布爾控件觸發(fā)調用節(jié)點的重新初始化為默認值?
    發(fā)表于 05-14 15:03

    通過vi調用節(jié)點調用vi的問題

    通過vi節(jié)點,打開前面板,運行vi等等。但是比如說我需要從用戶登錄界面,通過vi調用節(jié)點,打開某個試驗界面,同時希望是淡入淡出的效果,也就是通過設置透明度來實現(xiàn)??墒情_運行到節(jié)點的時候
    發(fā)表于 08-23 21:41

    調用節(jié)點的求助

    調用節(jié)點調用方法的控件值的設置
    發(fā)表于 04-09 11:50

    屬性節(jié)點調用節(jié)點的區(qū)別?

    請問,屬性節(jié)點調用節(jié)點的區(qū)別?
    發(fā)表于 11-21 12:00

    調用庫函數(shù)節(jié)點

    調用庫函數(shù)節(jié)點有什么作用
    發(fā)表于 09-14 21:55

    labview 調用節(jié)點找不到

    請問,這些調用節(jié)點怎么找不到,好惱火
    發(fā)表于 02-22 20:29

    labview dll節(jié)點調用的問題

    調用節(jié)點的時候出現(xiàn)這種情況怎么解決?
    發(fā)表于 04-16 14:44

    labview的matlab節(jié)點能否調用互相調用的matlab程序

    labview的matlab節(jié)點能否調用互相調用的matlab程序
    發(fā)表于 07-09 19:54

    labview 調用DLL節(jié)點出錯

    [問答] labview 調用DLL節(jié)點出錯提示 錯誤1517labview :(Hex 0x5ED)調用節(jié)點發(fā)生錯誤不知道哪位大神能幫忙解決一下回
    發(fā)表于 11-12 18:39

    屬性節(jié)點調用節(jié)點的動態(tài)引用問題

    本帖最后由 蕭獵 于 2021-9-10 16:27 編輯 各位大神: 目前關于屬性節(jié)點調用節(jié)點的引用問題,有靜態(tài)引用,即如下圖:也有先將各引用常量組織成數(shù)組,通過對數(shù)組的處理,動態(tài)的按程序
    發(fā)表于 09-07 14:39

    ROS中XMLRPC是什么

    XMLRPC是什么? 關于ROS節(jié)點建立連接的技術細節(jié),官方文檔說的非常簡單,在這里ROS Technical Overview。沒有基礎的同學看這個介紹必然還是不懂。 在ROS中,節(jié)點節(jié)點
    的頭像 發(fā)表于 09-14 17:40 ?1020次閱讀

    ROS是如何實現(xiàn)XMLRPC

    XMLRPC的C++代碼在下載后的ros_comm-noetic-develutilitiesxmlrpcpp路徑下。 還好,整個工程不算太大。XMLRPC分成客戶端和服務器端兩大部分。 咱們先看
    的頭像 發(fā)表于 09-14 17:45 ?725次閱讀

    ROS中節(jié)點管理器master是如何被啟動的

    我們來看看節(jié)點管理器master是如何被啟動的,再回到parent.pystart()函數(shù),如下。 我們發(fā)現(xiàn)它啟動了XMLRPC服務器后,接下來就調用了_init_runner()函數(shù)。 def
    的頭像 發(fā)表于 09-14 18:03 ?1727次閱讀