Skip to content

Troubleshooting

Gateway troubleshooting

This page is the deep runbook. Start at /help/troubleshooting if you want the fast triage flow first.

Command ladder

Run these first, in this order:

Terminal window
remoteclaw status
remoteclaw gateway status
remoteclaw logs --follow
remoteclaw doctor
remoteclaw channels status --probe

Expected healthy signals:

  • remoteclaw gateway status shows Runtime: running and RPC probe: ok.
  • remoteclaw doctor reports no blocking config/service issues.
  • remoteclaw channels status --probe shows connected/ready channels.

No replies

If channels are up but nothing answers, check routing and policy before reconnecting anything.

Terminal window
remoteclaw status
remoteclaw channels status --probe
remoteclaw pairing list --channel <channel> [--account <id>]
remoteclaw config get channels
remoteclaw logs --follow

Look for:

  • Pairing pending for DM senders.
  • Group mention gating (requireMention, mentionPatterns).
  • Channel/group allowlist mismatches.

Common signatures:

  • drop guild message (mention required → group message ignored until mention.
  • pairing request → sender needs approval.
  • blocked / allowlist → sender/channel was filtered by policy.

Related:

Dashboard control ui connectivity

When dashboard/control UI will not connect, validate URL, auth mode, and secure context assumptions.

Terminal window
remoteclaw gateway status
remoteclaw status
remoteclaw logs --follow
remoteclaw doctor
remoteclaw gateway status --json

Look for:

  • Correct probe URL and dashboard URL.
  • Auth mode/token mismatch between client and gateway.
  • HTTP usage where device identity is required.

Common signatures:

  • device identity required → non-secure context or missing device auth.
  • unauthorized / reconnect loop → token/password mismatch.
  • gateway connect failed: → wrong host/port/url target.

Related:

Gateway service not running

Use this when service is installed but process does not stay up.

Terminal window
remoteclaw gateway status
remoteclaw status
remoteclaw logs --follow
remoteclaw doctor
remoteclaw gateway status --deep

Look for:

  • Runtime: stopped with exit hints.
  • Service config mismatch (Config (cli) vs Config (service)).
  • Port/listener conflicts.

Common signatures:

  • Gateway start blocked: set gateway.mode=local → local gateway mode is not enabled. Fix: set gateway.mode="local" in your config (or run remoteclaw configure). If you are running RemoteClaw via Podman using the dedicated remoteclaw user, the config lives at ~remoteclaw/.remoteclaw/remoteclaw.json.
  • refusing to bind gateway ... without auth → non-loopback bind without token/password.
  • another gateway instance is already listening / EADDRINUSE → port conflict.

Related:

Channel connected messages not flowing

If channel state is connected but message flow is dead, focus on policy, permissions, and channel specific delivery rules.

Terminal window
remoteclaw channels status --probe
remoteclaw pairing list --channel <channel> [--account <id>]
remoteclaw status --deep
remoteclaw logs --follow
remoteclaw config get channels

Look for:

  • DM policy (pairing, allowlist, open, disabled).
  • Group allowlist and mention requirements.
  • Missing channel API permissions/scopes.

Common signatures:

  • mention required → message ignored by group mention policy.
  • pairing / pending approval traces → sender is not approved.
  • missing_scope, not_in_channel, Forbidden, 401/403 → channel auth/permissions issue.

Related:

Cron and heartbeat delivery

If cron or heartbeat did not run or did not deliver, verify scheduler state first, then delivery target.

Terminal window
remoteclaw cron status
remoteclaw cron list
remoteclaw cron runs --id <jobId> --limit 20
remoteclaw system heartbeat last
remoteclaw logs --follow

Look for:

  • Cron enabled and next wake present.
  • Job run history status (ok, skipped, error).
  • Heartbeat skip reasons (quiet-hours, requests-in-flight, alerts-disabled).

Common signatures:

  • cron: scheduler disabled; jobs will not run automatically → cron disabled.
  • cron: timer tick failed → scheduler tick failed; check file/log/runtime errors.
  • heartbeat skipped with reason=quiet-hours → outside active hours window.
  • heartbeat: unknown accountId → invalid account id for heartbeat delivery target.
  • heartbeat skipped with reason=dm-blocked → heartbeat target resolved to a DM-style user:<id> destination (blocked by design).

Related:

Node paired tool fails

If a node is paired but tools fail, isolate foreground, permission, and approval state.

Terminal window
remoteclaw nodes status
remoteclaw nodes describe --node <idOrNameOrIp>
remoteclaw approvals get --node <idOrNameOrIp>
remoteclaw logs --follow
remoteclaw status

Look for:

  • Node online with expected capabilities.
  • OS permission grants for camera/mic/location/screen.
  • Exec approvals and allowlist state.

Common signatures:

  • NODE_BACKGROUND_UNAVAILABLE → node app must be in foreground.
  • *_PERMISSION_REQUIRED / LOCATION_PERMISSION_REQUIRED → missing OS permission.
  • SYSTEM_RUN_DENIED: approval required → exec approval pending.
  • SYSTEM_RUN_DENIED: allowlist miss → command blocked by allowlist.

Related:

Browser tool fails

Use this when browser tool actions fail even though the gateway itself is healthy.

Terminal window
remoteclaw browser status
remoteclaw browser start --browser-profile remoteclaw
remoteclaw browser profiles
remoteclaw logs --follow
remoteclaw doctor

Look for:

  • Valid browser executable path.
  • CDP profile reachability.
  • Extension relay tab attachment for profile="chrome".

Common signatures:

  • Failed to start Chrome CDP on port → browser process failed to launch.
  • browser.executablePath not found → configured path is invalid.
  • Chrome extension relay is running, but no tab is connected → extension relay not attached.
  • Browser attachOnly is enabled ... not reachable → attach-only profile has no reachable target.

Related:

If you upgraded and something suddenly broke

Most post-upgrade breakage is config drift or stricter defaults now being enforced.

1) Auth and URL override behavior changed

Terminal window
remoteclaw gateway status
remoteclaw config get gateway.mode
remoteclaw config get gateway.remote.url
remoteclaw config get gateway.auth.mode

What to check:

  • If gateway.mode=remote, CLI calls may be targeting remote while your local service is fine.
  • Explicit --url calls do not fall back to stored credentials.

Common signatures:

  • gateway connect failed: → wrong URL target.
  • unauthorized → endpoint reachable but wrong auth.

2) Bind and auth guardrails are stricter

Terminal window
remoteclaw config get gateway.bind
remoteclaw config get gateway.auth.token
remoteclaw gateway status
remoteclaw logs --follow

What to check:

  • Non-loopback binds (lan, tailnet, custom) need auth configured.
  • Old keys like gateway.token do not replace gateway.auth.token.

Common signatures:

  • refusing to bind gateway ... without auth → bind+auth mismatch.
  • RPC probe: failed while runtime is running → gateway alive but inaccessible with current auth/url.

3) Pairing and device identity state changed

Terminal window
remoteclaw devices list
remoteclaw pairing list --channel <channel> [--account <id>]
remoteclaw logs --follow
remoteclaw doctor

What to check:

  • Pending device approvals for dashboard/nodes.
  • Pending DM pairing approvals after policy or identity changes.

Common signatures:

  • device identity required → device auth not satisfied.
  • pairing required → sender/device must be approved.

If the service config and runtime still disagree after checks, reinstall service metadata from the same profile/state directory:

Terminal window
remoteclaw gateway install --force
remoteclaw gateway restart

Related: