【ROS】如何让ROS中节点实现数据交换Ⅱ --服务通信

本文涉及的产品
资源编排,不限时长
简介: 在ros中,一个节点想要获取某种服务(例如:一个节点想要获取此时的相机数据,节点就需要向相机发送一个请求,而相机接收到请求后可以根据消息类型将数据类型返回),这就是基本的服务通信使用场景。

Halo,这里是Ppeua。平时主要更新C语言,C++,数据结构算法…感兴趣就关注我吧!你定不会失望。

本章将介绍如何通过服务通信的方式实现节点数据交换以及ROS相关指令


7f1e0841ff604c82ad26664e64713d65.jpg


0.服务通信概念


在ros中,一个节点想要获取某种服务(例如:一个节点想要获取此时的相机数据,节点就需要向相机发送一个请求,而相机接收到请求后可以根据消息类型将数据类型返回),这就是基本的服务通信使用场景。


以请求响应的方式实现不同节点间的数据交互


8fedcc8fbaa04b6e9c494f587825cddd.png


我们现阶段也不需要了解具体这代表什么意思,只需要知道:

client客户端/server服务端先后在rosmaster中注册本身信息,然后通过相同话题匹配.

1.server 与 client 的启动无先后顺序要求

2.server 与 client 都可以有多个

3.server 与 client 连接后不再需要rosmaster,也就是说仅在尝试连接的时候需要rosmaster


1.自定义srv消息


srv消息是服务端与客户端之间通信的一个数据载体,可用数据类型与std_msgs里的数据类型一致,但需要自己定义.

步骤大概为以下几步:

1.根据需要定义srv格式消息

2.修改配置文件

3.编译生成中间文件并引用


1.1定义srv格式消息


这是一个自己定义的srv的消息格式

因为要实现的是两个数相加,所以这样定义。


其中—上方为client客户端发送的消息格式,下方为服务端响应的消息格式。


# 客户端请求
int32 num1
int32 num2
---
# 服务端响应
int32 ans


1.2修改配置文件


1.和定义msg类似,也要先修改功能包目录下的package.xml,


6b8aef070af94145ad85373e84c4ce5d.png


其中54行的message_generation是编译时的消息软件包

而59行message_runtime是运行时的消息软件包


2.在CMakeList中找到这些地方并修改


 # 1.编译时的依赖包
 find_package(catkin REQUIRED COMPONENTS
 rospy
 std_msgs
 message_generation
 )
 # 2.加入自己定义的srv文件名字
 add_service_files(
 FILES
 Addints.srv 
 )
 # 3.编译包时的消息依赖
 generate_messages(
 DEPENDENCIES
 std_msgs
 )
 # 4.加入message_runtime,但官网没有这一步似乎也可以.
 catkin_package(**chmod +x py文件**
 CATKIN_DEPENDS rospy std_msgs message_runtime
 )


3.编译一下,可以在这个路径中找到刚刚编译完的中间件

之后调用的方法如下:

# 
from packagename.srv import * 

至于为什么要import * 我们可以先来看看编译完产生的文件是什么样的:

a99b175799484b96a58637c97ccbcbc0.png


其产生了一个srv的中间件,出现了三个类,我们之后这三个类都需要使用到,所以一般都是直接import*

2.自定义srv服务通信客户端python实现:


先来分析下作为一个客户端我们需要做什么事:

1.初始化ros节点

2.创建请求对象,设置通信话题

3.请求响应,获得响应结果


import rospy
import lesson3_srv.srv import *
rospy.init_node("sum_client")
client=rospy.ServiceProxy("sum2",Addints)
if(len(sys.argv)!=3):
    rospy.logerr("参数不对")
    sys.exit(1)
num=int(sys.argv[1])
num2=int(sys.argv[2])
response=client.call(num,num2)
rospy.loginfo("%d",response.ans)


这里先导入了rospy的包以及消息类型,初始化了节点信息与话题。


创建了请求服务的对象,serviceprovy(话题,srv消息)


对传入的参数进行了一个处理

clint.call返回类型为自定义消息类型的格式,call(srv中的参数)


最后处理返回的消息


这就是客户端实现,当然还有一些优化内容,等服务端实现完在提

3.自定义srv服务通信服务端python实现:


先来分析下作为一个服务端我们需要做什么事:


1.初始化节点

2.设置订阅话题

3.设置处理消息的回调函数


import rospy
from lesson3_srv.srv import *
def doNum(request):
    num1=request.num1
    num2=request.num2
    sum=num1+num2
    response=AddintsResponse()
    response.ans=sum
    rospy.loginfo("%d %d %d",request.num1,request.num2,response.ans)
    return response
rospy.init_node("sum")
server=rospy.Service("sum2",Addints,doNum)
rospy.spin()


这里先导包


然后通过service(话题名称,srv消息类型,回调函数)创建服务对象


刚刚客户端传入的数据,会作为回调函数的参数


先将其取出,之后通过AddintsResponse的方法创建一个返回对象,改变ans后返回此时的返回值是给了客户端


4.优化客户端


这里的客户端有个很小的问题,仅能在服务器启动后进行通信,若服务器没有启动,而先启动了客户端就会出错,ros官方提供了两个解决方法,二者选其一即可


# rospy.wait_for_service(话题名称)
# client.wait_for_service()


所以改进的客户端代码如下:


import rospy
import sys
from lesson3_srv.srv import *
rospy.init_node("sum_client")
client=rospy.ServiceProxy("sum2",Addints)
if(len(sys.argv)!=3):
    rospy.logerr("参数不对")
    sys.exit(1)
num=int(sys.argv[1])
num2=int(sys.argv[2])
#client.wait_for_service()
rospy.wait_for_service("sum2")
response=client.call(num,num2)
rospy.loginfo("%d",response.ans)


5.启动运行


1.先添加可执行权限 chmod +x py文件

2.之后配置一下CMakeList.txt


 catkin_install_python(
     PROGRAMS
 scripts/demo01_server.py
 scripts/demo01_client.py
 DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
 )


3.

 rosrun lesson3_srv demo01_client.py
 rosrun lesson3_srv demo01_server.py


运行效果:传入2 3 返回值为 5


295cbb75c513413e9876c81a4a2cf99c.png

251031d341a748ed90a2212c1d2d54c1.png


至此服务通信内容结束

相关实践学习
使用ROS创建VPC和VSwitch
本场景主要介绍如何利用阿里云资源编排服务,定义资源编排模板,实现自动化创建阿里云专有网络和交换机。
阿里云资源编排ROS使用教程
资源编排(Resource Orchestration)是一种简单易用的云计算资源管理和自动化运维服务。用户通过模板描述多个云计算资源的依赖关系、配置等,并自动完成所有资源的创建和配置,以达到自动化部署、运维等目的。编排模板同时也是一种标准化的资源和应用交付方式,并且可以随时编辑修改,使基础设施即代码(Infrastructure as Code)成为可能。 产品详情:https://www.aliyun.com/product/ros/
目录
相关文章
|
Python
ROS节点检测ArUco标签并记录空间坐标
利用Realsense D435i相机检测ArUco标签,使用Python程序订阅相机的ROS话题,记录Time和标签的XYZ值,储存在一个csv文件中;当出现识别不到标签或者反馈坐标为0,0,0的情况时,不进行记录。
262 0
|
7天前
ROS 2 - Gazebo 通信入门教程
ROS 2 - Gazebo 通信入门教程
11 0
|
1月前
|
机器人 Shell 开发者
`roslibpy`是一个Python库,它允许非ROS(Robot Operating System)环境(如Web浏览器、移动应用等)与ROS环境进行交互。通过使用`roslibpy`,开发者可以编写Python代码来远程控制ROS节点,发布和订阅话题,以及调用服务。
`roslibpy`是一个Python库,它允许非ROS(Robot Operating System)环境(如Web浏览器、移动应用等)与ROS环境进行交互。通过使用`roslibpy`,开发者可以编写Python代码来远程控制ROS节点,发布和订阅话题,以及调用服务。
|
2月前
|
弹性计算 API 持续交付
基于 ROS 的 Terraform 托管服务轻松部署文本转语音系统 ChatTTS
基于 IaC 的理念,通过定义一个模板,使用 ROS 提供的 Terraform 托管服务进行自动化部署,可以非常高效快捷地部署任意云资源和应用(比如 ChatTTS 服务)。相比于手动部署或者通过 API、SDK 的部署方式,有着高效、稳定等诸多优势,也是服务上云的最佳实践。
39 1
基于 ROS 的 Terraform 托管服务轻松部署文本转语音系统 ChatTTS
|
2月前
|
弹性计算 人工智能 JSON
一键云部署:资源编排 ROS 轻松部署 LLM 流程编排服务 Flowise
Flowise 是一个开源低代码平台,用于构建定制化的 LLM 流程和 AI 代理。阿里云的 Resource Orchestration Service (ROS) 提供了一键部署 Flowise 到 ECS 实例的方案。用户只需在 ROS 控制台配置模板参数,如可用区和实例类型,即可完成部署。部署后,从资源栈输出获取 Flowise 服务地址以开始使用。ROS 模板定义了 VPC、ECS 实例等资源,并通过 ROS 自动化部署,简化了云上资源和应用的管理。
201 1
一键云部署:资源编排 ROS 轻松部署 LLM 流程编排服务 Flowise
|
3月前
|
弹性计算 持续交付 数据中心
一键云部署:ROS的Terraform托管服务助你轻松上线2048经典游戏
阿里云的资源编排服务ROS提供了Terraform托管能力,用户可以直接在ROS控制台上部署Terraform脚本,本文将详细介绍如何使用ROS的Terraform托管服务一键部署经典的2048小游戏到云端,让全世界的玩家都能在线体验。
215 1
|
3月前
|
弹性计算 关系型数据库 API
ECS安装问题之安装资源编排服务(ROS)如何解决
ECS(Elastic Compute Service,弹性计算服务)是云计算服务提供商提供的一种基础云服务,允许用户在云端获取和配置虚拟服务器。以下是ECS服务使用中的一些常见问题及其解答的合集:
|
3月前
|
机器人 C++ Python
[ROS2] --- 通信接口
[ROS2] --- 通信接口
[ROS2] --- 通信接口
|
3月前
|
C++ Python
[ROS2] --- 手动编写一个节点
[ROS2] --- 手动编写一个节点
74 1
|
10月前
|
弹性计算 运维 持续交付
基于资源编排服务(ROS)实现存量资源的IaC化
如果您需要一种简单而有效的方法来管理大量云资源并实现自动化部署,推荐使用阿里云的资源编排服务ROS(Resource Orchestration Service)。ROS能够将存量资源转化为IaC(基础设施即代码),通过资源场景创建、模版生成和资源栈导入等功能,实现资源的统一管理和自动化部署。这不仅提高了资源管理的效率,还降低了成本。如果您想了解如何更轻松地管理云资源并加速部署流程,ROS是一个值得深入了解的工具。
114 1

推荐镜像

更多