mirror of
https://github.com/NousResearch/hermes-agent.git
synced 2026-05-11 03:31:55 +00:00
fix(gateway): cap adapter disconnect during stop
This commit is contained in:
parent
524cbabd89
commit
dccf1fb6e0
4 changed files with 79 additions and 2 deletions
|
|
@ -61,6 +61,7 @@ from hermes_cli.config import cfg_get
|
|||
_AGENT_CACHE_MAX_SIZE = 128
|
||||
_AGENT_CACHE_IDLE_TTL_SECS = 3600.0 # evict agents idle for >1h
|
||||
_PLATFORM_CONNECT_TIMEOUT_SECS_DEFAULT = 30.0
|
||||
_ADAPTER_DISCONNECT_TIMEOUT_SECS_DEFAULT = 5.0
|
||||
_TELEGRAM_COMMAND_MENTION_RE = re.compile(r"(?<![\w:/])/([A-Za-z0-9][A-Za-z0-9_-]*)")
|
||||
|
||||
|
||||
|
|
@ -1494,8 +1495,18 @@ class GatewayRunner:
|
|||
Must tolerate partial-init state and never raise, since callers
|
||||
use it inside error-handling blocks.
|
||||
"""
|
||||
timeout = self._adapter_disconnect_timeout_secs()
|
||||
try:
|
||||
await adapter.disconnect()
|
||||
if timeout <= 0:
|
||||
await adapter.disconnect()
|
||||
else:
|
||||
await asyncio.wait_for(adapter.disconnect(), timeout=timeout)
|
||||
except asyncio.TimeoutError:
|
||||
logger.warning(
|
||||
"Timed out after %.1fs while disconnecting %s adapter; continuing shutdown",
|
||||
timeout,
|
||||
platform.value if platform is not None else "adapter",
|
||||
)
|
||||
except Exception as e:
|
||||
logger.debug(
|
||||
"Defensive %s disconnect after failed connect raised: %s",
|
||||
|
|
@ -1503,6 +1514,21 @@ class GatewayRunner:
|
|||
e,
|
||||
)
|
||||
|
||||
def _adapter_disconnect_timeout_secs(self) -> float:
|
||||
"""Return the per-adapter disconnect timeout used during shutdown."""
|
||||
raw = os.getenv("HERMES_GATEWAY_ADAPTER_DISCONNECT_TIMEOUT", "").strip()
|
||||
if raw:
|
||||
try:
|
||||
timeout = float(raw)
|
||||
except ValueError:
|
||||
logger.warning(
|
||||
"Ignoring invalid HERMES_GATEWAY_ADAPTER_DISCONNECT_TIMEOUT=%r",
|
||||
raw,
|
||||
)
|
||||
else:
|
||||
return max(0.0, timeout)
|
||||
return _ADAPTER_DISCONNECT_TIMEOUT_SECS_DEFAULT
|
||||
|
||||
def _platform_connect_timeout_secs(self) -> float:
|
||||
"""Return the per-platform connect timeout used during startup/retry."""
|
||||
raw = os.getenv("HERMES_GATEWAY_PLATFORM_CONNECT_TIMEOUT", "").strip()
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue