-
Notifications
You must be signed in to change notification settings - Fork 365
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Lifespan QoS setting ignored when using Cyclone DDS in ROS 2 #1835
Comments
Hi @okahilak, what you're running into is that Cyclone's "lifespan" implementation follows the DDS specification. Section 2.2.3 of the spec clearly lists the "lifespan" QoS setting as applicable to DataWriter and Topic, but not to do DataReader, and defines it as:
I've always found it a strange choice. Surely it is the one interpreting the data that should decide what is relevant? (Imagine what "lifespan" would do to the archeologists ...) But the spec is pretty clear on what it means in DDS. One could choose to also implement a notion of lifespan on the data reader. I have experience with OpenSplice DDS's version, I also know it has hardly been used. As reading is generally pretty cheap (because the data is already present at the reader by design) arguably discarding old data after reading it should usually be good enough, even if it is not exactly the same. That said, it may be that ROS chose to interpret/document their lifespan QoS differently and everyone just assumed it would fit ... Clearly I'm not firmly opposed to adding a notion of lifespan on the reader, it is more of a cost/benefit analysis. I simply don't think it is the most pressing issue with Cyclone that needs addressing. Despite that, I would certainly be happy to entertain a PR that adds it — it is fairly straightforward because the DDS-spec based implementation already requires removing expired samples from reader history cache, so it is more a matter of tweaking the timing than of adding truly new code. |
Hi! Thanks for the friendly and detailed response, I appreciate it! Coming from the ROS world, I didn't venture into reading the DDS specification - you're right, it is pretty clear on how lifespan should work. I also agree that it would feel natural that the reader would have a say on how long the data stays relevant to them. That said, I can also see the importance of not deviating from the specification. I think my confusion stemmed from how ROS2 documents lifespan and deadline without clarifying how they may apply differently to publisher and subscriber:
As per the documentation of eProsima Fast DDS, their lifespan QoS affects DataReader, DataWriter, and Topic entities, so it works differently from Cyclone DDS. I could think of a few ways to decrease the potential for confusion, while not changing Cyclone DDS to deviate from DDS spec:
Alas, I don't have too much time right now to look into either option, but at least it is documented in this issue for possible future reference. |
I am encountering a behavior in ROS 2 where the Lifespan QoS setting seems to be ignored when using Cyclone DDS. This issue is not observed with eProsima Fast DDS.
Environment:
ROS 2 Version: Iron - Patch Release 2
OS: Ubuntu 22.04.3 LTS with PREEMPT_RT kernel patch
Architecture: x86_64
I'm running the following ROS node, which implements a minimal subscriber with a lifespan set to 100 ms:
Expected Behavior:
When I query topic info, the lifespan should be 100 ms.
Observed Behavior:
The lifespan appears to be infinite.
Steps to reproduce:
Here's a step-by-step guide and attached is a .tar.gz file to help reproduce the issue:
cyclonedds_lifespan_problem.tar.gz
The text was updated successfully, but these errors were encountered: