Gateway
여러 Gateway
대부분의 설정에서는 하나의 Gateway를 사용해야 합니다. 단일 Gateway가 여러 메시징 연결과 에이전트를 처리할 수 있기 때문입니다. 더 강한 격리나 중복성(예: 구조 봇)이 필요하면 격리된 프로필/포트로 별도의 Gateway를 실행하세요.
가장 권장되는 설정
대부분의 사용자에게 가장 간단한 구조 봇 설정은 다음과 같습니다.
- 기본 프로필에서 메인 봇 유지
--profile rescue에서 구조 봇 실행- 구조 계정에는 완전히 별도의 Telegram 봇 사용
- 구조 봇은
19789같은 다른 기본 포트에서 유지
이렇게 하면 구조 봇이 메인 봇과 격리되어 기본 봇이 다운된 경우에도 디버그하거나 구성 변경을 적용할 수 있습니다. 파생된 브라우저/canvas/CDP 포트가 충돌하지 않도록 기본 포트 사이에는 최소 20개의 포트 간격을 두세요.
구조 봇 빠른 시작
다른 작업을 해야 할 강한 이유가 없다면 이것을 기본 경로로 사용하세요.
# Rescue bot (separate Telegram bot, separate profile, port 19789)
openclaw --profile rescue onboard
openclaw --profile rescue gateway install --port 19789
메인 봇이 이미 실행 중이라면 보통 이것만으로 충분합니다.
openclaw --profile rescue onboard 중에는 다음을 수행하세요.
- 별도의 Telegram 봇 토큰 사용
rescue프로필 유지- 메인 봇보다 최소 20 높은 기본 포트 사용
- 이미 직접 관리하는 워크스페이스가 없다면 기본 구조 워크스페이스 수락
온보딩이 이미 구조 서비스를 설치했다면 마지막
gateway install은 필요하지 않습니다.
이 방식이 작동하는 이유
구조 봇은 자체 항목을 가지므로 독립적으로 유지됩니다.
- 프로필/구성
- 상태 디렉터리
- 워크스페이스
- 기본 포트(및 파생 포트)
- Telegram 봇 토큰
대부분의 설정에서는 구조 프로필에 완전히 별도의 Telegram 봇을 사용하세요.
- 운영자 전용으로 유지하기 쉬움
- 별도의 봇 토큰과 ID
- 메인 봇의 채널/앱 설치와 독립적
- 메인 봇이 고장 났을 때 간단한 DM 기반 복구 경로
--profile rescue onboard가 변경하는 내용
openclaw --profile rescue onboard는 일반 온보딩 흐름을 사용하지만,
모든 내용을 별도의 프로필에 씁니다.
실제로는 구조 봇이 자체 항목을 갖는다는 뜻입니다.
- 구성 파일
- 상태 디렉터리
- 워크스페이스(기본값
~/.openclaw/workspace-rescue) - 관리형 서비스 이름
그 외 프롬프트는 일반 온보딩과 동일합니다.
일반 다중 Gateway 설정
위의 구조 봇 레이아웃이 가장 쉬운 기본값이지만, 동일한 격리 패턴은 한 호스트의 모든 Gateway 쌍이나 그룹에도 적용됩니다.
더 일반적인 설정의 경우, 각 추가 Gateway에 자체 이름 있는 프로필과 자체 기본 포트를 지정하세요.
# main (default profile)
openclaw setup
openclaw gateway --port 18789
# extra gateway
openclaw --profile ops setup
openclaw --profile ops gateway --port 19789
두 Gateway 모두 이름 있는 프로필을 사용하려는 경우에도 가능합니다.
openclaw --profile main setup
openclaw --profile main gateway --port 18789
openclaw --profile ops setup
openclaw --profile ops gateway --port 19789
서비스도 같은 패턴을 따릅니다.
openclaw gateway install
openclaw --profile ops gateway install --port 19789
예비 운영자 경로가 필요하면 구조 봇 빠른 시작을 사용하세요. 서로 다른 채널, 테넌트, 워크스페이스 또는 운영 역할을 위한 여러 장기 실행 Gateway가 필요하면 일반 프로필 패턴을 사용하세요.
격리 체크리스트
Gateway 인스턴스마다 다음을 고유하게 유지하세요.
OPENCLAW_CONFIG_PATH— 인스턴스별 구성 파일OPENCLAW_STATE_DIR— 인스턴스별 세션, 자격 증명, 캐시agents.defaults.workspace— 인스턴스별 워크스페이스 루트gateway.port(또는--port) — 인스턴스별 고유 값- 파생된 브라우저/canvas/CDP 포트
이 항목들이 공유되면 구성 경합과 포트 충돌이 발생합니다.
포트 매핑(파생)
기본 포트 = gateway.port(또는 OPENCLAW_GATEWAY_PORT / --port).
- 브라우저 제어 서비스 포트 = 기본 + 2(local loopback 전용)
- canvas 호스트는 Gateway HTTP 서버에서 제공됨(
gateway.port와 같은 포트) - 브라우저 프로필 CDP 포트는
browser.controlPort + 9 .. + 108에서 자동 할당
구성이나 env에서 이 중 하나를 재정의하는 경우, 인스턴스마다 고유하게 유지해야 합니다.
브라우저/CDP 참고 사항(흔한 실수)
- 여러 인스턴스에서
browser.cdpUrl을 같은 값으로 고정하지 마세요. - 각 인스턴스에는 자체 브라우저 제어 포트와 CDP 범위(해당 Gateway 포트에서 파생)가 필요합니다.
- 명시적 CDP 포트가 필요한 경우 인스턴스별로
browser.profiles.<name>.cdpPort를 설정하세요. - 원격 Chrome:
browser.profiles.<name>.cdpUrl을 사용하세요(프로필별, 인스턴스별).
수동 env 예시
OPENCLAW_CONFIG_PATH=~/.openclaw/main.json \
OPENCLAW_STATE_DIR=~/.openclaw \
openclaw gateway --port 18789
OPENCLAW_CONFIG_PATH=~/.openclaw/rescue.json \
OPENCLAW_STATE_DIR=~/.openclaw-rescue \
openclaw gateway --port 19789
빠른 확인
openclaw gateway status --deep
openclaw --profile rescue gateway status --deep
openclaw --profile rescue gateway probe
openclaw status
openclaw --profile rescue status
openclaw --profile rescue browser status
해석:
gateway status --deep는 이전 설치에서 남은 오래된 launchd/systemd/schtasks 서비스를 찾는 데 도움이 됩니다.multiple reachable gateways detected같은gateway probe경고 텍스트는 의도적으로 둘 이상의 격리된 Gateway를 실행하는 경우에만 예상됩니다.