ROS 2边学边练(5)-- 何为服务(services)

2024-03-30 18:36

本文主要是介绍ROS 2边学边练(5)-- 何为服务(services),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概念

        服务是ROS世界中的另外一种通信方式,遵循一种经典的C/S架构(有过socket编程经验的同学应该对此不陌生),客户端节点通过服务向服务端节点发起请求(获取某种数据或功能),服务端收到请求后回复给发起该请求的客户端节点信息(通过服务),而不会像主题那样一旦订阅者订阅了主题,发布者会不断的通过主题发布消息(有数据产生的情况下)给所有订阅者,服务只是客户端请求一次,服务端回复一次,而已。下面我们来看看服务在ROS图中的几种场景吧(帮助理解)。

(一个客户端节点)

(多个客户端节点)

        总结上面的两幅图的中心思想,服务是一种点对点的通信方式,客户端节点(一个或多个)可以共用同一个服务来向服务端节点(一个,一个服务只能对应一个服务端节点)发起请求,但服务端节点只能回复给发起请求的客户端节点。

        服务一般适用于有实时性要求(服务是一种同步机制,发出请求会一直等待回复响应)及可能有一定逻辑处理的情况(发出参数数据希望能得到一种综合处理结果,有点类似那种我告诉你我的生辰八字,你给我算算命理的情况一样)。

动动手

         我们还是拿小海龟来说事吧(小海龟估计烦死了)。

启动小海龟

        两个终端分别启动两个节点,分别是turtle_node和turtle_teleop_key,命令如下:

$ros2 run turtlesim turtlesim_node
$ros2 run turtlesim turtle_teleop_key

服务列表

        同前面的主题列表查看方式一样,我们可以通过下面的命令查看当前活动的服务列表:

$ros2 service list

可以看到两个节点都有6个相同的带parameters的服务,在ROS中几乎每个节点都可能会有这些服务,但今天我们先不讨论这个,我们主要关注体验下/clear、/kill、/reset、/spawn、/turtle1/set_pen、/turtle1/teleport_absolute、/turtle1/teleport_relative这些服务(我们可以在rqt里面call这些服务,前面的文章有例子)。

服务数据类型

        每种通信方式都有其协定的数据结构类型才能正常进行交流,服务也不例外,我们通过下面命令进行查看:

$ros2 service type <service_name>

就拿/clear服务来举例,ros2 service type /clear,返回如下,

Empty这种服务数据类型就代表发起的请求及回复都没有数据。

也可以通过增加-t来显示当前所有服务的数据类型。

$ros2 service list -t

寻找服务(带某种服务数据类型)

        既然我们可以查看当前所有服务及其对应的数据类型,那么我们是不是也可以通过数据类型来查看使用这种数据类型的服务有哪些呢?

$ros2 service find <type_name>

喏,上面就是使用方法,我们从上面随便选一两个数据类型来查查看。

数据类型详情查看

        老规矩,直接interface show查看,

$ros2 interface show <type_name>

先来Empty,

返回三道杠,何意?三道杠上面的代表请求数据类型,三道杠下面的代表回复的数据类型,正如上文所说,Empty数据类型是既无请求数据也无回复数据,所以表现出来的就是大家看到的这样。

我们再来看看turtlesim/srv/Spawn服务数据类型,请求数据类型是3个flat32类型(浮点数)数据以及一个string类型(字符串)数据,x、y、theta为坐标角度相关的数据,name为节点对象的名字(可指定,如不指定,系统会自动赋值一个),然后系统会根据请求的数据消息返回生成对象的最终名字作为这次请求的回复响应。

调用服务(命令行)

$ros2 service call <service_name> <service_type> <arguments>

我们手动调用一个服务来练练手,比如还是拿/clear这个服务(数据类型为Empty,不需要参数,简单)来试,试之前我们先让小海龟热热身,在海洋上画出点痕迹出来,然后我们调用/clear服务,看看会发生什么。

$ros2 service call /clear std_srvs/srv/Empty

痕迹抹除啦。下面我们来点有难度的,新孵化出一只海龟,这个可就需要参数啦(注意参数的语法格式必须是YAML),名字我们不取,看看服务会给我们返回什么样的雅名。

$ros2 service call /spawn turtlesim/srv/Spawn "{x: 2, y: 2, theta: 0.2, name: ''}"

如果主动取个名字呢。

打印服务数据

        前面我们可以通过echo来展示主题间各节点通信的具体数据内容,我们看服务是不是也一样,官方文档给出的查看命令如下:

$ros2 service echo <service_name | service_type> <arguments>

根据手册在查看之前,我们还必须先手动打开service_configure_introspection及client_configure_introspection(默认是关闭的),这种操作个人感觉还是有点不方便的,为了方便表述,我们拿另外一个例子来说明。

先调用py脚本启动示例,

$ros2 launch demo_nodes_cpp introspect_services_launch.py

不断再刷上面的内容(2+3=5),然后再使能C/S的configure_introspection,

$ros2 param set /introspection_service service_configure_introspection contents
$ros2 param set /introspection_client client_configure_introspection contents

参数设置成功哈,但是这个例子所运行的服务名称和数据类型是啥呢,看调用的那个py文件也可以,但我们要做符合我们身份的事情,敲行命令查查先(应该还记得吧),

就是第一个,服务为/add_two_ints,其数据类型为example/srv/AddTwoInts,差不多了,不对,如果要echo出服务的具体数据,我们还差参数,但是参数是需要知道数据类型的数据结构的(可选项),我们再查查,

好了,万事俱备,开始ros2 service echo吧,先输入下面命令会给出什么提示(因为参数具体给什么此时我心里也没底):

$ros2 service echo /add_two_ints | example_interfaces/srv/AddTwoInts

出错了?提示一共两个错误,其一是没有example_interfaces/srv/AddTwoInts这个文件或目录,其二是这个版本的ros service根本没有echo这个功能,我们根据提示查查看ros service到底支持哪些功能,

$ros2 service -h

咦,果真没有,ros service仅支持ros2 service call、find、list、type这四个功能,看来还是印证了那句老话,尽信书(权威)不如无书,唯有实践出真知,路是一个脚印一个脚印走出来的。

本篇完。

这篇关于ROS 2边学边练(5)-- 何为服务(services)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/862258

相关文章

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

基于SpringBoot的宠物服务系统+uniapp小程序+LW参考示例

系列文章目录 1.基于SSM的洗衣房管理系统+原生微信小程序+LW参考示例 2.基于SpringBoot的宠物摄影网站管理系统+LW参考示例 3.基于SpringBoot+Vue的企业人事管理系统+LW参考示例 4.基于SSM的高校实验室管理系统+LW参考示例 5.基于SpringBoot的二手数码回收系统+原生微信小程序+LW参考示例 6.基于SSM的民宿预订管理系统+LW参考示例 7.基于

Golang支持平滑升级的HTTP服务

前段时间用Golang在做一个HTTP的接口,因编译型语言的特性,修改了代码需要重新编译可执行文件,关闭正在运行的老程序,并启动新程序。对于访问量较大的面向用户的产品,关闭、重启的过程中势必会出现无法访问的情况,从而影响用户体验。 使用Golang的系统包开发HTTP服务,是无法支持平滑升级(优雅重启)的,本文将探讨如何解决该问题。 一、平滑升级(优雅重启)的一般思路 一般情况下,要实现平滑

Golang服务平滑重启

与重载配置相同的是我们也需要通过信号来通知server重启,但关键在于平滑重启,如果只是简单的重启,只需要kill掉,然后再拉起即可。平滑重启意味着server升级的时候可以不用停止业务。 我们先来看下Github上有没有相应的库解决这个问题,然后找到了如下三个库: facebookgo/grace - Graceful restart & zero downtime deploy for G

ROS - C++实现RosBag包回放/提取

文章目录 1. 回放原理2. 回放/提取 多个话题3. 回放/提取数据包,并实时发布 1. 回放原理 #include <ros/ros.h>#include <rosbag/bag.h>#include <std_msgs/String.h>int main(int argc, char** argv){// 初始化ROS节点ros::init(argc, argv,

Java后端微服务架构下的API限流策略:Guava RateLimiter

Java后端微服务架构下的API限流策略:Guava RateLimiter 大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿! 在微服务架构中,API限流是保护服务不受过度使用和拒绝服务攻击的重要手段。Guava RateLimiter是Google开源的Java库中的一个组件,提供了简单易用的限流功能。 API限流概述 API限流通过控制请求的速率来防止

【微服务】Ribbon(负载均衡,服务调用)+ OpenFeign(服务发现,远程调用)【详解】

文章目录 1.Ribbon(负载均衡,服务调用)1.1问题引出1.2 Ribbon负载均衡1.3 RestTemplate整合Ribbon1.4 指定Ribbon负载均衡策略1.4.1 配置文件1.4.2 配置类1.4.3 定义Ribbon客户端配置1.4.4 自定义负载均衡策略 2.OpenFeign面向接口的服务调用(服务发现,远程调用)2.1 OpenFeign的使用2.1 .1创建