forked from eclipse-zenoh/zenoh-plugin-ros2dds
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDEFAULT_CONFIG.json5
267 lines (244 loc) · 15 KB
/
DEFAULT_CONFIG.json5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
////
//// This file presents the default configuration used by both the `zenoh-plugin-ros2dds` plugin and the `zenoh-bridge-ros2dds` standalone executable.
//// The "ros2" JSON5 object below can be used as such in the "plugins" part of a config file for the zenoh router (zenohd).
////
{
plugins: {
////
//// ROS2 related configuration
//// All settings are optional and are unset by default - uncomment the ones you want to set
////
ros2dds: {
////
//// nodename: A ROS node name to be used by this bridge.
//// Default: "zenoh_bridge_ros2dds"
////
// nodename: "zenoh_bridge_ros2dds",
////
//// namespace: A ROS namespace which:
//// - is used for the "zenoh_bridge_ros2dds" node itself
//// - is added to all discovered interfaces when routed to Zenoh
//// (i.e. a "cmd_vel" topic in the robot will be seen as "namespace/cmd_vel" outside the robot)
//// Note that this also applies to topics with absolute path such as "/rosout", "/tf" and "/tf_static".
//// Default: "/"
////
// namespace: "/",
////
//// domain: The DDS Domain ID. By default set to 0, or to "$ROS_DOMAIN_ID" is this environment variable is defined.
////
// domain: 0,
////
//// ros_localhost_only: If set to true, the DDS discovery and traffic will occur only on the localhost interface (127.0.0.1).
//// By default set to false, unless the "ROS_LOCALHOST_ONLY=1" environment variable is defined.
////
// ros_localhost_only: true,
////
//// ros_automatic_discovery_range: controls how far ROS nodes will try to discover each other.
//// Valid options are:
//// * "SUBNET" is the default, and for DDS based middleware it means it will discover any node reachable via multicast.
//// * "LOCALHOST" means a node will only try to discover other nodes on the same machine.
//// * "OFF" means the node won’t discover any other nodes, even on the same machine.
//// * "SYSTEM_DEFAULT" means “don’t change any discovery settings”.
////
//// Note that this is only available with ROS 2 Iron and later version
//// For more information: https://docs.ros.org/en/rolling/Tutorials/Advanced/Improved-Dynamic-Discovery.html
////
// ros_automatic_discovery_range: "SUBNET",
////
//// ros_static_peers: is a semicolon (;) separated list of addresses that ROS should try to discover nodes on.
//// This allows connecting to nodes on specific machines (as long as their discovery range is not set to OFF).
////
//// Note that this is only available with ROS 2 Iron and later version
//// For more information: https://docs.ros.org/en/rolling/Tutorials/Advanced/Improved-Dynamic-Discovery.html
////
// ros_static_peers: "192.168.1.1;192.168.1.2",
////
//// shm_enabled: If set to true, the DDS implementation will use Iceoryx shared memory.
//// Requires the bridge to be built with the 'dds_shm' feature for this option to valid.
//// By default set to false.
////
// shm_enabled: false,
////
//// allow / deny: Specify the lists of ROS 2 interfaces that are allowed or denied to be routed over Zenoh.
//// Each element of the lists is a regular expression that must match the full interface name.
//// You cannot set both 'allow' and 'deny' in the same configuration.
//// If neither 'allow' nor 'deny' are set, all interfaces are allowed.
//// Use 'allow' to allow only the specified interfaces. If an interface type is set to an empty list
//// or is not specified at all, it means that NO such interface is allowed.
//// Use 'deny' to allow all except the specified interfaces. If an interface type is set to an empty list
//// or is not specified at all, it means that ALL such interface are allowed.
// allow: {
// publishers: [".*/laser_scan", "/tf", ".*/pose"],
// subscribers: [".*/cmd_vel"],
// service_servers: [".*/.*_parameters"],
// service_clients: [],
// action_servers: [".*/rotate_absolute"],
// action_clients: [],
// },
// deny: {
// publishers: ["/rosout", "/parameter_events"],
// subscribers: ["/rosout"],
// service_servers: [".*/set_parameters"],
// service_clients: [".*/set_parameters"],
// action_servers: [],
// action_clients: [],
// },
////
//// pub_max_frequencies: Specify a list of maximum frequency of publications routing over zenoh for a set of Publishers.
//// The strings must have the format "<regex>=<float>":
//// - "regex" is a regular expression matching a Publisher interface name
//// - "float" is the maximum frequency in Hertz;
//// if publication rate is higher, downsampling will occur when routing.
// pub_max_frequencies: [".*/laser_scan=5", "/tf=10"],
////
//// pub_priorities: Specify a list of priorities of publications routing over zenoh for a set of Publishers.
//// In case of high traffic, the publications with higher priorities will overtake
//// the publications with lower priorities in Zenoh publication queues.
//// The strings must have the format "<regex>=<integer>[:express]":
//// - "regex" is a regular expression matching a Publisher topic name
//// - "integer" is a priority value in the range [1-7]. Highest priority is 1, lowest is 7 and default is 5.
//// (see Zenoh Priority definition here: https://docs.rs/zenoh/latest/zenoh/publication/enum.Priority.html)
//// - ":express" is an option to indicate that the Zenoh express policy must be used for those publications.
//// The express policy makes Zenoh to to send the message immediatly, not waiting for possible further messages
//// to create a bigger batch of messages. This usually has a positive impact on latency for the topic
//// but a negative impact on the general throughput, as more overhead is used for those topics.
// pub_priorities: ["/scan=1:express", "/pose=2", "/rosout=7"],
////
//// reliable_routes_blocking: When true, the publications from a RELIABLE DDS Writer will be
//// routed to zenoh using the CongestionControl::Block option.
//// Meaning the routing will be blocked in case of network congestion,
//// blocking the DDS Reader and the RELIABLE DDS Writer in return.
//// When false (or for BERST_EFFORT DDS Writers), CongestionControl::Drop
//// is used, meaning the route might drop some data in case of congestion.
////
// reliable_routes_blocking: true,
////
//// queries_timeout: Timeouts configuration for various Zenoh queries.
//// Each field is optional. If not set, the 'default' timeout (5.0 seconds by default) applies to all queries,
//// except for actions' get_result that is by default configured with a larget timeout (300.0 seconds)
//// to support actions that last a long time.
//// Refer to https://github.com/eclipse-zenoh/zenoh-plugin-ros2dds/issues/369#issuecomment-2563725619
//// Each value can be either a float in seconds that will apply as a timeout to all queries,
//// either a list of strings with format "<regex>=<float>" where:
//// - "regex" is a regular expression matching an interface name
//// - "float" is the timeout in seconds
// queries_timeout: {
// //// default timeout that will apply to all query, except the ones specified below
// //// in 'transient_local_subscribers', 'services' and 'actions'
// default: 5.0,
// //// timeouts for TRANSIENT_LOCAL subscriber when querying publishers for historical publications
// transient_local_subscribers: 1.0,
// //// timeouts for Service clients calling a Service server
// services: ["add_two_ints=0.5", ".*=1.0"],
// //// timeouts for Action clients calling an Action server (send_goal, cancel_goal and get_result services)
// actions: {
// send_goal: 1.0,
// cancel_goal: 1.0,
// get_result: [".*long_mission=3600", ".*short_action=10.0", ".*=300"],
// }
// },
//// transient_local_cache_multiplier: A multiplier used to determine the size of the `PublicationCache` for a route serving a `TRANSIENT_LOCAL` Publisher.
//// When a `TRANSIENT_LOCAL` Publisher is discovered, the plugin creates a route with a `PublicationCache` to store
//// the publications for late joiner bridges that serve late joiner Subscribers.
//// The cache size must be at least equal to the Publisher's `history_length` QoS setting.
//// Since the plugin creates one route per topic, the route might serve multiple Publishers.
//// Therefore, the `PublicationCache` size is calculated as `history_length * transient_local_cache_multiplier`.
//// If there are more than 10 `TRANSIENT_LOCAL` Publishers on the same topic, consider increasing this multiplier.
// transient_local_cache_multiplier: 10,
////
//// This plugin uses Tokio (https://tokio.rs/) for asynchronous programming.
//// When running as a plugin within a Zenoh router, the plugin creates its own Runtime managing 2 pools of threads:
//// - worker threads for non-blocking tasks. Those threads are spawn at Runtime creation.
//// - blocking threads for blocking tasks (e.g. I/O). Those threads are spawn when needed.
//// For more details see https://github.com/tokio-rs/tokio/discussions/3858#discussioncomment-869878
//// When running as a standalone bridge the Zenoh Session's Runtime is used and can be configured via the
//// `ZENOH_RUNTIME` environment variable. See https://docs.rs/zenoh-runtime/latest/zenoh_runtime/enum.ZRuntime.html
////
//// work_thread_num: The number of worker thread in the asynchronous runtime will use. (default: 2)
//// Only for a plugin, no effect on a bridge.
// work_thread_num: 2,
//// max_block_thread_num: The number of blocking thread in the asynchronous runtime will use. (default: 50)
//// Only for a plugin, no effect on a bridge.
// max_block_thread_num: 50,
},
////
//// REST API configuration (active only if this part is defined)
////
// rest: {
// ////
// //// The HTTP port number (for all network interfaces).
// //// You can bind on a specific interface setting a "<local_ip>:<port>" string.
// ////
// http_port: 8000,
// },
},
////
//// Zenoh related configuration.
//// Only the most relevant sections are displayed here.
//// For a complete view of configuration possibilities, see https://github.com/eclipse-zenoh/zenoh/blob/main/DEFAULT_CONFIG.json5
////
/// The identifier (as unsigned 128bit integer in hexadecimal lowercase - leading zeros are not accepted)
/// that zenoh runtime will use.
/// If not set, a random unsigned 128bit integer will be used.
/// WARNING: this id must be unique in your zenoh network.
// id: "1234567890abcdef",
////
//// mode: The bridge's mode (router, peer or client)
////
//mode: "router",
////
//// Which endpoints to connect to. E.g. tcp/localhost:7447.
//// By configuring the endpoints, it is possible to tell zenoh which remote router or other zenoh-bridge-ros2dds to connect to at startup.
////
connect: {
endpoints: [
// "<proto>/<ip>:<port>"
]
},
////
//// Which endpoints to listen on.
//// By configuring the endpoints, it is possible to tell zenoh which are the endpoints that other routers,
//// peers, or client can use to establish a zenoh session.
//// In 'router' mode (default) the zenoh-bridge-ros2dds is listening by default on `tcp/0.0.0.0:7447` (`0.0.0.0` meaning all the available network interfaces)
////
// listen: {
// endpoints: [
// // "<proto>/<ip>:<port>"
// ]
//},
////
//// Configure the scouting mechanisms and their behaviours
////
//scouting: {
// /// The UDP multicast scouting configuration.
// multicast: {
// /// Whether multicast scouting is enabled or not
// enabled: true,
// /// The socket which should be used for multicast scouting
// address: "224.0.0.224:7446",
// /// The network interface which should be used for multicast scouting
// interface: "auto", // If not set or set to "auto" the interface if picked automatically
// /// Which type of Zenoh instances to automatically establish sessions with upon discovery on UDP multicast.
// /// Accepts a single value or different values for router, peer and client.
// /// Each value is an array containing values "peer", "router" and "client".
// autoconnect: { router: [], peer: ["router","peer"] },
// /// Whether or not to listen for scout messages on UDP multicast and reply to them.
// listen: true,
// },
// /// The gossip scouting configuration.
// gossip: {
// /// Whether gossip scouting is enabled or not
// enabled: true,
// /// When true, gossip scouting information is propagated multiple hops to all nodes in the local network.
// /// When false, gossip scouting information is only propagated to the next hop.
// /// Activating multihop gossip implies more scouting traffic and a lower scalability.
// /// It mostly makes sense when using "linkstate" routing mode where all nodes in the subsystem don't have
// /// direct connectivity with each other.
// multihop: false,
// /// Which type of Zenoh instances to automatically establish sessions with upon discovery on gossip.
// /// Accepts a single value or different values for router, peer and client.
// /// Each value is an array containing values "peer", "router" and "client".
// autoconnect: { router: [], peer: ["router","peer"] },
// },
//},
}