From 06f29d0bed525f6c02fbd5f08f473ec1bd11e4da Mon Sep 17 00:00:00 2001 From: Yadu Date: Mon, 22 Jan 2024 22:24:32 +0800 Subject: [PATCH] Limit threads per zenoh session (#95) * Limit threads per zenoh session and in router config Signed-off-by: Yadunund --- .../config/DEFAULT_RMW_ZENOH_ROUTER_CONFIG.json5 | 9 ++++++++- .../DEFAULT_RMW_ZENOH_SESSION_CONFIG.json5 | 10 ++++++++++ zenoh_c_vendor/CMakeLists.txt | 16 ++++++++++++++++ 3 files changed, 34 insertions(+), 1 deletion(-) diff --git a/rmw_zenoh_cpp/config/DEFAULT_RMW_ZENOH_ROUTER_CONFIG.json5 b/rmw_zenoh_cpp/config/DEFAULT_RMW_ZENOH_ROUTER_CONFIG.json5 index 434de9fe..ac57e00e 100644 --- a/rmw_zenoh_cpp/config/DEFAULT_RMW_ZENOH_ROUTER_CONFIG.json5 +++ b/rmw_zenoh_cpp/config/DEFAULT_RMW_ZENOH_ROUTER_CONFIG.json5 @@ -186,7 +186,14 @@ backoff: 100, // Number of threads dedicated to transmission // By default, the number of threads is calculated as follows: 1 + ((#cores - 1) / 4) - // threads: 4, + // We limit the number of threads that the zenoh session can spin to 1. + // Without this limit, applications with multiple zenoh sessions can + // encounter system resource errors when trying to create new threads. + // Once zenoh migrates to relying on tokio for its async runtime, + // see https://github.com/eclipse-zenoh/zenoh/pull/566, we can consider + // removing these flags since with tokio, zenoh can better manage the threads it spins + // with the help of thread pools. + threads: 1, }, }, /// Configure the zenoh RX parameters of a link diff --git a/rmw_zenoh_cpp/config/DEFAULT_RMW_ZENOH_SESSION_CONFIG.json5 b/rmw_zenoh_cpp/config/DEFAULT_RMW_ZENOH_SESSION_CONFIG.json5 index 43550e1d..8a07b61e 100644 --- a/rmw_zenoh_cpp/config/DEFAULT_RMW_ZENOH_SESSION_CONFIG.json5 +++ b/rmw_zenoh_cpp/config/DEFAULT_RMW_ZENOH_SESSION_CONFIG.json5 @@ -185,6 +185,16 @@ /// Higher values lead to a more aggressive batching but it will introduce additional latency. backoff: 100, }, + // Number of threads dedicated to transmission + // By default, the number of threads is calculated as follows: 1 + ((#cores - 1) / 4) + // We limit the number of threads that the zenoh session can spin to 1. + // Without this limit, applications with multiple zenoh sessions can + // encounter system resource errors when trying to create new threads. + // Once zenoh migrates to relying on tokio for its async runtime, + // see https://github.com/eclipse-zenoh/zenoh/pull/566, we can consider + // removing these flags since with tokio, zenoh can better manage the threads it spins + // with the help of thread pools. + threads: 1, }, /// Configure the zenoh RX parameters of a link rx: { diff --git a/zenoh_c_vendor/CMakeLists.txt b/zenoh_c_vendor/CMakeLists.txt index 2240ba87..2b3ebdf4 100644 --- a/zenoh_c_vendor/CMakeLists.txt +++ b/zenoh_c_vendor/CMakeLists.txt @@ -10,9 +10,25 @@ endif() find_package(ament_cmake REQUIRED) find_package(ament_cmake_vendor_package REQUIRED) +# Disable default features and only enable tcp transport for zenoh. This reduces +# build time but more importantly allows us to limit the number of threads that +# the zenoh session can spin via the session config as well as the ASYNC_STD_THREAD_COUNT +# environment variable. Without this limit, applications with multiple zenoh sessions can +# encounter system resource errors when trying to create new threads. +# Once zenoh migrates to relying on tokio for its async runtime, +# see https://github.com/eclipse-zenoh/zenoh/pull/566, we can consider +# removing these flags since with tokio, zenoh can better manage the threads it spins +# with the help of thread pools. +# Note: We separate the two args needed for cargo with "$" and not ";" as the +# latter is a list separater in cmake and hence the string will be split into two +# when expanded. +set(ZENOHC_CARGO_FLAGS "--no-default-features$--features=zenoh/transport_tcp") + ament_vendor(zenoh_c_vendor VCS_URL https://github.com/eclipse-zenoh/zenoh-c.git VCS_VERSION 0.10.1-rc + CMAKE_ARGS + "-DZENOHC_CARGO_FLAGS=${ZENOHC_CARGO_FLAGS}" ) # set(INSTALL_DIR "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}-prefix/install")