Gateway

Heartbeat

Heartbeat chạy các lượt tác tử định kỳ trong phiên chính để mô hình có thể nêu ra bất kỳ điều gì cần chú ý mà không gửi quá nhiều tin nhắn cho bạn.

Heartbeat là một lượt phiên chính theo lịch — nó không tạo bản ghi tác vụ nền. Bản ghi tác vụ dành cho công việc tách rời (lượt chạy ACP, tác tử con, công việc Cron cô lập).

Khắc phục sự cố: Tác vụ đã lên lịch

Bắt đầu nhanh (người mới)

  • Chọn nhịp chạy

    Giữ bật Heartbeat (mặc định là 30m, hoặc 1h cho xác thực Anthropic OAuth/token, bao gồm tái sử dụng Claude CLI) hoặc đặt nhịp chạy riêng của bạn.

  • Thêm HEARTBEAT.md (tùy chọn)

    Tạo một checklist HEARTBEAT.md nhỏ hoặc khối tasks: trong không gian làm việc của tác tử.

  • Quyết định nơi gửi tin nhắn Heartbeat

    target: "none" là mặc định; đặt target: "last" để định tuyến tới liên hệ gần nhất.

  • Tinh chỉnh tùy chọn

    • Bật gửi suy luận Heartbeat để minh bạch.
    • Dùng ngữ cảnh khởi động nhẹ nếu lượt chạy Heartbeat chỉ cần HEARTBEAT.md.
    • Bật phiên cô lập để tránh gửi toàn bộ lịch sử hội thoại trong mỗi Heartbeat.
    • Giới hạn Heartbeat trong giờ hoạt động (giờ địa phương).
  • Cấu hình ví dụ:

    {
      agents: {
        defaults: {
          heartbeat: {
            every: "30m",
            target: "last", // explicit delivery to last contact (default is "none")
            directPolicy: "allow", // default: allow direct/DM targets; set "block" to suppress
            lightContext: true, // optional: only inject HEARTBEAT.md from bootstrap files
            isolatedSession: true, // optional: fresh session each run (no conversation history)
            skipWhenBusy: true, // optional: also defer when subagent or nested lanes are busy
            // activeHours: { start: "08:00", end: "24:00" },
            // includeReasoning: true, // optional: send separate `Reasoning:` message too
          },
        },
      },
    }
    

    Mặc định

    • Khoảng thời gian: 30m (hoặc 1h khi chế độ xác thực được phát hiện là Anthropic OAuth/token, bao gồm tái sử dụng Claude CLI). Đặt agents.defaults.heartbeat.every hoặc agents.list[].heartbeat.every theo từng tác tử; dùng 0m để tắt.
    • Nội dung prompt (có thể cấu hình qua agents.defaults.heartbeat.prompt): Read HEARTBEAT.md if it exists (workspace context). Follow it strictly. Do not infer or repeat old tasks from prior chats. If nothing needs attention, reply HEARTBEAT_OK.
    • Prompt Heartbeat được gửi nguyên văn dưới dạng tin nhắn người dùng. System prompt chỉ bao gồm một mục "Heartbeat" khi Heartbeat được bật cho tác tử mặc định, và lượt chạy được đánh dấu nội bộ.
    • Khi Heartbeat bị tắt bằng 0m, các lượt chạy bình thường cũng bỏ qua HEARTBEAT.md khỏi ngữ cảnh khởi động để mô hình không thấy hướng dẫn chỉ dành cho Heartbeat.
    • Giờ hoạt động (heartbeat.activeHours) được kiểm tra theo múi giờ đã cấu hình. Ngoài khung giờ, Heartbeat bị bỏ qua cho đến tick tiếp theo nằm trong khung giờ.
    • Heartbeat tự động hoãn khi công việc Cron đang hoạt động hoặc đang xếp hàng. Đặt heartbeat.skipWhenBusy: true để hoãn thêm trên các làn bận khác (tác tử con hoặc công việc lệnh lồng nhau); điều này hữu ích cho Ollama cục bộ và các máy chủ runtime đơn bị giới hạn khác.

    Prompt Heartbeat dùng để làm gì

    Prompt mặc định được cố ý viết rộng:

    • Tác vụ nền: "Consider outstanding tasks" nhắc tác tử xem lại các việc cần theo dõi (hộp thư đến, lịch, lời nhắc, công việc đang xếp hàng) và nêu ra bất kỳ điều gì khẩn cấp.
    • Kiểm tra với con người: "Checkup sometimes on your human during day time" nhắc thỉnh thoảng gửi một tin nhắn nhẹ kiểu "bạn cần gì không?", nhưng tránh gửi quá nhiều vào ban đêm bằng cách dùng múi giờ địa phương đã cấu hình của bạn (xem Múi giờ).

    Heartbeat có thể phản ứng với tác vụ nền đã hoàn tất, nhưng bản thân một lượt chạy Heartbeat không tạo bản ghi tác vụ.

    Nếu bạn muốn Heartbeat làm một việc rất cụ thể (ví dụ: "check Gmail PubSub stats" hoặc "verify gateway health"), đặt agents.defaults.heartbeat.prompt (hoặc agents.list[].heartbeat.prompt) thành nội dung tùy chỉnh (được gửi nguyên văn).

    Hợp đồng phản hồi

    • Nếu không có gì cần chú ý, trả lời bằng HEARTBEAT_OK.
    • Các lượt chạy Heartbeat có khả năng dùng công cụ có thể thay vào đó gọi heartbeat_respond với notify: false để không có cập nhật hiển thị, hoặc notify: true cộng với notificationText để cảnh báo. Khi có, phản hồi công cụ có cấu trúc được ưu tiên hơn phương án dự phòng bằng văn bản.
    • Trong các lượt chạy Heartbeat, OpenClaw xem HEARTBEAT_OK là một xác nhận khi nó xuất hiện ở đầu hoặc cuối phản hồi. Token này bị loại bỏ và phản hồi bị bỏ nếu nội dung còn lại ackMaxChars (mặc định: 300).
    • Nếu HEARTBEAT_OK xuất hiện ở giữa phản hồi, nó không được xử lý đặc biệt.
    • Đối với cảnh báo, không bao gồm HEARTBEAT_OK; chỉ trả về văn bản cảnh báo.

    Ngoài Heartbeat, HEARTBEAT_OK lạc ở đầu/cuối tin nhắn sẽ bị loại bỏ và ghi log; tin nhắn chỉ có HEARTBEAT_OK sẽ bị bỏ.

    Cấu hình

    {
      agents: {
        defaults: {
          heartbeat: {
            every: "30m", // default: 30m (0m disables)
            model: "anthropic/claude-opus-4-6",
            includeReasoning: false, // default: false (deliver separate Reasoning: message when available)
            lightContext: false, // default: false; true keeps only HEARTBEAT.md from workspace bootstrap files
            isolatedSession: false, // default: false; true runs each heartbeat in a fresh session (no conversation history)
            skipWhenBusy: false, // default: false; true also waits for subagent/nested lanes
            target: "last", // default: none | options: last | none | <channel id> (core or plugin, e.g. "bluebubbles")
            to: "+15551234567", // optional channel-specific override
            accountId: "ops-bot", // optional multi-account channel id
            prompt: "Read HEARTBEAT.md if it exists (workspace context). Follow it strictly. Do not infer or repeat old tasks from prior chats. If nothing needs attention, reply HEARTBEAT_OK.",
            ackMaxChars: 300, // max chars allowed after HEARTBEAT_OK
          },
        },
      },
    }
    

    Phạm vi và độ ưu tiên

    • agents.defaults.heartbeat đặt hành vi Heartbeat toàn cục.
    • agents.list[].heartbeat được hợp nhất lên trên; nếu bất kỳ tác tử nào có khối heartbeat, chỉ các tác tử đó chạy Heartbeat.
    • channels.defaults.heartbeat đặt mặc định hiển thị cho tất cả kênh.
    • channels.<channel>.heartbeat ghi đè mặc định của kênh.
    • channels.<channel>.accounts.<id>.heartbeat (kênh nhiều tài khoản) ghi đè cài đặt theo kênh.

    Heartbeat theo từng tác tử

    Nếu bất kỳ mục agents.list[] nào bao gồm khối heartbeat, chỉ các tác tử đó chạy Heartbeat. Khối theo từng tác tử được hợp nhất lên trên agents.defaults.heartbeat (vì vậy bạn có thể đặt mặc định dùng chung một lần và ghi đè theo từng tác tử).

    Ví dụ: hai tác tử, chỉ tác tử thứ hai chạy Heartbeat.

    {
      agents: {
        defaults: {
          heartbeat: {
            every: "30m",
            target: "last", // explicit delivery to last contact (default is "none")
          },
        },
        list: [
          { id: "main", default: true },
          {
            id: "ops",
            heartbeat: {
              every: "1h",
              target: "whatsapp",
              to: "+15551234567",
              timeoutSeconds: 45,
              prompt: "Read HEARTBEAT.md if it exists (workspace context). Follow it strictly. Do not infer or repeat old tasks from prior chats. If nothing needs attention, reply HEARTBEAT_OK.",
            },
          },
        ],
      },
    }
    

    Ví dụ về giờ hoạt động

    Giới hạn Heartbeat trong giờ làm việc theo một múi giờ cụ thể:

    {
      agents: {
        defaults: {
          heartbeat: {
            every: "30m",
            target: "last", // explicit delivery to last contact (default is "none")
            activeHours: {
              start: "09:00",
              end: "22:00",
              timezone: "America/New_York", // optional; uses your userTimezone if set, otherwise host tz
            },
          },
        },
      },
    }
    

    Ngoài khung giờ này (trước 9 giờ sáng hoặc sau 10 giờ tối giờ miền Đông), Heartbeat bị bỏ qua. Tick đã lên lịch tiếp theo nằm trong khung giờ sẽ chạy bình thường.

    Thiết lập 24/7

    Nếu bạn muốn Heartbeat chạy cả ngày, hãy dùng một trong các mẫu sau:

    • Bỏ hẳn activeHours (không hạn chế khung giờ; đây là hành vi mặc định).
    • Đặt khung giờ cả ngày: activeHours: { start: "00:00", end: "24:00" }.

    Ví dụ nhiều tài khoản

    Dùng accountId để nhắm tới một tài khoản cụ thể trên các kênh nhiều tài khoản như Telegram:

    {
      agents: {
        list: [
          {
            id: "ops",
            heartbeat: {
              every: "1h",
              target: "telegram",
              to: "12345678:topic:42", // optional: route to a specific topic/thread
              accountId: "ops-bot",
            },
          },
        ],
      },
      channels: {
        telegram: {
          accounts: {
            "ops-bot": { botToken: "YOUR_TELEGRAM_BOT_TOKEN" },
          },
        },
      },
    }
    

    Ghi chú về trường

    everystring

    Khoảng thời gian Heartbeat (chuỗi thời lượng; đơn vị mặc định = phút).

    modelstring

    Ghi đè mô hình tùy chọn cho các lượt chạy Heartbeat (provider/model).

    includeReasoningboolean

    Khi bật, cũng gửi tin nhắn Reasoning: riêng khi có sẵn (cùng dạng với /reasoning on).

    lightContextboolean

    Khi là true, các lượt chạy Heartbeat dùng ngữ cảnh khởi động nhẹ và chỉ giữ HEARTBEAT.md từ các tệp khởi động của không gian làm việc.

    isolatedSessionboolean

    Khi là true, mỗi Heartbeat chạy trong một phiên mới không có lịch sử hội thoại trước đó. Dùng cùng mẫu cô lập như Cron sessionTarget: "isolated". Giảm mạnh chi phí token cho mỗi Heartbeat. Kết hợp với lightContext: true để tiết kiệm tối đa. Định tuyến gửi vẫn dùng ngữ cảnh phiên chính.

    skipWhenBusyboolean

    Khi là true, các lượt chạy Heartbeat hoãn trên các làn bận khác: tác tử con hoặc công việc lệnh lồng nhau. Làn Cron luôn hoãn Heartbeat, ngay cả khi không có cờ này, nên máy chủ dùng mô hình cục bộ không chạy prompt Cron và Heartbeat cùng lúc.

    sessionstring

    Khóa phiên tùy chọn cho các lượt chạy Heartbeat.

    • main (mặc định): phiên chính của tác tử.
    • Khóa phiên rõ ràng (sao chép từ openclaw sessions --json hoặc CLI phiên).
    • Định dạng khóa phiên: xem PhiênNhóm.
    targetstring
    • last: gửi tới kênh bên ngoài được dùng gần nhất.
    • kênh rõ ràng: bất kỳ kênh hoặc Plugin id nào đã cấu hình, ví dụ discord, matrix, telegram, hoặc whatsapp.
    • none (mặc định): chạy Heartbeat nhưng không gửi ra bên ngoài.
    directPolicy"allow" | "block"

    Kiểm soát hành vi gửi trực tiếp/DM. allow: cho phép gửi Heartbeat trực tiếp/DM. block: chặn gửi trực tiếp/DM (reason=dm-blocked).

    tostring

    Ghi đè người nhận tùy chọn (id theo kênh, ví dụ E.164 cho WhatsApp hoặc Telegram chat id). Đối với topic/thread của Telegram, dùng <chatId>:topic:<messageThreadId>.

    accountIdstring

    Id tài khoản tùy chọn cho kênh nhiều tài khoản. Khi target: "last", id tài khoản áp dụng cho kênh gần nhất đã phân giải nếu kênh đó hỗ trợ tài khoản; nếu không thì bị bỏ qua. Nếu id tài khoản không khớp với tài khoản đã cấu hình cho kênh đã phân giải, việc gửi sẽ bị bỏ qua.

    promptstring

    Ghi đè nội dung prompt mặc định (không hợp nhất).

    ackMaxCharsnumber

    Số ký tự tối đa được phép sau HEARTBEAT_OK trước khi phân phối.

    suppressToolErrorWarningsboolean

    Khi là true, ẩn payload cảnh báo lỗi công cụ trong các lần chạy Heartbeat.

    activeHoursobject

    Giới hạn các lần chạy Heartbeat trong một khung thời gian. Đối tượng có start (HH:MM, bao gồm; dùng 00:00 cho đầu ngày), end (HH:MM không bao gồm; cho phép 24:00 cho cuối ngày), và timezone tùy chọn.

    • Bị bỏ qua hoặc "user": dùng agents.defaults.userTimezone của bạn nếu đã đặt, nếu không thì quay về múi giờ hệ thống máy chủ.
    • "local": luôn dùng múi giờ hệ thống máy chủ.
    • Mọi mã định danh IANA (ví dụ America/New_York): được dùng trực tiếp; nếu không hợp lệ, quay về hành vi "user" ở trên.
    • startend không được bằng nhau đối với một cửa sổ hoạt động; các giá trị bằng nhau được xem là độ rộng bằng không (luôn nằm ngoài cửa sổ).
    • Ngoài cửa sổ hoạt động, Heartbeat bị bỏ qua cho đến tick tiếp theo nằm trong cửa sổ.

    Hành vi phân phối

    Session and target routing
    • Theo mặc định, Heartbeat chạy trong phiên chính của agent (agent:<id>:<mainKey>), hoặc global khi session.scope = "global". Đặt session để ghi đè sang một phiên kênh cụ thể (Discord/WhatsApp/v.v.).
    • session chỉ ảnh hưởng đến ngữ cảnh chạy; việc phân phối do targetto kiểm soát.
    • Để phân phối tới một kênh/người nhận cụ thể, đặt target + to. Với target: "last", việc phân phối dùng kênh bên ngoài gần nhất cho phiên đó.
    • Theo mặc định, các lần phân phối Heartbeat cho phép mục tiêu trực tiếp/DM. Đặt directPolicy: "block" để ẩn lượt gửi tới mục tiêu trực tiếp trong khi vẫn chạy lượt Heartbeat.
    • Nếu hàng đợi chính, lane phiên đích, lane cron, hoặc một cron job đang hoạt động đang bận, Heartbeat sẽ bị bỏ qua và thử lại sau.
    • Nếu skipWhenBusy: true, các lane subagent và lane lồng nhau cũng trì hoãn các lần chạy Heartbeat.
    • Nếu target không phân giải được đích bên ngoài nào, lượt chạy vẫn diễn ra nhưng không có tin nhắn đi nào được gửi.
    Visibility and skip behavior
    • Nếu showOk, showAlerts, và useIndicator đều bị tắt, lượt chạy sẽ bị bỏ qua ngay từ đầu với reason=alerts-disabled.
    • Nếu chỉ việc phân phối cảnh báo bị tắt, OpenClaw vẫn có thể chạy Heartbeat, cập nhật dấu thời gian tác vụ đến hạn, khôi phục dấu thời gian rảnh của phiên, và ẩn payload cảnh báo gửi ra ngoài.
    • Nếu mục tiêu Heartbeat đã phân giải hỗ trợ trạng thái đang nhập, OpenClaw hiển thị trạng thái đang nhập khi lượt chạy Heartbeat đang hoạt động. Trạng thái này dùng cùng mục tiêu mà Heartbeat sẽ gửi đầu ra trò chuyện tới, và bị tắt bởi typingMode: "never".
    Session lifecycle and audit
    • Các phản hồi chỉ dành cho Heartbeat không giữ phiên hoạt động. Siêu dữ liệu Heartbeat có thể cập nhật hàng phiên, nhưng thời hạn rảnh dùng lastInteractionAt từ tin nhắn người dùng/kênh thực gần nhất, và thời hạn hằng ngày dùng sessionStartedAt.
    • Lịch sử Control UI và WebChat ẩn các prompt Heartbeat và các xác nhận chỉ OK. Bản ghi phiên bên dưới vẫn có thể chứa các lượt đó để kiểm tra/phát lại.
    • Tác vụ nền tách rời có thể xếp hàng một sự kiện hệ thống và đánh thức Heartbeat khi phiên chính cần nhận biết nhanh điều gì đó. Lần đánh thức đó không biến lượt chạy Heartbeat thành một tác vụ nền.

    Điều khiển hiển thị

    Theo mặc định, các xác nhận HEARTBEAT_OK bị ẩn trong khi nội dung cảnh báo được phân phối. Bạn có thể điều chỉnh điều này theo từng kênh hoặc từng tài khoản:

    channels:
      defaults:
        heartbeat:
          showOk: false # Hide HEARTBEAT_OK (default)
          showAlerts: true # Show alert messages (default)
          useIndicator: true # Emit indicator events (default)
      telegram:
        heartbeat:
          showOk: true # Show OK acknowledgments on Telegram
      whatsapp:
        accounts:
          work:
            heartbeat:
              showAlerts: false # Suppress alert delivery for this account
    

    Thứ tự ưu tiên: theo tài khoản → theo kênh → mặc định kênh → mặc định tích hợp sẵn.

    Mỗi cờ làm gì

    • showOk: gửi xác nhận HEARTBEAT_OK khi model trả về phản hồi chỉ OK.
    • showAlerts: gửi nội dung cảnh báo khi model trả về phản hồi không phải OK.
    • useIndicator: phát sự kiện chỉ báo cho các bề mặt trạng thái UI.

    Nếu cả ba đều false, OpenClaw bỏ qua hoàn toàn lượt chạy Heartbeat (không gọi model).

    Ví dụ theo kênh và theo tài khoản

    channels:
      defaults:
        heartbeat:
          showOk: false
          showAlerts: true
          useIndicator: true
      slack:
        heartbeat:
          showOk: true # all Slack accounts
        accounts:
          ops:
            heartbeat:
              showAlerts: false # suppress alerts for the ops account only
      telegram:
        heartbeat:
          showOk: true
    

    Mẫu thường dùng

    Mục tiêu Cấu hình
    Hành vi mặc định (OK im lặng, bật cảnh báo) (không cần cấu hình)
    Hoàn toàn im lặng (không tin nhắn, không chỉ báo) channels.defaults.heartbeat: { showOk: false, showAlerts: false, useIndicator: false }
    Chỉ chỉ báo (không tin nhắn) channels.defaults.heartbeat: { showOk: false, showAlerts: false, useIndicator: true }
    OK chỉ trong một kênh channels.telegram.heartbeat: { showOk: true }

    HEARTBEAT.md (tùy chọn)

    Nếu tệp HEARTBEAT.md tồn tại trong workspace, prompt mặc định sẽ bảo agent đọc tệp đó. Hãy xem nó như "danh sách kiểm tra Heartbeat" của bạn: nhỏ, ổn định, và an toàn để đưa vào mỗi 30 phút.

    Trong các lượt chạy bình thường, HEARTBEAT.md chỉ được chèn khi hướng dẫn Heartbeat được bật cho agent mặc định. Tắt nhịp Heartbeat bằng 0m hoặc đặt includeSystemPromptSection: false sẽ bỏ nó khỏi ngữ cảnh bootstrap bình thường.

    Nếu HEARTBEAT.md tồn tại nhưng thực tế trống (chỉ có dòng trống và tiêu đề markdown như # Heading), OpenClaw bỏ qua lượt chạy Heartbeat để tiết kiệm lệnh gọi API. Lần bỏ qua đó được báo cáo là reason=empty-heartbeat-file. Nếu tệp bị thiếu, Heartbeat vẫn chạy và model quyết định cần làm gì.

    Giữ nó thật nhỏ (danh sách kiểm tra ngắn hoặc lời nhắc) để tránh phình prompt.

    Ví dụ HEARTBEAT.md:

    # Heartbeat checklist
    
    - Quick scan: anything urgent in inboxes?
    - If it's daytime, do a lightweight check-in if nothing else is pending.
    - If a task is blocked, write down _what is missing_ and ask Peter next time.
    

    Khối tasks:

    HEARTBEAT.md cũng hỗ trợ một khối tasks: có cấu trúc nhỏ cho các kiểm tra theo khoảng thời gian bên trong chính Heartbeat.

    Ví dụ:

    tasks:
    
    - name: inbox-triage
      interval: 30m
      prompt: "Check for urgent unread emails and flag anything time sensitive."
    - name: calendar-scan
      interval: 2h
      prompt: "Check for upcoming meetings that need prep or follow-up."
    
    # Additional instructions
    
    - Keep alerts short.
    - If nothing needs attention after all due tasks, reply HEARTBEAT_OK.
    
    Behavior
    • OpenClaw phân tích khối tasks: và kiểm tra từng tác vụ theo interval riêng của nó.
    • Chỉ các tác vụ đến hạn mới được đưa vào prompt Heartbeat cho tick đó.
    • Nếu không có tác vụ nào đến hạn, Heartbeat bị bỏ qua hoàn toàn (reason=no-tasks-due) để tránh lãng phí lệnh gọi model.
    • Nội dung không phải tác vụ trong HEARTBEAT.md được giữ nguyên và nối thêm làm ngữ cảnh bổ sung sau danh sách tác vụ đến hạn.
    • Dấu thời gian chạy gần nhất của tác vụ được lưu trong trạng thái phiên (heartbeatTaskState), nên các khoảng thời gian vẫn tồn tại qua các lần khởi động lại bình thường.
    • Dấu thời gian tác vụ chỉ được tăng sau khi một lượt chạy Heartbeat hoàn tất đường dẫn phản hồi bình thường. Các lượt chạy bị bỏ qua empty-heartbeat-file / no-tasks-due không đánh dấu tác vụ là đã hoàn tất.

    Chế độ tác vụ hữu ích khi bạn muốn một tệp Heartbeat chứa nhiều kiểm tra định kỳ mà không phải trả chi phí cho tất cả chúng ở mỗi tick.

    Agent có thể cập nhật HEARTBEAT.md không?

    Có — nếu bạn yêu cầu.

    HEARTBEAT.md chỉ là một tệp bình thường trong workspace của agent, nên bạn có thể nói với agent (trong một cuộc trò chuyện bình thường) điều gì đó như:

    • "Cập nhật HEARTBEAT.md để thêm kiểm tra lịch hằng ngày."
    • "Viết lại HEARTBEAT.md để ngắn hơn và tập trung vào các việc theo dõi hộp thư đến."

    Nếu bạn muốn việc này xảy ra chủ động, bạn cũng có thể đưa một dòng rõ ràng vào prompt Heartbeat của mình như: "Nếu danh sách kiểm tra trở nên lỗi thời, hãy cập nhật HEARTBEAT.md bằng một danh sách tốt hơn."

    Đánh thức thủ công (theo yêu cầu)

    Bạn có thể xếp hàng một sự kiện hệ thống và kích hoạt Heartbeat ngay lập tức bằng:

    openclaw system event --text "Check for urgent follow-ups" --mode now
    

    Nếu nhiều agent đã cấu hình heartbeat, một lần đánh thức thủ công sẽ chạy ngay lập tức từng Heartbeat của các agent đó.

    Dùng --mode next-heartbeat để chờ tick đã lên lịch tiếp theo.

    Phân phối reasoning (tùy chọn)

    Theo mặc định, Heartbeat chỉ phân phối payload "câu trả lời" cuối cùng.

    Nếu muốn minh bạch, bật:

    • agents.defaults.heartbeat.includeReasoning: true

    Khi được bật, Heartbeat cũng sẽ phân phối một tin nhắn riêng có tiền tố Reasoning: (cùng dạng với /reasoning on). Điều này có thể hữu ích khi agent đang quản lý nhiều phiên/codex và bạn muốn thấy vì sao nó quyết định ping bạn — nhưng nó cũng có thể làm lộ nhiều chi tiết nội bộ hơn mức bạn muốn. Nên giữ tắt trong chat nhóm.

    Nhận thức chi phí

    Heartbeat chạy các lượt agent đầy đủ. Khoảng thời gian ngắn hơn tiêu tốn nhiều token hơn. Để giảm chi phí:

    • Dùng isolatedSession: true để tránh gửi toàn bộ lịch sử hội thoại (~100K token xuống còn ~2-5K mỗi lượt chạy).
    • Dùng lightContext: true để giới hạn tệp bootstrap chỉ còn HEARTBEAT.md.
    • Đặt một model rẻ hơn (ví dụ ollama/llama3.2:1b).
    • Giữ HEARTBEAT.md nhỏ.
    • Dùng target: "none" nếu bạn chỉ muốn cập nhật trạng thái nội bộ.

    Tràn ngữ cảnh sau Heartbeat

    Nếu trước đó một Heartbeat đã để lại một phiên hiện có trên một model cục bộ nhỏ hơn, ví dụ một model Ollama với cửa sổ 32k, và lượt phiên chính tiếp theo báo tràn ngữ cảnh, hãy đặt lại model runtime của phiên về model chính đã cấu hình. Thông báo đặt lại của OpenClaw nêu rõ điều này khi model runtime gần nhất khớp với heartbeat.model đã cấu hình.

    Các Heartbeat hiện tại giữ nguyên model runtime hiện có của phiên dùng chung sau khi lượt chạy hoàn tất. Bạn vẫn có thể dùng isolatedSession: true để chạy Heartbeat trong một phiên mới, kết hợp với lightContext: true để có prompt nhỏ nhất, hoặc chọn một model Heartbeat có cửa sổ ngữ cảnh đủ lớn cho phiên dùng chung.

    Liên quan