Быстрый старт
Как работает cron
- Cron выполняется внутри процесса Gateway (а не внутри модели).
- Определения заданий, состояние выполнения и история запусков сохраняются в общей базе данных состояния SQLite OpenClaw, поэтому перезапуски не теряют расписания.
- При обновлении выполните
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или методы RPC cron в Gateway.- Все выполнения cron создают записи фоновых задач.
- При запуске Gateway просроченные изолированные задания агентского хода перепланируются за пределы окна подключения канала, а не воспроизводятся немедленно, поэтому запуск Discord/Telegram и настройка встроенных команд остаются отзывчивыми после перезапусков.
- Одноразовые задания (
--at) по умолчанию автоматически удаляются после успешного выполнения. - Изолированные запуски cron по возможности закрывают отслеживаемые вкладки браузера и процессы для своего сеанса
cron:<jobId>после завершения запуска, чтобы отсоединенная браузерная автоматизация не оставляла осиротевшие процессы. - Изолированные запуски cron, получившие узкое разрешение на самоочистку cron, по-прежнему могут читать состояние планировщика, отфильтрованный по себе список текущего задания и историю запусков этого задания, поэтому проверки состояния и Heartbeat могут просматривать собственное расписание без получения более широкого доступа на изменение cron.
- Изолированные запуски cron также защищаются от устаревших подтверждающих ответов. Если первый результат — это лишь промежуточное обновление состояния (
on it,pulling everything togetherи похожие подсказки), а ни один дочерний запуск субагента больше не отвечает за финальный ответ, OpenClaw один раз повторно запрашивает фактический результат перед доставкой. - Изолированные запуски cron используют структурированные метаданные отказа выполнения из встроенного запуска, включая обертки node-host
UNAVAILABLE, у которых вложенное сообщение об ошибке начинается сSYSTEM_RUN_DENIEDилиINVALID_REQUEST, поэтому заблокированная команда не считается успешным запуском, а обычный текст ассистента не трактуется как отказ. - Изолированные запуски cron также считают ошибки агента на уровне запуска ошибками задания, даже если полезная нагрузка ответа не была создана, поэтому сбои модели или провайдера увеличивают счетчики ошибок и запускают уведомления о сбое, а не помечают задание как успешное.
- Когда изолированное задание агентского хода достигает
timeoutSeconds, cron прерывает базовый запуск агента и дает ему короткое окно для очистки. Если запуск не завершается штатно, очистка, принадлежащая Gateway, принудительно очищает владение сеансом этого запуска до того, как cron зафиксирует тайм-аут, поэтому ожидающая работа чата не остается за устаревшим обрабатываемым сеансом. - Если изолированный агентский ход зависает до старта исполнителя или до первого вызова модели, cron фиксирует тайм-аут с указанием фазы, например
setup timed out before runner startилиstalled before first model call (last phase: context-engine). Эти сторожевые проверки покрывают встроенные провайдеры и провайдеры на основе CLI до фактического запуска их внешнего процесса CLI и ограничиваются отдельно от длинных значенийtimeoutSeconds, чтобы сбои холодного старта, аутентификации или контекста проявлялись быстро, а не ждали полного бюджета задания. - Если вы используете системный cron или другой внешний планировщик для запуска
openclaw agent, оберните его жесткой эскалацией завершения, даже если CLI обрабатываетSIGTERM/SIGINT. Запуски через Gateway просят Gateway прервать принятые запуски; локальные и встроенные резервные запуски получают тот же сигнал прерывания. Для GNUtimeoutпредпочитайтеtimeout -k 60 600 openclaw agent ...вместо простогоtimeout 600 ...; значение-k— это страховка супервизора на случай, если процесс не сможет завершиться штатно. Для systemd-юнитов сохраняйте ту же форму: используйте стоп-сигналSIGTERMплюс окно ожидания, напримерTimeoutStopSec, перед любым окончательным завершением. Если повторная попытка повторно использует--run-id, пока исходный запуск Gateway еще активен, дубликат считается находящимся в выполнении, а не запускает второй запуск.
Согласование задач для cron сначала принадлежит среде выполнения, а во вторую очередь опирается на долговечную историю: активная задача cron остается живой, пока среда выполнения cron все еще отслеживает это задание как выполняющееся, даже если старая строка дочернего сеанса все еще существует. Когда среда выполнения перестает владеть заданием и истекает 5-минутное льготное окно, обслуживание проверяет сохраненные журналы запусков и состояние задания для соответствующего запуска
cron:<jobId>:<startedAt>. Если эта долговечная история показывает терминальный результат, реестр задач финализируется на ее основе; в противном случае обслуживание, принадлежащее Gateway, может пометить задачу как lost. Офлайн-аудит CLI может восстановиться из долговечной истории, но не считает собственный пустой набор активных заданий в процессе доказательством того, что запуск cron, принадлежащий Gateway, исчез.Типы расписаний
| Вид | Флаг CLI | Описание |
|---|---|---|
at | --at | Одноразовая временная метка (ISO 8601 или относительная, например 20m) |
every | --every | Фиксированный интервал |
cron | --cron | 5-польное или 6-польное выражение cron с необязательным --tz |
--tz America/New_York для планирования по локальному настенному времени.
Повторяющиеся выражения на начало часа автоматически распределяются с разбросом до 5 минут, чтобы снизить пики нагрузки. Используйте --exact, чтобы принудительно задать точное время, или --stagger 30s для явного окна.
День месяца и день недели используют логику OR
Выражения Cron разбираются с помощью croner. Когда поля дня месяца и дня недели оба не являются подстановочными, croner срабатывает, когда совпадает любое из полей, а не оба. Это стандартное поведение Vixie cron.+ в Croner (0 9 15 * +1) или планируйте по одному полю, а другое проверяйте в подсказке или команде задания.
Стили выполнения
| Стиль | Значение --session | Где выполняется | Лучше всего для |
|---|---|---|---|
| Основной сеанс | main | Выделенная линия пробуждения cron | Напоминания, системные события |
| Изолированный | isolated | Выделенный cron:<jobId> | Отчеты, фоновые работы |
| Текущий сеанс | current | Привязан во время создания | Повторяющаяся работа с учетом контекста |
| Пользовательский сеанс | session:custom-id | Постоянный именованный сеанс | Рабочие процессы, которые опираются на историю |
Main session vs isolated vs custom
Main session vs isolated vs custom
Задания основного сеанса ставят системное событие в очередь принадлежащей cron линии запуска и при необходимости пробуждают Heartbeat (
--wake now или --wake next-heartbeat). Они могут использовать последний контекст доставки целевого основного сеанса для ответов, но не добавляют обычные ходы cron в линию человеческого чата и не продлевают свежесть ежедневного или idle-сброса для целевого сеанса. Изолированные задания выполняют выделенный агентский ход со свежим сеансом. Пользовательские сеансы (session:xxx) сохраняют контекст между запусками, включая рабочие процессы вроде ежедневных стендапов, которые строятся на предыдущих сводках.События cron основного сеанса — это самодостаточные напоминания системных событий. Они
не включают автоматически инструкцию “Read
HEARTBEAT.md” из стандартной подсказки Heartbeat. Если повторяющееся напоминание должно обращаться к
HEARTBEAT.md, явно укажите это в тексте события cron или в
собственных инструкциях агента.What 'fresh session' means for isolated jobs
What 'fresh session' means for isolated jobs
Для изолированных заданий «свежий сеанс» означает новый идентификатор транскрипта или сеанса для каждого запуска. OpenClaw может переносить безопасные предпочтения, такие как настройки thinking/fast/verbose, метки и явно выбранные пользователем переопределения модели или аутентификации, но не наследует окружающий контекст разговора из более старой строки cron: маршрутизацию канала или группы, политику отправки или очереди, повышение прав, источник или привязку среды выполнения ACP. Используйте
current или session:<id>, когда повторяющееся задание должно намеренно строиться на том же контексте разговора.Runtime cleanup
Runtime cleanup
Для изолированных заданий завершение среды выполнения теперь включает по возможности очистку браузера для этого сеанса cron. Сбои очистки игнорируются, чтобы фактический результат cron по-прежнему имел приоритет.Изолированные запуски cron также освобождают любые встроенные экземпляры среды выполнения MCP, созданные для задания, через общий путь очистки среды выполнения. Это соответствует тому, как завершаются MCP-клиенты основного сеанса и пользовательского сеанса, поэтому изолированные задания cron не оставляют между запусками дочерние процессы stdio или долгоживущие подключения MCP.
Subagent and Discord delivery
Subagent and Discord delivery
Когда изолированные запуски cron оркестрируют субагентов, доставка также предпочитает финальный вывод потомка устаревшему промежуточному тексту родителя. Если потомки все еще выполняются, OpenClaw подавляет это частичное родительское обновление вместо его объявления.Для текстовых целей объявлений Discord OpenClaw отправляет канонический финальный текст ассистента один раз вместо повторного воспроизведения как потоковых или промежуточных текстовых полезных нагрузок, так и финального ответа. Медиа и структурированные полезные нагрузки Discord по-прежнему доставляются отдельными полезными нагрузками, чтобы вложения и компоненты не отбрасывались.
Полезные нагрузки команд
Используйте полезные нагрузки команд для детерминированных скриптов, которые должны выполняться внутри планировщика Gateway без запуска агентского хода изолированного агента с моделью. Задания команд выполняются на хосте Gateway, захватывают stdout/stderr, записывают запуск в историю cron и повторно используют те же режимы доставкиannounce, webhook и none, что и изолированные задания.
Командный cron — это поверхность операторско-административной автоматизации Gateway, а не вызов агента
tools.exec. Создание, обновление, удаление или ручной запуск заданий cron
требует operator.admin; запланированные командные запуски позже выполняются внутри
процесса Gateway как эта автоматизация, созданная администратором. Политика agent exec, такая как
tools.exec.mode, запросы подтверждения и списки разрешенных инструментов для каждого агента, регулирует
видимые модели exec-инструменты, а не полезные нагрузки командного cron.--command <shell> сохраняет argv: ["sh", "-lc", <shell>]. Используйте --command-argv '["node","scripts/report.mjs"]', когда вам нужно точное выполнение argv без разбора оболочкой. Необязательные поля --command-env KEY=VALUE, --command-input, --timeout-seconds, --no-output-timeout-seconds и --output-max-bytes управляют окружением процесса, stdin и ограничениями вывода.
Если stdout не пуст, этот текст является доставленным результатом. Если stdout пуст, а stderr не пуст, доставляется stderr. Если присутствуют оба потока, cron доставляет небольшой блок stdout: / stderr:. Нулевой код выхода записывает запуск как ok; ненулевой выход, сигнал, тайм-аут или тайм-аут без вывода записывает error и может вызвать оповещения о сбое. Команда, которая выводит только NO_REPLY, использует обычное подавление silent-token в cron и ничего не отправляет обратно в чат.
Параметры полезной нагрузки для изолированных задач
Текст запроса (обязателен для изолированного режима).
Переопределение модели; использует выбранную разрешенную модель для задачи.
Список резервных моделей для отдельной задачи, например
--fallbacks openrouter/gpt-4.1-mini,openai/gpt-5. Передайте --fallbacks "" для строгого запуска без резервных вариантов.В
cron edit удаляет переопределение резервных вариантов для отдельной задачи, чтобы задача следовала настроенному приоритету резервных вариантов. Нельзя сочетать с --fallbacks.В
cron edit удаляет переопределение модели для отдельной задачи, чтобы задача следовала обычному приоритету выбора модели cron (сохраненное переопределение cron-сессии, если задано, иначе модель агента/по умолчанию). Нельзя сочетать с --model.Переопределение уровня мышления.
Пропустить внедрение файлов начальной загрузки рабочей области.
Ограничить инструменты, которые может использовать задача, например
--tools exec,read.--model использует выбранную разрешенную модель как основную модель этой задачи. Это не то же самое, что переопределение /model в чат-сессии: настроенные цепочки резервных вариантов по-прежнему применяются, когда основная модель задачи дает сбой. Если запрошенная модель не разрешена или не может быть разрешена, cron завершает запуск явной ошибкой валидации, а не молча откатывается к выбору модели агента/по умолчанию для задачи.
Задачи cron также могут содержать fallbacks на уровне полезной нагрузки. Если они присутствуют, этот список заменяет настроенную цепочку резервных вариантов для задачи. Используйте fallbacks: [] в полезной нагрузке/API задачи, когда нужен строгий запуск cron, который пробует только выбранную модель. Если у задачи есть --model, но нет ни резервных вариантов в полезной нагрузке, ни настроенных резервных вариантов, OpenClaw передает явное пустое переопределение резервных вариантов, чтобы основная модель агента не добавлялась как скрытая дополнительная цель повтора.
Предварительные проверки локального провайдера обходят настроенные резервные варианты перед тем, как пометить запуск cron как skipped; fallbacks: [] сохраняет этот путь предварительной проверки строгим.
Приоритет выбора модели для изолированных задач:
- Переопределение модели Gmail hook (когда запуск пришел из Gmail и это переопределение разрешено)
modelв полезной нагрузке отдельной задачи- Сохраненное выбранное пользователем переопределение модели cron-сессии
- Выбор модели агента/по умолчанию
params.fastMode, изолированный cron использует его по умолчанию. Сохраненное переопределение fastMode в сессии по-прежнему имеет приоритет над конфигурацией в любом направлении. Автоматический режим использует порог params.fastAutoOnSeconds выбранной модели, если он присутствует, по умолчанию 60 секунд.
Если изолированный запуск попадает на передачу live-переключения модели, cron повторяет запуск с переключенным провайдером/моделью и сохраняет этот live-выбор для активного запуска перед повтором. Когда переключение также несет новый профиль аутентификации, cron также сохраняет переопределение этого профиля аутентификации для активного запуска. Повторы ограничены: после начальной попытки и 2 повторов переключения cron прерывается, а не зацикливается навсегда.
Перед тем как изолированный запуск cron войдет в runner агента, OpenClaw проверяет доступные локальные endpoint-адреса провайдера для настроенных провайдеров api: "ollama" и api: "openai-completions", у которых baseUrl является loopback, частной сетью или .local. Если этот endpoint недоступен, запуск записывается как skipped с понятной ошибкой провайдера/модели вместо запуска вызова модели. Результат endpoint кэшируется на 5 минут, поэтому множество наступивших задач, использующих один и тот же недоступный локальный сервер Ollama, vLLM, SGLang или LM Studio, совместно используют одну небольшую проверку вместо создания шквала запросов. Пропущенные запуски предварительной проверки провайдера не увеличивают backoff ошибок выполнения; включите failureAlert.includeSkipped, если нужны повторяющиеся уведомления о пропуске.
Доставка и вывод
| Режим | Что происходит |
|---|---|
announce | Доставляет итоговый текст цели через резервную доставку, если агент не отправил его |
webhook | Отправляет полезную нагрузку события завершения на URL методом POST |
none | Нет резервной доставки runner |
--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 чувствительны к регистру; используйте точный идентификатор комнаты или форму room:!room:server из Matrix.
Когда доставка announce использует channel: "last" или пропускает channel, цель с префиксом провайдера, например telegram:123, может выбрать канал до того, как cron откатится к истории сессии или одному настроенному каналу. Селекторами провайдера являются только префиксы, объявленные загруженным Plugin. Если delivery.channel задан явно, префикс цели должен называть того же провайдера; например, channel: "whatsapp" с to: "telegram:123" отклоняется, вместо того чтобы позволить WhatsApp интерпретировать идентификатор Telegram как номер телефона. Префиксы типа цели и сервиса, такие как channel:<id>, user:<id>, imessage:<handle> и sms:<number>, остаются синтаксисом цели, принадлежащим каналу, а не селекторами провайдера.
Для изолированных задач доставка в чат является общей. Если доступен маршрут чата, агент может использовать инструмент message, даже когда задача использует --no-deliver. Если агент отправляет сообщение в настроенную/текущую цель, OpenClaw пропускает резервный announce. В противном случае announce, webhook и none управляют только тем, что runner делает с финальным ответом после хода агента.
Когда агент создает изолированное напоминание из активного чата, OpenClaw сохраняет сохраненную live-цель доставки для резервного маршрута announce. Внутренние ключи сессии могут быть в нижнем регистре; цели доставки провайдера не реконструируются из этих ключей, когда доступен текущий контекст чата.
Неявная доставка announce использует настроенные allowlist каналов для проверки и перенаправления устаревших целей. Подтверждения из хранилища пар DM не являются получателями резервной автоматизации; задайте delivery.to или настройте запись allowFrom канала, когда запланированная задача должна проактивно отправлять в DM.
Язык вывода
Задачи cron не выводят язык ответа из канала, локали или предыдущих сообщений. Поместите правило языка в запланированное сообщение или шаблон:{{language}}, заполнены до запуска задачи. Если
вывод смешивает языки, сделайте правило явным, например: “Use Chinese
for narrative text and keep technical terms in English.”
Уведомления о сбоях следуют отдельному пути назначения:
cron.failureDestinationзадает глобальное значение по умолчанию для уведомлений о сбоях.job.delivery.failureDestinationпереопределяет его для отдельной задачи.- Если ни одно из них не задано и задача уже доставляет через
announce, уведомления о сбоях теперь откатываются к этой основной цели announce. delivery.failureDestinationподдерживается только для задачsessionTarget="isolated", если основной режим доставки неwebhook.failureAlert.includeSkipped: trueвключает для задачи или глобальной политики оповещений cron повторяющиеся оповещения о пропущенных запусках. Пропущенные запуски ведут отдельный счетчик последовательных пропусков, поэтому они не влияют на backoff ошибок выполнения.
Примеры CLI
- Одноразовое напоминание
- Повторяющаяся изолированная задача
- Переопределение модели и мышления
- Вывод Webhook
- Вывод команды
Webhooks
Gateway может предоставлять HTTP endpoint-адреса webhook для внешних триггеров. Включите в конфигурации:Аутентификация
Каждый запрос должен включать токен hook через заголовок:Authorization: Bearer <token>(рекомендуется)x-openclaw-token: <token>
POST /hooks/wake
POST /hooks/wake
POST /hooks/agent
POST /hooks/agent
Запустить ход изолированного агента:Поля:
message (обязательно), name, agentId, wakeMode, deliver, channel, to, model, fallbacks, thinking, timeoutSeconds.Сопоставленные hooks (POST /hooks/<name>)
Сопоставленные hooks (POST /hooks/<name>)
Пользовательские имена hook разрешаются через
hooks.mappings в конфигурации. Сопоставления могут преобразовывать произвольные полезные нагрузки в действия wake или agent с помощью шаблонов или преобразований кода.Интеграция Gmail PubSub
Подключите триггеры входящих Gmail к OpenClaw через Google PubSub.Предварительные требования: CLI
gcloud, gog (gogcli), включенные хуки OpenClaw, Tailscale для публичной конечной точки HTTPS.Настройка мастером (рекомендуется)
hooks.gmail, включает пресет Gmail и использует Tailscale Funnel для конечной точки push.
Автозапуск Gateway
Когда заданоhooks.enabled=true и hooks.gmail.account, Gateway запускает gog gmail watch serve при загрузке и автоматически продлевает watch. Задайте OPENCLAW_SKIP_GMAIL_WATCHER=1, чтобы отказаться.
Разовая ручная настройка
Переопределение модели Gmail
Управление заданиями
openclaw cron run <jobId> возвращается после постановки ручного запуска в очередь. Используйте --wait для хуков завершения, скриптов обслуживания или другой автоматизации, которая должна блокироваться до окончания запуска из очереди. Режим ожидания опрашивает точно возвращенный runId; он завершается с 0 при статусе ok и с ненулевым кодом при error, skipped или тайм-ауте ожидания.
Инструмент агента cron возвращает компактные сводки заданий (id, name, enabled, nextRunAtMs, scheduleKind, lastRunStatus) из cron(action: "list"); используйте cron(action: "get", jobId: "...") для полного определения одного задания. Прямые вызывающие стороны Gateway могут передать compact: true в cron.list; если опустить это поле, сохраняется существующий полный ответ с предварительным просмотром доставки.
openclaw cron create — псевдоним для openclaw cron add, а новые задания могут использовать позиционное расписание ("0 9 * * 1", "every 1h", "20m" или временную метку ISO), за которым следует позиционный промпт агента. Используйте --webhook <url> в cron add|create или cron edit, чтобы отправить payload завершенного запуска методом POST на конечную точку HTTP. Доставку Webhook нельзя сочетать с флагами доставки в чат, такими как --announce, --channel, --to, --thread-id или --account. В cron edit флаги --clear-channel, --clear-to, --clear-thread-id и --clear-account по отдельности сбрасывают эти поля маршрутизации (каждый отклоняется вместе с соответствующим флагом установки), что отличается от --no-deliver, который отключает резервную доставку runner.
Примечание о переопределении модели:
openclaw cron add|edit --model ...меняет выбранную модель задания.- Если модель разрешена, именно этот provider/model попадает в изолированный запуск агента.
- Если она не разрешена или не может быть разрешена, Cron завершает запуск с явной ошибкой валидации.
- Патчи payload API
cron.updateмогут задаватьmodel: null, чтобы очистить сохраненное переопределение модели задания. openclaw cron edit <job-id> --clear-modelочищает это переопределение из CLI (тот же эффект, что и патчmodel: null) и не может сочетаться с--model.- Настроенные цепочки fallback по-прежнему применяются, потому что
--modelдля Cron — основная модель задания, а не переопределение/modelсессии. openclaw cron add|edit --fallbacks ...задает payloadfallbacks, заменяя настроенные fallback для этого задания;--fallbacks ""отключает fallback и делает запуск строгим.openclaw cron edit <job-id> --clear-fallbacksочищает переопределение для отдельного задания.- Обычный
--modelбез явного или настроенного списка fallback не переходит к основной модели агента как к скрытой дополнительной цели повтора.
Конфигурация
maxConcurrentRuns ограничивает как плановую отправку Cron, так и выполнение изолированных ходов агента, и по умолчанию равен 8. Изолированные ходы агента Cron внутри используют выделенную очередь выполнения cron-nested, поэтому повышение этого значения позволяет независимым LLM-запускам Cron продвигаться параллельно, а не только запускать их внешние обертки Cron. Общая не-Cron очередь nested этой настройкой не расширяется.
cron.store — логический ключ хранилища и устаревший путь импорта doctor. Запустите openclaw doctor --fix, чтобы импортировать существующие JSON-хранилища в SQLite и архивировать их; будущие изменения Cron должны идти через CLI или API Gateway.
Отключить Cron: cron.enabled: false или OPENCLAW_SKIP_CRON=1.
Поведение повторных попыток
Поведение повторных попыток
Повтор для одноразового запуска: временные ошибки (лимит частоты, перегрузка, сеть, ошибка сервера) повторяются до 3 раз с экспоненциальной задержкой. Постоянные ошибки отключают задание немедленно.Повтор для регулярного запуска: экспоненциальная задержка (от 30 с до 60 мин) между повторами. Задержка сбрасывается после следующего успешного запуска.
Обслуживание
Обслуживание
cron.sessionRetention (по умолчанию 24h) удаляет устаревшие записи изолированных сессий запуска. cron.runLog.keepLines ограничивает сохраненные строки истории запусков SQLite для каждого задания; maxBytes сохраняется для совместимости конфигурации со старыми файловыми журналами запусков.Устранение неполадок
Лестница команд
Cron не срабатывает
Cron не срабатывает
- Проверьте
cron.enabledи переменную средыOPENCLAW_SKIP_CRON. - Убедитесь, что Gateway работает непрерывно.
- Для расписаний
cronпроверьте часовой пояс (--tz) относительно часового пояса хоста. reason: not-dueв выводе запуска означает, что ручной запуск был проверен командойopenclaw cron run <jobId> --due, и срок задания еще не наступил.
Cron сработал, но доставки нет
Cron сработал, но доставки нет
- Режим доставки
noneозначает, что резервная отправка runner не ожидается. Агент все еще может отправить напрямую с помощью инструментаmessage, когда доступен маршрут чата. - Отсутствующая/недействительная цель доставки (
channel/to) означает, что исходящая отправка была пропущена. - Для Matrix скопированные или устаревшие задания с приведенными к нижнему регистру ID комнаты
delivery.toмогут завершаться ошибкой, потому что ID комнат Matrix чувствительны к регистру. Измените задание на точное значение!room:serverилиroom:!room:serverиз Matrix. - Ошибки авторизации канала (
unauthorized,Forbidden) означают, что доставка была заблокирована учетными данными. - Если изолированный запуск возвращает только молчаливый токен (
NO_REPLY/no_reply), OpenClaw подавляет прямую исходящую доставку, а также подавляет резервный путь сводки из очереди, поэтому в чат ничего не публикуется. - Если агент должен сам написать пользователю, проверьте, что у задания есть пригодный маршрут (
channel: "last"с предыдущим чатом или явный канал/цель).
Cron или Heartbeat, похоже, мешает rollover в стиле /new
Cron или Heartbeat, похоже, мешает rollover в стиле /new
- Актуальность ежедневного и idle-сброса не основана на
updatedAt; см. Управление сессиями. - Пробуждения Cron, запуски Heartbeat, уведомления exec и служебные записи gateway могут обновлять строку сессии для маршрутизации/статуса, но они не продлевают
sessionStartedAtилиlastInteractionAt. - Для устаревших строк, созданных до появления этих полей, OpenClaw может восстановить
sessionStartedAtиз заголовка сессии transcript JSONL, если файл все еще доступен. Устаревшие idle-строки безlastInteractionAtиспользуют это восстановленное время начала как базовую точку idle.
Подводные камни часовых поясов
Подводные камни часовых поясов
- Cron без
--tzиспользует часовой пояс хоста gateway. - Расписания
atбез часового пояса считаются UTC. activeHoursHeartbeat использует настроенное разрешение часового пояса.
Связанные разделы
- Автоматизация — все механизмы автоматизации одним взглядом
- Фоновые задачи — журнал задач для выполнений Cron
- Heartbeat — периодические ходы основной сессии
- Часовой пояс — конфигурация часового пояса