Automation and tasks

Tarefas em segundo plano

Tarefas em segundo plano rastreiam trabalho que roda fora da sua sessão de conversa principal: execuções ACP, criações de subagentes, execuções isoladas de trabalhos Cron e operações iniciadas pela CLI.

Tarefas não substituem sessões, trabalhos Cron nem Heartbeats - elas são o livro-razão de atividades que registra qual trabalho destacado aconteceu, quando e se foi bem-sucedido.

TL;DR

  • Tarefas são registros, não agendadores - Cron e Heartbeat decidem quando o trabalho roda, tarefas rastreiam o que aconteceu.
  • ACP, subagentes, todos os trabalhos Cron e operações da CLI criam tarefas. Turnos de Heartbeat não criam.
  • Cada tarefa passa por queued → running → terminal (succeeded, failed, timed_out, cancelled ou lost).
  • Tarefas Cron permanecem ativas enquanto o runtime do Cron ainda possui o trabalho; se o estado de runtime em memória desapareceu, a manutenção de tarefas primeiro verifica o histórico durável de execuções Cron antes de marcar uma tarefa como perdida.
  • A conclusão é orientada por push: trabalho destacado pode notificar diretamente ou acordar a sessão/Heartbeat solicitante quando termina, então loops de consulta de status geralmente têm o formato errado.
  • Execuções Cron isoladas e conclusões de subagentes fazem limpeza de melhor esforço das abas/processos de navegador rastreados para sua sessão filha antes da escrituração final de limpeza.
  • A entrega Cron isolada suprime respostas intermediárias obsoletas do pai enquanto trabalho de subagente descendente ainda está drenando, e prefere a saída final descendente quando ela chega antes da entrega.
  • Notificações de conclusão são entregues diretamente a um canal ou enfileiradas para o próximo Heartbeat.
  • openclaw tasks list mostra todas as tarefas; openclaw tasks audit expõe problemas.
  • Registros terminais são mantidos por 7 dias e depois podados automaticamente.

Início rápido

Listar e filtrar

# List all tasks (newest first)
openclaw tasks list

# Filter by runtime or status
openclaw tasks list --runtime acp
openclaw tasks list --status running

Inspecionar

# Show details for a specific task (by ID, run ID, or session key)
openclaw tasks show <lookup>

Cancelar e notificar

# Cancel a running task (kills the child session)
openclaw tasks cancel <lookup>

# Change notification policy for a task
openclaw tasks notify <lookup> state_changes

Auditoria e manutenção

# Run a health audit
openclaw tasks audit

# Preview or apply maintenance
openclaw tasks maintenance
openclaw tasks maintenance --apply

Fluxo de tarefas

# Inspect TaskFlow state
openclaw tasks flow list
openclaw tasks flow show <lookup>
openclaw tasks flow cancel <lookup>

O que cria uma tarefa

Origem Tipo de runtime Quando um registro de tarefa é criado Política padrão de notificação
Execuções ACP em segundo plano acp Criação de uma sessão ACP filha done_only
Orquestração de subagente subagent Criação de um subagente via sessions_spawn done_only
Trabalhos Cron (todos os tipos) cron Toda execução Cron (sessão principal e isolada) silent
Operações da CLI cli Comandos openclaw agent que rodam pelo gateway silent
Trabalhos de mídia do agente cli Execuções music_generate/video_generate apoiadas por sessão silent
Padrões de notificação para Cron e mídia

Tarefas Cron de sessão principal usam a política de notificação silent por padrão - elas criam registros para rastreamento, mas não geram notificações. Tarefas Cron isoladas também usam silent por padrão, mas são mais visíveis porque rodam em sua própria sessão.

Execuções music_generate e video_generate apoiadas por sessão também usam a política de notificação silent. Elas ainda criam registros de tarefa, mas a conclusão é devolvida à sessão original do agente como um despertar interno para que o agente possa escrever a mensagem de acompanhamento e anexar a mídia finalizada. Conclusões de grupo/canal seguem a política normal de resposta visível, então o agente usa a ferramenta de mensagem quando a entrega de origem exige isso. Se o agente de conclusão não produzir evidência de entrega por ferramenta de mensagem em uma rota somente de ferramenta, o OpenClaw envia o fallback de conclusão diretamente para o canal original em vez de deixar a mídia privada.

Proteção contra video_generate concorrente

Enquanto uma tarefa video_generate apoiada por sessão ainda está ativa, a ferramenta também atua como proteção: chamadas repetidas de video_generate nessa mesma sessão retornam o status da tarefa ativa em vez de iniciar uma segunda geração concorrente. Use action: "status" quando quiser uma consulta explícita de progresso/status do lado do agente.

O que não cria tarefas
  • Turnos de Heartbeat - sessão principal; veja Heartbeat
  • Turnos normais de chat interativo
  • Respostas diretas de /command

Ciclo de vida da tarefa

stateDiagram-v2
    [*] --> queued
    queued --> running : agent starts
    running --> succeeded : completes ok
    running --> failed : error
    running --> timed_out : timeout exceeded
    running --> cancelled : operator cancels
    queued --> lost : session gone > 5 min
    running --> lost : session gone > 5 min
Status O que significa
queued Criada, aguardando o agente iniciar
running O turno do agente está em execução ativa
succeeded Concluída com sucesso
failed Concluída com erro
timed_out Excedeu o tempo limite configurado
cancelled Interrompida pelo operador via openclaw tasks cancel
lost O runtime perdeu o estado de apoio autoritativo após um período de carência de 5 minutos

As transições acontecem automaticamente - quando a execução do agente associada termina, o status da tarefa é atualizado para corresponder.

A conclusão da execução do agente é autoritativa para registros de tarefa ativos. Uma execução destacada bem-sucedida finaliza como succeeded, erros comuns de execução finalizam como failed, e resultados de timeout ou aborto finalizam como timed_out. Se um operador já cancelou a tarefa, ou se o runtime já registrou um estado terminal mais forte, como failed, timed_out ou lost, um sinal posterior de sucesso não rebaixa esse status terminal.

lost é consciente do runtime:

  • Tarefas ACP: os metadados da sessão ACP filha de apoio desapareceram.
  • Tarefas de subagente: a sessão filha de apoio desapareceu do armazenamento do agente de destino.
  • Tarefas Cron: o runtime do Cron não rastreia mais o trabalho como ativo e o histórico durável de execuções Cron não mostra um resultado terminal para essa execução. Auditoria offline pela CLI não trata seu próprio estado vazio de runtime Cron em processo como autoridade.
  • Tarefas CLI: tarefas com um id de execução/id de origem usam o contexto de execução ativo, então linhas persistentes de sessão filha ou sessão de chat não as mantêm vivas depois que a execução pertencente ao Gateway desaparece. Tarefas CLI legadas sem identidade de execução ainda recorrem à sessão filha. Execuções openclaw agent apoiadas pelo Gateway também finalizam a partir de seu resultado de execução, então execuções concluídas não ficam ativas até que o varredor as marque como lost.

Entrega e notificações

Quando uma tarefa atinge um estado terminal, o OpenClaw notifica você. Há dois caminhos de entrega:

Entrega direta - se a tarefa tem um destino de canal (o requesterOrigin), a mensagem de conclusão vai direto para esse canal (Telegram, Discord, Slack etc.). Para conclusões de subagente, o OpenClaw também preserva o roteamento de thread/tópico vinculado quando disponível e pode preencher um to / conta ausente a partir da rota armazenada da sessão solicitante (lastChannel / lastTo / lastAccountId) antes de desistir da entrega direta.

Entrega enfileirada na sessão - se a entrega direta falhar ou nenhuma origem estiver definida, a atualização é enfileirada como um evento de sistema na sessão do solicitante e aparece no próximo Heartbeat.

Isso significa que o fluxo de trabalho usual é baseado em push: inicie o trabalho destacado uma vez e deixe o runtime acordar ou notificar você na conclusão. Consulte o estado da tarefa apenas quando precisar de depuração, intervenção ou uma auditoria explícita.

Políticas de notificação

Controle quanto você ouve sobre cada tarefa:

Política O que é entregue
done_only (padrão) Apenas estado terminal (succeeded, failed etc.) - este é o padrão
state_changes Toda transição de estado e atualização de progresso
silent Nada

Altere a política enquanto uma tarefa está em execução:

openclaw tasks notify <lookup> state_changes

Referência da CLI

tasks list
openclaw tasks list [--runtime <acp|subagent|cron|cli>] [--status <status>] [--json]

Colunas de saída: ID da tarefa, Tipo, Status, Entrega, ID da execução, Sessão filha, Resumo.

tasks show
openclaw tasks show <lookup>

O token de consulta aceita um ID de tarefa, ID de execução ou chave de sessão. Mostra o registro completo, incluindo tempos, estado de entrega, erro e resumo terminal.

tasks cancel
openclaw tasks cancel <lookup>

Para tarefas ACP e de subagente, isso encerra a sessão filha. Para tarefas rastreadas pela CLI, o cancelamento é registrado no registro de tarefas (não há um handle separado de runtime filho). O status transiciona para cancelled e uma notificação de entrega é enviada quando aplicável.

tasks notify
openclaw tasks notify <lookup> <done_only|state_changes|silent>
tasks audit
openclaw tasks audit [--json]

Expõe problemas operacionais. Achados também aparecem em openclaw status quando problemas são detectados.

Constatação Severidade Acionador
stale_queued warn Na fila por mais de 10 minutos
stale_running error Em execução por mais de 30 minutos
lost warn/error A propriedade da tarefa com respaldo do runtime desapareceu; tarefas perdidas retidas alertam até cleanupAfter, depois viram erros
delivery_failed warn A entrega falhou e a política de notificação não é silent
missing_cleanup warn Tarefa terminal sem carimbo de data/hora de limpeza
inconsistent_timestamps warn Violação da linha do tempo (por exemplo, terminou antes de começar)
manutenção de tarefas
openclaw tasks maintenance [--json]
openclaw tasks maintenance --apply [--json]

Use isso para visualizar ou aplicar reconciliação, marcação de limpeza e poda para tarefas e estado do Task Flow.

A reconciliação é ciente do runtime:

  • Tarefas ACP/subagente verificam a sessão filha que as respalda.
  • Tarefas de subagente cuja sessão filha tem uma lápide de recuperação de reinicialização são marcadas como perdidas, em vez de serem tratadas como sessões de respaldo recuperáveis.
  • Tarefas Cron verificam se o runtime de cron ainda é proprietário do trabalho e depois recuperam o status terminal dos logs de execução cron persistidos/estado do trabalho antes de recorrer a lost. Somente o processo Gateway é autoritativo para o conjunto de trabalhos ativos cron em memória; a auditoria offline da CLI usa histórico durável, mas não marca uma tarefa cron como perdida apenas porque esse Set local está vazio.
  • Tarefas CLI com identidade de execução verificam o contexto de execução ativo proprietário, não apenas linhas de sessão filha ou sessão de chat.

A limpeza de conclusão também é ciente do runtime:

  • A conclusão de subagente fecha, em melhor esforço, abas/processos de navegador rastreados para a sessão filha antes que a limpeza de anúncio continue.
  • A conclusão de cron isolado fecha, em melhor esforço, abas/processos de navegador rastreados para a sessão cron antes que a execução seja totalmente desmontada.
  • A entrega de cron isolado aguarda o acompanhamento de subagente descendente quando necessário e suprime texto obsoleto de reconhecimento do pai em vez de anunciá-lo.
  • A entrega de conclusão de subagente prefere o texto de assistente visível mais recente; se estiver vazio, recorre ao texto de ferramenta/toolResult mais recente sanitizado, e execuções de chamada de ferramenta que só atingiram timeout podem ser condensadas em um resumo curto de progresso parcial. Execuções terminais com falha anunciam o status de falha sem reproduzir o texto de resposta capturado.
  • Falhas de limpeza não mascaram o resultado real da tarefa.
tasks flow list | show | cancel
openclaw tasks flow list [--status <status>] [--json]
openclaw tasks flow show <lookup> [--json]
openclaw tasks flow cancel <lookup>

Use isso quando o Task Flow orquestrador é o que importa para você, em vez de um registro individual de tarefa em segundo plano.

Quadro de tarefas do chat (/tasks)

Use /tasks em qualquer sessão de chat para ver tarefas em segundo plano vinculadas a essa sessão. O quadro mostra tarefas ativas e concluídas recentemente com runtime, status, tempo e detalhes de progresso ou erro.

Quando a sessão atual não tem tarefas vinculadas visíveis, /tasks recorre às contagens de tarefas locais do agente para que você ainda tenha uma visão geral sem vazar detalhes de outras sessões.

Para o livro-razão completo do operador, use a CLI: openclaw tasks list.

Integração de status (pressão de tarefas)

openclaw status inclui um resumo de tarefas em uma olhada:

Tasks: 3 queued · 2 running · 1 issues

O resumo informa:

  • active - contagem de queued + running
  • failures - contagem de failed + timed_out + lost
  • byRuntime - detalhamento por acp, subagent, cron, cli

Tanto /status quanto a ferramenta session_status usam um snapshot de tarefas ciente de limpeza: tarefas ativas são priorizadas, linhas concluídas obsoletas são ocultadas, e falhas recentes só aparecem quando nenhum trabalho ativo resta. Isso mantém o cartão de status focado no que importa agora.

Armazenamento e manutenção

Onde as tarefas ficam

Registros de tarefa persistem no SQLite em:

$OPENCLAW_STATE_DIR/tasks/runs.sqlite

O registro é carregado em memória no início do gateway e sincroniza gravações com o SQLite para durabilidade entre reinicializações. O Gateway mantém o log write-ahead do SQLite limitado usando o limite padrão de autocheckpoint do SQLite mais checkpoints TRUNCATE periódicos e no encerramento.

Manutenção automática

Um varredor roda a cada 60 segundos e cuida de quatro coisas:

  • Reconciliação

    Verifica se tarefas ativas ainda têm respaldo autoritativo do runtime. Tarefas ACP/subagente usam estado de sessão filha, tarefas cron usam propriedade de trabalho ativo, e tarefas CLI com identidade de execução usam o contexto de execução proprietário. Se esse estado de respaldo desaparecer por mais de 5 minutos, a tarefa será marcada como lost.

  • Reparo de sessão ACP

    Fecha sessões ACP one-shot terminais ou órfãs pertencentes ao pai, e fecha sessões ACP persistentes terminais obsoletas ou órfãs somente quando nenhuma vinculação de conversa ativa permanece.

  • Marcação de limpeza

    Define um carimbo de data/hora cleanupAfter em tarefas terminais (endedAt + 7 dias). Durante a retenção, tarefas perdidas ainda aparecem na auditoria como avisos; depois que cleanupAfter expira ou quando os metadados de limpeza estão ausentes, elas são erros.

  • Poda

    Exclui registros após a data cleanupAfter.

  • Como as tarefas se relacionam com outros sistemas

    Tarefas e Task Flow

    Task Flow é a camada de orquestração de fluxos acima das tarefas em segundo plano. Um único fluxo pode coordenar várias tarefas ao longo de sua vida útil usando modos de sincronização gerenciados ou espelhados. Use openclaw tasks para inspecionar registros individuais de tarefas e openclaw tasks flow para inspecionar o fluxo orquestrador.

    Consulte Task Flow para obter detalhes.

    Tarefas e cron

    Uma definição de trabalho cron fica em ~/.openclaw/cron/jobs.json; o estado de execução em runtime fica ao lado dela em ~/.openclaw/cron/jobs-state.json. Toda execução cron cria um registro de tarefa - tanto em sessão principal quanto isolada. Tarefas cron de sessão principal usam a política de notificação silent por padrão, para que sejam rastreadas sem gerar notificações.

    Consulte Trabalhos Cron.

    Tarefas e heartbeat

    Execuções Heartbeat são turnos de sessão principal - elas não criam registros de tarefa. Quando uma tarefa é concluída, ela pode acionar um despertar heartbeat para que você veja o resultado rapidamente.

    Consulte Heartbeat.

    Tarefas e sessões

    Uma tarefa pode referenciar um childSessionKey (onde o trabalho executa) e um requesterSessionKey (quem a iniciou). Sessões são contexto de conversa; tarefas são rastreamento de atividade por cima disso.

    Tarefas e execuções de agente

    O runId de uma tarefa vincula à execução do agente que faz o trabalho. Eventos de ciclo de vida do agente (início, fim, erro) atualizam automaticamente o status da tarefa - você não precisa gerenciar o ciclo de vida manualmente.

    Relacionado