Automation

예약된 작업

Cron은 Gateway의 내장 스케줄러입니다. 작업을 지속 저장하고, 적절한 시간에 에이전트를 깨우며, 출력을 채팅 채널 또는 webhook 엔드포인트로 다시 전달할 수 있습니다.

빠른 시작

  • 일회성 알림 추가

    bash
    openclaw cron create "2026-02-01T16:00:00Z" \  --name "Reminder" \  --session main \  --system-event "Reminder: check the cron docs draft" \  --wake now \  --delete-after-run
  • 작업 확인

    bash
    openclaw cron listopenclaw cron get <job-id>openclaw cron show <job-id>
  • 실행 기록 보기

    bash
    openclaw cron runs --id <job-id>
  • cron 작동 방식

    • Cron은 Gateway 내부 프로세스에서 실행됩니다(모델 내부가 아님).
    • 작업 정의, 런타임 상태, 실행 기록은 OpenClaw의 공유 SQLite 상태 데이터베이스에 지속 저장되므로 다시 시작해도 일정이 손실되지 않습니다.
    • 업그레이드 시 openclaw doctor --fix를 실행하여 기존 ~/.openclaw/cron/jobs.json, jobs-state.json, runs/*.jsonl 파일을 SQLite로 가져오고 .migrated 접미사로 이름을 변경합니다. 형식이 잘못된 작업 행은 런타임에서 건너뛰고 나중에 복구하거나 검토할 수 있도록 jobs-quarantine.json에 복사됩니다.
    • cron.store는 여전히 논리적 cron 저장소 키와 doctor 가져오기 경로의 이름입니다. 가져온 뒤에는 해당 JSON 파일을 편집해도 활성 cron 작업이 더 이상 변경되지 않습니다. 대신 openclaw cron add|edit|remove 또는 Gateway cron RPC 메서드를 사용하세요.
    • 모든 cron 실행은 백그라운드 작업 레코드를 생성합니다.
    • Gateway 시작 시, 기한이 지난 격리된 에이전트 턴 작업은 즉시 재생되지 않고 채널 연결 시간대 밖으로 다시 예약되므로, 다시 시작 후에도 Discord/Telegram 시작과 네이티브 명령 설정이 응답성을 유지합니다.
    • 일회성 작업(--at)은 기본적으로 성공 후 자동 삭제됩니다.
    • 격리된 cron 실행은 실행이 완료될 때 해당 cron:<jobId> 세션의 추적된 브라우저 탭/프로세스를 최선 노력으로 닫아, 분리된 브라우저 자동화가 고아 프로세스를 남기지 않도록 합니다.
    • 좁은 cron 자체 정리 권한을 받은 격리된 cron 실행은 스케줄러 상태, 자신의 현재 작업으로 자체 필터링된 목록, 해당 작업의 실행 기록을 계속 읽을 수 있으므로, 상태/Heartbeat 확인이 더 넓은 cron 변경 권한을 얻지 않고도 자체 일정을 검사할 수 있습니다.
    • 격리된 cron 실행은 오래된 확인 응답도 방지합니다. 첫 번째 결과가 단지 임시 상태 업데이트(on it, pulling everything together 및 유사한 힌트)이고 최종 답변을 담당하는 하위 subagent 실행이 더 이상 없으면, OpenClaw는 전달 전에 실제 결과를 한 번 다시 요청합니다.
    • 격리된 cron 실행은 임베디드 실행의 구조화된 실행 거부 메타데이터를 사용합니다. 여기에는 중첩된 오류 메시지가 SYSTEM_RUN_DENIED 또는 INVALID_REQUEST로 시작하는 node-host UNAVAILABLE 래퍼가 포함되므로, 차단된 명령이 정상 실행으로 보고되지 않으며 일반 assistant 문장은 거부로 취급되지 않습니다.
    • 격리된 cron 실행은 응답 페이로드가 생성되지 않은 경우에도 실행 수준의 에이전트 실패를 작업 오류로 처리하므로, 모델/프로바이더 실패는 오류 카운터를 증가시키고 작업을 성공으로 정리하는 대신 실패 알림을 트리거합니다.
    • 격리된 에이전트 턴 작업이 timeoutSeconds에 도달하면 cron은 기본 에이전트 실행을 중단하고 짧은 정리 시간을 부여합니다. 실행이 비워지지 않으면 Gateway 소유 정리가 cron이 타임아웃을 기록하기 전에 해당 실행의 세션 소유권을 강제로 해제하므로, 대기 중인 채팅 작업이 오래된 처리 세션 뒤에 남지 않습니다.
    • 격리된 에이전트 턴이 러너 시작 전이나 첫 모델 호출 전에 멈추면 cron은 setup timed out before runner start 또는 stalled before first model call (last phase: context-engine) 같은 단계별 타임아웃을 기록합니다. 이러한 watchdog은 외부 CLI 프로세스가 실제로 시작되기 전의 임베디드 프로바이더와 CLI 기반 프로바이더를 커버하며, 긴 timeoutSeconds 값과 독립적으로 제한되어 콜드 스타트/인증/컨텍스트 실패가 전체 작업 예산을 기다리지 않고 빠르게 드러나도록 합니다.
    • 시스템 cron 또는 다른 외부 스케줄러로 openclaw agent를 실행하는 경우, CLI가 SIGTERM/SIGINT를 처리하더라도 하드 킬 에스컬레이션으로 감싸세요. Gateway 기반 실행은 Gateway에 수락된 실행 중단을 요청하며, 로컬 및 임베디드 폴백 실행은 동일한 중단 신호를 받습니다. GNU timeout의 경우 일반 timeout 600 ...보다 timeout -k 60 600 openclaw agent ...를 선호하세요. -k 값은 프로세스가 비워지지 않을 때의 supervisor 백스톱입니다. systemd 유닛의 경우 최종 kill 전에 TimeoutStopSec 같은 유예 시간을 두고 SIGTERM 중지 신호를 사용하는 동일한 형태를 유지하세요. 원래 Gateway 실행이 아직 활성 상태인 동안 재시도가 --run-id를 재사용하면, 두 번째 실행을 시작하는 대신 중복 실행이 진행 중으로 보고됩니다.

    일정 유형

    종류 CLI 플래그 설명
    at --at 일회성 타임스탬프(ISO 8601 또는 20m 같은 상대 시간)
    every --every 고정 간격
    cron --cron 선택적 --tz가 있는 5필드 또는 6필드 cron 표현식

    시간대가 없는 타임스탬프는 UTC로 취급됩니다. 로컬 벽시계 일정에는 --tz America/New_York를 추가하세요.

    매시 정각 반복 표현식은 부하 급증을 줄이기 위해 최대 5분까지 자동으로 분산됩니다. 정확한 타이밍을 강제하려면 --exact를, 명시적 창을 지정하려면 --stagger 30s를 사용하세요.

    월의 일자와 요일은 OR 논리를 사용합니다

    Cron 표현식은 croner로 파싱됩니다. 월의 일자 필드와 요일 필드가 모두 와일드카드가 아닌 경우, croner는 둘 중 하나의 필드가 일치하면 매치합니다. 둘 다 일치해야 하는 것은 아닙니다. 이는 표준 Vixie cron 동작입니다.

    Code
    # Intended: "9 AM on the 15th, only if it's a Monday"# Actual:   "9 AM on every 15th, AND 9 AM on every Monday"0 9 15 * 1

    이는 월 0~1회 대신 월 약 5~6회 실행됩니다. OpenClaw는 여기서 Croner의 기본 OR 동작을 사용합니다. 두 조건을 모두 요구하려면 Croner의 + 요일 수정자(0 9 15 * +1)를 사용하거나, 한 필드로 예약하고 다른 조건은 작업의 프롬프트나 명령에서 가드하세요.

    실행 스타일

    스타일 --session 실행 위치 적합한 용도
    메인 세션 main 전용 cron 깨우기 레인 알림, 시스템 이벤트
    격리 isolated 전용 cron:<jobId> 보고서, 백그라운드 잡무
    현재 세션 current 생성 시점에 바인딩됨 컨텍스트 인식 반복 작업
    사용자 지정 세션 session:custom-id 지속 명명 세션 기록을 기반으로 누적되는 워크플로
    메인 세션 vs 격리 vs 사용자 지정

    메인 세션 작업은 시스템 이벤트를 cron 소유 실행 레인에 큐잉하고 선택적으로 Heartbeat를 깨웁니다(--wake now 또는 --wake next-heartbeat). 응답에는 대상 메인 세션의 마지막 전달 컨텍스트를 사용할 수 있지만, 일상적인 cron 턴을 사람 채팅 레인에 추가하지 않고 대상 세션의 일일/유휴 재설정 freshness를 연장하지 않습니다. 격리 작업은 새 세션으로 전용 에이전트 턴을 실행합니다. 사용자 지정 세션(session:xxx)은 실행 간 컨텍스트를 지속 저장하여 이전 요약을 기반으로 하는 일일 스탠드업 같은 워크플로를 가능하게 합니다.

    메인 세션 cron 이벤트는 자체 완결적인 시스템 이벤트 알림입니다. 기본 Heartbeat 프롬프트의 "Read HEARTBEAT.md" 지침을 자동으로 포함하지 않습니다. 반복 알림이 HEARTBEAT.md를 참조해야 한다면, cron 이벤트 텍스트나 에이전트 자체 지침에 이를 명시적으로 적으세요.

    격리된 작업에서 '새 세션'의 의미

    격리된 작업에서 "새 세션"은 각 실행마다 새 transcript/session id를 의미합니다. OpenClaw는 thinking/fast/verbose 설정, 레이블, 명시적으로 사용자가 선택한 모델/인증 오버라이드 같은 안전한 선호사항은 전달할 수 있지만, 오래된 cron 행의 주변 대화 컨텍스트는 상속하지 않습니다. 채널/그룹 라우팅, 전송 또는 큐 정책, 권한 상승, origin, ACP 런타임 바인딩이 여기에 해당합니다. 반복 작업이 의도적으로 같은 대화 컨텍스트를 기반으로 해야 한다면 current 또는 session:<id>를 사용하세요.

    런타임 정리

    격리된 작업의 경우 런타임 종료에는 이제 해당 cron 세션에 대한 최선 노력 브라우저 정리가 포함됩니다. 정리 실패는 무시되므로 실제 cron 결과가 여전히 우선합니다.

    격리된 cron 실행은 또한 공유 런타임 정리 경로를 통해 작업용으로 생성된 모든 번들 MCP 런타임 인스턴스를 폐기합니다. 이는 메인 세션 및 사용자 지정 세션 MCP 클라이언트가 종료되는 방식과 일치하므로, 격리된 cron 작업이 실행 간 stdio 자식 프로세스나 장기 지속 MCP 연결을 누수하지 않습니다.

    Subagent 및 Discord 전달

    격리된 cron 실행이 subagent를 오케스트레이션할 때 전달도 오래된 부모 임시 텍스트보다 최종 하위 출력물을 선호합니다. 하위 실행이 아직 실행 중이면 OpenClaw는 해당 부분적인 부모 업데이트를 알리는 대신 억제합니다.

    텍스트 전용 Discord announce 대상의 경우 OpenClaw는 스트리밍/중간 텍스트 페이로드와 최종 답변을 모두 재생하지 않고 표준 최종 assistant 텍스트를 한 번 보냅니다. 미디어와 구조화된 Discord 페이로드는 첨부파일과 컴포넌트가 누락되지 않도록 여전히 별도 페이로드로 전달됩니다.

    명령 페이로드

    모델 기반 격리 에이전트 턴을 시작하지 않고 Gateway 스케줄러 내부에서 실행되어야 하는 결정적 스크립트에는 명령 페이로드를 사용하세요. 명령 작업은 Gateway 호스트에서 실행되고, stdout/stderr를 캡처하며, 실행을 cron 기록에 저장하고, 격리된 작업과 동일한 announce, webhook, none 전달 모드를 재사용합니다.

    bash
    openclaw cron create "*/15 * * * *" \  --name "Queue depth probe" \  --command "scripts/check-queue.sh" \  --command-cwd "/srv/app" \  --announce \  --channel telegram \  --to "-1001234567890"

    --command <shell>argv: ["sh", "-lc", <shell>]을 저장합니다. 셸 파싱 없이 정확한 argv 실행을 원하면 --command-argv '["node","scripts/report.mjs"]'를 사용하세요. 선택적 --command-env KEY=VALUE, --command-input, --timeout-seconds, --no-output-timeout-seconds, --output-max-bytes 필드는 프로세스 환경, stdin, 출력 한계를 제어합니다.

    stdout이 비어 있지 않으면 해당 텍스트가 전달된 결과입니다. stdout이 비어 있고 stderr가 비어 있지 않으면 stderr가 전달됩니다. 두 스트림이 모두 있으면 cron은 작은 stdout: / stderr: 블록을 전달합니다. 종료 코드가 0이면 실행이 ok로 기록되고, 0이 아닌 종료, 시그널, 시간 초과 또는 출력 없음 시간 초과는 error로 기록되며 실패 알림을 트리거할 수 있습니다. NO_REPLY만 출력하는 명령은 일반 cron 무음 토큰 억제를 사용하며 채팅에 아무것도 다시 게시하지 않습니다.

    격리된 작업의 페이로드 옵션

    --messagestringrequired

    프롬프트 텍스트(격리된 작업에 필수).

    --modelstring

    모델 재정의입니다. 작업에 선택된 허용 모델을 사용합니다.

    --fallbacksstring

    작업별 대체 모델 목록입니다. 예: --fallbacks openrouter/gpt-4.1-mini,openai/gpt-5. 대체 모델 없이 엄격하게 실행하려면 --fallbacks ""를 전달하세요.

    --clear-fallbacksboolean

    cron edit에서 작업별 대체 모델 재정의를 제거하여 작업이 구성된 대체 모델 우선순위를 따르게 합니다. --fallbacks와 함께 사용할 수 없습니다.

    --clear-modelboolean

    cron edit에서 작업별 모델 재정의를 제거하여 작업이 일반 cron 모델 선택 우선순위(설정된 경우 저장된 cron 세션 재정의, 그렇지 않으면 에이전트/기본 모델)를 따르게 합니다. --model과 함께 사용할 수 없습니다.

    --thinkingstring

    사고 수준 재정의입니다.

    --clear-thinkingboolean

    cron edit에서 작업별 사고 재정의를 제거하여 작업이 일반 cron 사고 우선순위를 따르게 합니다. --thinking과 함께 사용할 수 없습니다.

    --light-contextboolean

    워크스페이스 부트스트랩 파일 주입을 건너뜁니다.

    --toolsstring

    작업이 사용할 수 있는 도구를 제한합니다. 예: --tools exec,read.

    --model은 선택된 허용 모델을 해당 작업의 기본 모델로 사용합니다. 이는 채팅 세션 /model 재정의와 같지 않습니다. 작업 기본 모델이 실패하면 구성된 대체 체인이 계속 적용됩니다. 요청한 모델이 허용되지 않았거나 확인할 수 없으면 cron은 작업의 에이전트/기본 모델 선택으로 조용히 대체하지 않고 명시적 검증 오류로 실행을 실패시킵니다.

    Cron 작업은 페이로드 수준 fallbacks도 포함할 수 있습니다. 존재하는 경우 해당 목록은 작업에 대해 구성된 대체 체인을 대체합니다. 선택한 모델만 시도하는 엄격한 cron 실행을 원하면 작업 페이로드/API에서 fallbacks: []를 사용하세요. 작업에 --model이 있지만 페이로드나 구성된 대체 모델이 없으면 OpenClaw는 명시적인 빈 대체 재정의를 전달하여 에이전트 기본 모델이 숨겨진 추가 재시도 대상으로 추가되지 않게 합니다.

    로컬 제공자 사전 점검은 cron 실행을 skipped로 표시하기 전에 구성된 대체 모델을 순회합니다. fallbacks: []는 해당 사전 점검 경로를 엄격하게 유지합니다.

    격리된 작업의 모델 선택 우선순위는 다음과 같습니다.

    1. Gmail 훅 모델 재정의(실행이 Gmail에서 왔고 해당 재정의가 허용된 경우)
    2. 작업별 페이로드 model
    3. 사용자가 선택하여 저장된 cron 세션 모델 재정의
    4. 에이전트/기본 모델 선택

    빠른 모드도 확인된 실시간 선택을 따릅니다. 선택된 모델 구성에 params.fastMode가 있으면 격리된 cron은 기본적으로 이를 사용합니다. 저장된 세션 fastMode 재정의는 어느 방향이든 구성보다 여전히 우선합니다. 자동 모드는 선택된 모델의 params.fastAutoOnSeconds 컷오프가 있으면 이를 사용하고, 기본값은 60초입니다.

    격리된 실행이 실시간 모델 전환 핸드오프에 도달하면 cron은 전환된 제공자/모델로 다시 시도하고, 재시도 전에 활성 실행에 대해 해당 실시간 선택을 유지합니다. 전환에 새 인증 프로필도 포함된 경우 cron은 활성 실행에 대해 해당 인증 프로필 재정의도 유지합니다. 재시도는 제한됩니다. 최초 시도에 더해 전환 재시도 2회 후에는 cron이 무한 루프 대신 중단합니다.

    격리된 cron 실행이 에이전트 러너에 들어가기 전에 OpenClaw는 baseUrl이 loopback, 사설 네트워크 또는 .local인 구성된 api: "ollama"api: "openai-completions" 제공자에 대해 도달 가능한 로컬 제공자 엔드포인트를 확인합니다. 해당 엔드포인트가 다운되어 있으면 실행은 모델 호출을 시작하는 대신 명확한 제공자/모델 오류와 함께 skipped로 기록됩니다. 엔드포인트 결과는 5분 동안 캐시되므로, 동일하게 죽은 로컬 Ollama, vLLM, SGLang 또는 LM Studio 서버를 사용하는 많은 만기 작업은 요청 폭주를 만드는 대신 하나의 작은 프로브를 공유합니다. 제공자 사전 점검으로 건너뛴 실행은 실행 오류 백오프를 증가시키지 않습니다. 반복적인 건너뜀 알림을 원하면 failureAlert.includeSkipped를 활성화하세요.

    전달 및 출력

    모드 발생하는 일
    announce 에이전트가 전송하지 않은 경우 최종 텍스트를 대상에 대체 전달합니다
    webhook 완료 이벤트 페이로드를 URL에 POST합니다
    none 러너 대체 전달 없음

    채널 전달에는 --announce --channel telegram --to "-1001234567890"를 사용하세요. Telegram 포럼 주제에는 -1001234567890:topic:123을 사용하세요. OpenClaw는 Telegram 소유의 -1001234567890:123 축약형도 허용합니다. 직접 RPC/config 호출자는 delivery.threadId를 문자열 또는 숫자로 전달할 수 있습니다. Slack/Discord/Mattermost 대상은 명시적 접두사(channel:<id>, user:<id>)를 사용해야 합니다. Matrix 방 ID는 대소문자를 구분합니다. 정확한 방 ID 또는 Matrix의 room:!room:server 형식을 사용하세요.

    announce 전달에서 channel: "last"를 사용하거나 channel을 생략하면 telegram:123 같은 제공자 접두사 대상이 cron이 세션 기록 또는 하나의 구성된 채널로 대체하기 전에 채널을 선택할 수 있습니다. 로드된 Plugin이 알리는 접두사만 제공자 선택자입니다. delivery.channel이 명시적이면 대상 접두사는 같은 제공자를 명명해야 합니다. 예를 들어 channel: "whatsapp"to: "telegram:123"는 WhatsApp이 Telegram ID를 전화번호로 해석하게 두는 대신 거부됩니다. channel:<id>, user:<id>, imessage:<handle>, sms:<number> 같은 대상 종류 및 서비스 접두사는 제공자 선택자가 아니라 채널 소유 대상 구문으로 남습니다.

    격리된 작업의 경우 채팅 전달은 공유됩니다. 채팅 경로를 사용할 수 있으면 작업이 --no-deliver를 사용하더라도 에이전트는 message 도구를 사용할 수 있습니다. 에이전트가 구성된/현재 대상으로 보내면 OpenClaw는 대체 announce를 건너뜁니다. 그렇지 않으면 announce, webhook, none은 에이전트 턴 이후 러너가 최종 응답을 어떻게 처리할지만 제어합니다.

    에이전트가 활성 채팅에서 격리된 알림을 만들면 OpenClaw는 대체 announce 경로를 위해 보존된 실시간 전달 대상을 저장합니다. 내부 세션 키는 소문자일 수 있습니다. 현재 채팅 컨텍스트를 사용할 수 있을 때 제공자 전달 대상은 해당 키에서 재구성되지 않습니다.

    암시적 announce 전달은 구성된 채널 허용 목록을 사용하여 오래된 대상을 검증하고 다시 라우팅합니다. DM 페어링 저장소 승인은 대체 자동화 수신자가 아닙니다. 예약된 작업이 DM으로 능동적으로 보내야 하면 delivery.to를 설정하거나 채널 allowFrom 항목을 구성하세요.

    출력 언어

    Cron 작업은 채널, 로케일 또는 이전 메시지에서 응답 언어를 추론하지 않습니다. 예약된 메시지 또는 템플릿에 언어 규칙을 넣으세요.

    bash
    openclaw cron edit <jobId> \  --message "업데이트를 요약하세요. 중국어로 응답하고 URL, 코드, 제품 이름은 변경하지 마세요."

    템플릿 파일의 경우 렌더링된 프롬프트에 언어 지침을 유지하고 작업 실행 전에 {{language}} 같은 플레이스홀더가 채워졌는지 확인하세요. 출력이 언어를 섞는 경우 규칙을 명시적으로 작성하세요. 예: "서술 텍스트에는 중국어를 사용하고 기술 용어는 영어로 유지하세요."

    실패 알림은 별도의 대상 경로를 따릅니다.

    • cron.failureDestination은 실패 알림의 전역 기본값을 설정합니다.
    • job.delivery.failureDestination은 작업별로 이를 재정의합니다.
    • 둘 다 설정되지 않았고 작업이 이미 announce를 통해 전달하는 경우, 실패 알림은 이제 해당 기본 announce 대상으로 대체됩니다.
    • delivery.failureDestination은 기본 전달 모드가 webhook인 경우를 제외하고 sessionTarget="isolated" 작업에서만 지원됩니다.
    • failureAlert.includeSkipped: true는 작업 또는 전역 cron 알림 정책이 반복된 건너뜀 실행 알림을 받도록 선택합니다. 건너뛴 실행은 별도의 연속 건너뜀 카운터를 유지하므로 실행 오류 백오프에 영향을 주지 않습니다.

    CLI 예시

    일회성 알림

    bash
    openclaw cron add \  --name "Calendar check" \  --at "20m" \  --session main \  --system-event "Next heartbeat: check calendar." \  --wake now

    반복 격리 작업

    bash
    openclaw cron create "0 7 * * *" \  "Summarize overnight updates." \  --name "Morning brief" \  --tz "America/Los_Angeles" \  --session isolated \  --announce \  --channel slack \  --to "channel:C1234567890"

    모델 및 사고 재정의

    bash
    openclaw cron add \  --name "Deep analysis" \  --cron "0 6 * * 1" \  --tz "America/Los_Angeles" \  --session isolated \  --message "Weekly deep analysis of project progress." \  --model "opus" \  --thinking high \  --announce

    Webhook 출력

    bash
    openclaw cron create "0 18 * * 1-5" \  "Summarize today's deploys as JSON." \  --name "Deploy digest" \  --webhook "https://example.invalid/openclaw/cron"

    명령 출력

    bash
    openclaw cron create "*/15 * * * *" \  --name "Queue depth probe" \  --command "scripts/check-queue.sh" \  --command-cwd "/srv/app" \  --announce \  --channel telegram \  --to "-1001234567890"

    Webhook

    Gateway는 외부 트리거용 HTTP Webhook 엔드포인트를 노출할 수 있습니다. config에서 활성화하세요.

    json5
    {  hooks: {    enabled: true,    token: "shared-secret",    path: "/hooks",  },}

    인증

    모든 요청은 헤더를 통해 훅 토큰을 포함해야 합니다.

    • Authorization: Bearer <token>(권장)
    • x-openclaw-token: <token>

    쿼리 문자열 토큰은 거부됩니다.

    POST /hooks/wake

    기본 세션에 시스템 이벤트를 큐에 넣습니다.

    bash
    curl -X POST http://127.0.0.1:18789/hooks/wake \  -H 'Authorization: Bearer SECRET' \  -H 'Content-Type: application/json' \  -d '{"text":"New email received","mode":"now"}'
    textstringrequired

    이벤트 설명입니다.

    modestringdefault: now

    now 또는 next-heartbeat.

    POST /hooks/agent

    격리된 에이전트 턴을 실행합니다.

    bash
    curl -X POST http://127.0.0.1:18789/hooks/agent \  -H 'Authorization: Bearer SECRET' \  -H 'Content-Type: application/json' \  -d '{"message":"Summarize inbox","name":"Email","model":"openai/gpt-5.4"}'

    필드: message(필수), name, agentId, wakeMode, deliver, channel, to, model, fallbacks, thinking, timeoutSeconds.

    OPENCLAW_DOCS_MARKER:accordionOpen:IHRpdGxlPSLrp6TtlZHrkJwg7ZuFKFBPU1QgL2hvb2tzLzxuYW1l )"> 사용자 지정 훅 이름은 config의 hooks.mappings를 통해 확인됩니다. 매핑은 템플릿 또는 코드 변환으로 임의의 페이로드를 wake 또는 agent 작업으로 변환할 수 있습니다.

    Gmail PubSub 통합

    Google PubSub을 통해 Gmail 받은편지함 트리거를 OpenClaw에 연결합니다.

    마법사 설정(권장)

    bash
    openclaw webhooks gmail setup --account openclaw@gmail.com

    이 명령은 hooks.gmail 구성을 작성하고, Gmail 프리셋을 활성화하며, 푸시 엔드포인트에 Tailscale Funnel을 사용합니다.

    Gateway 자동 시작

    hooks.enabled=true이고 hooks.gmail.account가 설정되어 있으면 Gateway는 부팅 시 gog gmail watch serve를 시작하고 watch를 자동 갱신합니다. 사용하지 않으려면 OPENCLAW_SKIP_GMAIL_WATCHER=1을 설정하세요.

    수동 일회성 설정

  • GCP 프로젝트 선택

    gog에서 사용하는 OAuth 클라이언트를 소유한 GCP 프로젝트를 선택합니다.

    bash
    gcloud auth logingcloud config set project <project-id>gcloud services enable gmail.googleapis.com pubsub.googleapis.com
  • 주제 생성 및 Gmail 푸시 접근 권한 부여

    bash
    gcloud pubsub topics create gog-gmail-watchgcloud pubsub topics add-iam-policy-binding gog-gmail-watch \  --member=serviceAccount:gmail-api-push@system.gserviceaccount.com \  --role=roles/pubsub.publisher
  • watch 시작

    bash
    gog gmail watch start \  --account openclaw@gmail.com \  --label INBOX \  --topic projects/<project-id>/topics/gog-gmail-watch
  • Gmail 모델 재정의

    json5
    {  hooks: {    gmail: {      model: "openrouter/meta-llama/llama-3.3-70b-instruct:free",      thinking: "off",    },  },}

    작업 관리

    bash
    # 모든 작업 나열openclaw cron list # 저장된 작업 하나를 JSON으로 가져오기openclaw cron get <jobId> # 확인된 전달 경로를 포함해 작업 하나 표시openclaw cron show <jobId> # 작업 편집openclaw cron edit <jobId> --message "Updated prompt" --model "opus" # 지금 작업 강제 실행openclaw cron run <jobId> # 지금 작업을 강제 실행하고 종료 상태를 기다리기openclaw cron run <jobId> --wait --wait-timeout 10m --poll-interval 2s # 기한이 된 경우에만 실행openclaw cron run <jobId> --due # 실행 기록 보기openclaw cron runs --id <jobId> --limit 50 # 정확한 실행 하나 보기openclaw cron runs --id <jobId> --run-id <runId> # 작업 삭제openclaw cron remove <jobId> # 에이전트 선택(다중 에이전트 설정)openclaw cron create "0 6 * * *" "Check ops queue" --name "Ops sweep" --session isolated --agent opsopenclaw cron edit <jobId> --clear-agent

    openclaw cron run <jobId>는 수동 실행을 큐에 넣은 뒤 반환합니다. 종료 훅, 유지 관리 스크립트 또는 큐에 넣은 실행이 끝날 때까지 차단해야 하는 기타 자동화에는 --wait를 사용하세요. 대기 모드는 반환된 정확한 runId를 폴링합니다. 상태가 ok이면 0으로 종료하고, error, skipped 또는 대기 시간 초과이면 0이 아닌 값으로 종료합니다.

    에이전트 cron 도구는 cron(action: "list")에서 간결한 작업 요약(id, name, enabled, nextRunAtMs, scheduleKind, lastRunStatus)을 반환합니다. 전체 작업 정의 하나에는 cron(action: "get", jobId: "...")를 사용하세요. 직접 Gateway 호출자는 cron.listcompact: true를 전달할 수 있습니다. 이를 생략하면 전달 미리보기가 포함된 기존 전체 응답이 유지됩니다.

    openclaw cron createopenclaw cron add의 별칭이며, 새 작업은 위치 기반 스케줄("0 9 * * 1", "every 1h", "20m" 또는 ISO 타임스탬프) 뒤에 위치 기반 에이전트 프롬프트를 사용할 수 있습니다. 완료된 실행 페이로드를 HTTP 엔드포인트로 POST하려면 cron add|create 또는 cron edit에서 --webhook <url>을 사용하세요. Webhook 전달은 --announce, --channel, --to, --thread-id, --account 같은 채팅 전달 플래그와 함께 사용할 수 없습니다. cron edit에서 --clear-channel, --clear-to, --clear-thread-id, --clear-account는 해당 라우팅 필드를 각각 해제하며(각각 대응하는 설정 플래그와 함께 사용하면 거부됨), 이는 --no-deliver가 러너 폴백 전달을 비활성화하는 것과는 다릅니다.

    구성

    json5
    {  cron: {    enabled: true,    store: "~/.openclaw/cron/jobs.json",    maxConcurrentRuns: 8,    retry: {      maxAttempts: 3,      backoffMs: [60000, 120000, 300000],      retryOn: ["rate_limit", "overloaded", "network", "server_error"],    },    webhookToken: "replace-with-dedicated-webhook-token",    sessionRetention: "24h",    runLog: { maxBytes: "2mb", keepLines: 2000 },  },}

    maxConcurrentRuns는 예약된 cron 디스패치와 격리된 에이전트 턴 실행을 모두 제한하며 기본값은 8입니다. 격리된 cron 에이전트 턴은 내부적으로 큐의 전용 cron-nested 실행 레인을 사용하므로, 이 값을 높이면 독립적인 cron LLM 실행이 외부 cron 래퍼만 시작하는 대신 병렬로 진행될 수 있습니다. 공유 비 cron nested 레인은 이 설정으로 확장되지 않습니다.

    cron.store는 논리적 저장소 키이자 레거시 doctor 가져오기 경로입니다. 기존 JSON 저장소를 SQLite로 가져오고 보관하려면 openclaw doctor --fix를 실행하세요. 이후 cron 변경은 CLI 또는 Gateway API를 통해 수행해야 합니다.

    cron 비활성화: cron.enabled: false 또는 OPENCLAW_SKIP_CRON=1.

    재시도 동작

    일회성 재시도: 일시적 오류(속도 제한, 과부하, 네트워크, 서버 오류)는 지수 백오프로 최대 3번 재시도합니다. 영구 오류는 즉시 비활성화합니다.

    반복 재시도: 재시도 사이에 지수 백오프(30초~60분)를 적용합니다. 백오프는 다음 성공 실행 후 재설정됩니다.

    유지 관리

    cron.sessionRetention(기본값 24h)은 격리된 실행 세션 항목을 정리합니다. cron.runLog.keepLines는 작업별로 보존되는 SQLite 실행 기록 행 수를 제한합니다. maxBytes는 이전 파일 기반 실행 로그와의 구성 호환성을 위해 유지됩니다.

    문제 해결

    명령 단계

    bash
    openclaw statusopenclaw gateway statusopenclaw cron statusopenclaw cron listopenclaw cron runs --id <jobId> --limit 20openclaw system heartbeat lastopenclaw logs --followopenclaw doctor
    Cron이 실행되지 않음
    • cron.enabledOPENCLAW_SKIP_CRON 환경 변수를 확인하세요.
    • Gateway가 계속 실행 중인지 확인하세요.
    • cron 스케줄의 경우 시간대(--tz)와 호스트 시간대를 확인하세요.
    • 실행 출력의 reason: not-dueopenclaw cron run <jobId> --due로 수동 실행을 확인했으며 작업 기한이 아직 되지 않았음을 의미합니다.
    Cron은 실행되었지만 전달되지 않음
    • 전달 모드 none은 러너 폴백 전송이 예상되지 않음을 의미합니다. 채팅 경로를 사용할 수 있으면 에이전트는 여전히 message 도구로 직접 전송할 수 있습니다.
    • 전달 대상이 없거나 유효하지 않음(channel/to)은 아웃바운드를 건너뛰었음을 의미합니다.
    • Matrix의 경우, 복사되었거나 레거시인 작업에서 소문자로 된 delivery.to 방 ID를 사용하면 Matrix 방 ID가 대소문자를 구분하므로 실패할 수 있습니다. 작업을 Matrix의 정확한 !room:server 또는 room:!room:server 값으로 편집하세요.
    • 채널 인증 오류(unauthorized, Forbidden)는 자격 증명에 의해 전달이 차단되었음을 의미합니다.
    • 격리된 실행이 무응답 토큰(NO_REPLY / no_reply)만 반환하면 OpenClaw는 직접 아웃바운드 전달과 폴백 큐 요약 경로를 모두 억제하므로 채팅에 아무것도 게시되지 않습니다.
    • 에이전트가 사용자에게 직접 메시지를 보내야 한다면 작업에 사용할 수 있는 경로(channel: "last"와 이전 채팅, 또는 명시적 채널/대상)가 있는지 확인하세요.
    Cron 또는 Heartbeat가 /new 스타일 롤오버를 막는 것처럼 보임
    • 일일 및 유휴 재설정 최신성은 updatedAt에 기반하지 않습니다. 세션 관리를 참조하세요.
    • Cron 깨우기, Heartbeat 실행, exec 알림, Gateway 장부 관리는 라우팅/상태를 위해 세션 행을 업데이트할 수 있지만, sessionStartedAt 또는 lastInteractionAt을 연장하지 않습니다.
    • 해당 필드가 존재하기 전에 생성된 레거시 행의 경우, 파일을 아직 사용할 수 있으면 OpenClaw는 트랜스크립트 JSONL 세션 헤더에서 sessionStartedAt을 복구할 수 있습니다. lastInteractionAt이 없는 레거시 유휴 행은 복구된 시작 시간을 유휴 기준선으로 사용합니다.
    시간대 주의 사항
    • --tz가 없는 Cron은 Gateway 호스트 시간대를 사용합니다.
    • 시간대가 없는 at 스케줄은 UTC로 처리됩니다.
    • Heartbeat activeHours는 구성된 시간대 해석을 사용합니다.

    관련 항목

    Was this useful?
    On this page

    On this page