Skip to content

Latest commit

 

History

History
1204 lines (926 loc) · 41.5 KB

File metadata and controls

1204 lines (926 loc) · 41.5 KB
PicoClaw

PicoClaw: Trợ lý AI Siêu Nhẹ viết bằng Go

Phần cứng $10 · RAM 10MB · Khởi động 1 giây · Nào, xuất phát!

Go Hardware License
Website Docs Wiki
Twitter Discord

中文 | 日本語 | Português | Tiếng Việt | Français | English


🦐 PicoClaw là trợ lý AI cá nhân siêu nhẹ, lấy cảm hứng từ nanobot, được viết lại hoàn toàn bằng Go thông qua quá trình "tự khởi tạo" (self-bootstrapping) — nơi chính AI Agent đã tự dẫn dắt toàn bộ quá trình chuyển đổi kiến trúc và tối ưu hóa mã nguồn.

⚡️ Cực kỳ nhẹ: Chạy trên phần cứng chỉ $10 với RAM <10MB. Tiết kiệm 99% bộ nhớ so với OpenClaw và rẻ hơn 98% so với Mac mini!

Caution

🚨 TUYÊN BỐ BẢO MẬT & KÊNH CHÍNH THỨC

  • KHÔNG CÓ CRYPTO: PicoClaw KHÔNG có bất kỳ token/coin chính thức nào. Mọi thông tin trên pump.fun hoặc các sàn giao dịch khác đều là LỪA ĐẢO.
  • DOMAIN CHÍNH THỨC: Website chính thức DUY NHẤTpicoclaw.io, website công ty là sipeed.com.
  • Cảnh báo: Nhiều tên miền .ai/.org/.com/.net/... đã bị bên thứ ba đăng ký, không phải của chúng tôi.
  • Cảnh báo: PicoClaw đang trong giai đoạn phát triển sớm và có thể còn các vấn đề bảo mật mạng chưa được giải quyết. Không nên triển khai lên môi trường production trước phiên bản v1.0.
  • Lưu ý: PicoClaw gần đây đã merge nhiều PR, dẫn đến bộ nhớ sử dụng có thể lớn hơn (10–20MB) ở các phiên bản mới nhất. Chúng tôi sẽ ưu tiên tối ưu tài nguyên khi bộ tính năng đã ổn định.

📢 Tin tức

2026-02-16 🎉 PicoClaw đạt 12K stars chỉ trong một tuần! Cảm ơn tất cả mọi người! PicoClaw đang phát triển nhanh hơn chúng tôi tưởng tượng. Do số lượng PR tăng cao, chúng tôi cấp thiết cần maintainer từ cộng đồng. Các vai trò tình nguyện viên và roadmap đã được công bố tại đây — rất mong đón nhận sự tham gia của bạn!

2026-02-13 🎉 PicoClaw đạt 5000 stars trong 4 ngày! Cảm ơn cộng đồng! Chúng tôi đang hoàn thiện Lộ trình dự án (Roadmap) và thiết lập Nhóm phát triển để đẩy nhanh tốc độ phát triển PicoClaw. 🚀 Kêu gọi hành động: Vui lòng gửi yêu cầu tính năng tại GitHub Discussions. Chúng tôi sẽ xem xét và ưu tiên trong cuộc họp hàng tuần.

2026-02-09 🎉 PicoClaw chính thức ra mắt! Được xây dựng trong 1 ngày để mang AI Agent đến phần cứng $10 với RAM <10MB. 🦐 PicoClaw, Lên Đường!

✨ Tính năng nổi bật

🪶 Siêu nhẹ: Bộ nhớ sử dụng <10MB — nhỏ hơn 99% so với Clawdbot (chức năng cốt lõi).

💰 Chi phí tối thiểu: Đủ hiệu quả để chạy trên phần cứng $10 — rẻ hơn 98% so với Mac mini.

⚡️ Khởi động siêu nhanh: Nhanh gấp 400 lần, khởi động trong 1 giây ngay cả trên CPU đơn nhân 0.6GHz.

🌍 Di động thực sự: Một file binary duy nhất chạy trên RISC-V, ARM, MIPS và x86. Một click là chạy!

🤖 AI tự xây dựng: Triển khai Go-native tự động — 95% mã nguồn cốt lõi được Agent tạo ra, với sự tinh chỉnh của con người.

OpenClaw NanoBot PicoClaw
Ngôn ngữ TypeScript Python Go
RAM >1GB >100MB < 10MB
Thời gian khởi động
(CPU 0.8GHz)
>500s >30s <1s
Chi phí Mac Mini $599 Hầu hết SBC Linux ~$50 Mọi bo mạch Linux
Chỉ từ $10

PicoClaw

🦾 Demo

🛠️ Quy trình trợ lý tiêu chuẩn

🧩 Lập trình Full-Stack

🗂️ Quản lý Nhật ký & Kế hoạch

🔎 Tìm kiếm Web & Học hỏi

Phát triển • Triển khai • Mở rộng Lên lịch • Tự động hóa • Ghi nhớ Khám phá • Phân tích • Xu hướng

🐜 Triển khai sáng tạo trên phần cứng tối thiểu

PicoClaw có thể triển khai trên hầu hết mọi thiết bị Linux!

  • $9.9 LicheeRV-Nano phiên bản E (Ethernet) hoặc W (WiFi6), dùng làm Trợ lý Gia đình tối giản.
  • $30~50 NanoKVM, hoặc $100 NanoKVM-Pro, dùng cho quản trị Server tự động.
  • $50 MaixCAM hoặc $100 MaixCAM2, dùng cho Giám sát thông minh.
picoclaw_detect_person.mp4

🌟 Nhiều hình thức triển khai hơn đang chờ bạn khám phá!

📦 Cài đặt

Cài đặt bằng binary biên dịch sẵn

Tải file binary cho nền tảng của bạn từ trang Release.

Cài đặt từ mã nguồn (có tính năng mới nhất, khuyên dùng cho phát triển)

git clone https://github.com/sipeed/picoclaw.git

cd picoclaw
make deps

# Build (không cần cài đặt)
make build

# Build cho nhiều nền tảng
make build-all

# Build và cài đặt
make install

🐳 Docker Compose

Bạn cũng có thể chạy PicoClaw bằng Docker Compose mà không cần cài đặt gì trên máy.

# 1. Clone repo
git clone https://github.com/sipeed/picoclaw.git
cd picoclaw

# 2. Lần chạy đầu tiên — tự tạo docker/data/config.json rồi dừng lại
docker compose -f docker/docker-compose.yml --profile gateway up
# Container hiển thị "First-run setup complete." rồi tự dừng.

# 3. Thiết lập API Key
vim docker/data/config.json   # API key của provider, bot token, v.v.

# 4. Khởi động
docker compose -f docker/docker-compose.yml --profile gateway up -d

Tip

Người dùng Docker: Theo mặc định, Gateway lắng nghe trên 127.0.0.1, không thể truy cập từ máy chủ. Nếu bạn cần truy cập các endpoint kiểm tra sức khỏe hoặc mở cổng, hãy đặt PICOCLAW_GATEWAY_HOST=0.0.0.0 trong môi trường của bạn hoặc cập nhật config.json.

# 5. Xem logs
docker compose -f docker/docker-compose.yml logs -f picoclaw-gateway

# 6. Dừng
docker compose -f docker/docker-compose.yml --profile gateway down

Chế độ Agent (chạy một lần)

# Đặt câu hỏi
docker compose -f docker/docker-compose.yml run --rm picoclaw-agent -m "2+2 bằng mấy?"

# Chế độ tương tác
docker compose -f docker/docker-compose.yml run --rm picoclaw-agent

Cập nhật

docker compose -f docker/docker-compose.yml pull
docker compose -f docker/docker-compose.yml --profile gateway up -d

🚀 Bắt đầu nhanh

Tip

Thiết lập API key trong ~/.picoclaw/config.json. Lấy API key: Volcengine (CodingPlan) (LLM) · OpenRouter (LLM) · Zhipu (LLM). Tìm kiếm web là tùy chọn — lấy Tavily API miễn phí (1000 truy vấn/tháng) hoặc Brave Search API (2000 truy vấn/tháng).

1. Khởi tạo

picoclaw onboard

2. Cấu hình (~/.picoclaw/config.json)

{
  "model_list": [
    {
      "model_name": "ark-code-latest",
      "model": "volcengine/ark-code-latest",
      "api_key": "sk-your-api-key",
      "api_base":"https://ark.cn-beijing.volces.com/api/coding/v3"
    },
    {
      "model_name": "gpt-5.4",
      "model": "openai/gpt-5.4",
      "api_key": "sk-your-openai-key",
      "request_timeout": 300,
      "api_base": "https://api.openai.com/v1"
    }
  ],
  "agents": {
    "defaults": {
      "model_name": "gpt4"
    }
  },
  "channels": {
    "telegram": {
      "enabled": true,
      "token": "YOUR_TELEGRAM_BOT_TOKEN",
      "allow_from": []
    }
  }
}

Mới: Định dạng cấu hình model_list cho phép thêm nhà cung cấp mà không cần thay đổi mã nguồn. Xem Cấu hình Mô hình để biết chi tiết. request_timeout là tùy chọn và dùng đơn vị giây. Nếu bỏ qua hoặc đặt <= 0, PicoClaw sẽ dùng timeout mặc định (120s).

3. Lấy API Key

Lưu ý: Xem config.example.json để có mẫu cấu hình đầy đủ.

4. Trò chuyện

picoclaw agent -m "Xin chào, bạn là ai?"

Vậy là xong! Bạn đã có một trợ lý AI hoạt động chỉ trong 2 phút.


💬 Tích hợp ứng dụng Chat

Trò chuyện với PicoClaw qua Telegram, Discord, DingTalk, LINE hoặc WeCom.

Kênh Mức độ thiết lập
Telegram Dễ (chỉ cần token)
Discord Dễ (bot token + intents)
QQ Dễ (AppID + AppSecret)
DingTalk Trung bình (app credentials)
LINE Trung bình (credentials + webhook URL)
WeCom AI Bot Trung bình (Token + khóa AES)
Telegram (Khuyên dùng)

1. Tạo bot

  • Mở Telegram, tìm @BotFather
  • Gửi /newbot, làm theo hướng dẫn
  • Sao chép token

2. Cấu hình

{
  "channels": {
    "telegram": {
      "enabled": true,
      "token": "YOUR_BOT_TOKEN",
      "allow_from": ["YOUR_USER_ID"]
    }
  }
}

Lấy User ID từ @userinfobot trên Telegram.

3. Chạy

picoclaw gateway
Discord

1. Tạo bot

2. Bật Intents

  • Trong phần Bot settings, bật MESSAGE CONTENT INTENT
  • (Tùy chọn) Bật SERVER MEMBERS INTENT nếu muốn dùng danh sách cho phép theo thông tin thành viên

3. Lấy User ID

  • Discord Settings → Advanced → bật Developer Mode
  • Click chuột phải vào avatar → Copy User ID

4. Cấu hình

{
  "channels": {
    "discord": {
      "enabled": true,
      "token": "YOUR_BOT_TOKEN",
      "allow_from": ["YOUR_USER_ID"]
    }
  }
}

5. Mời bot vào server

  • OAuth2 → URL Generator
  • Scopes: bot
  • Bot Permissions: Send Messages, Read Message History
  • Mở URL mời được tạo và thêm bot vào server của bạn

6. Chạy

picoclaw gateway
QQ

1. Tạo bot

2. Cấu hình

{
  "channels": {
    "qq": {
      "enabled": true,
      "app_id": "YOUR_APP_ID",
      "app_secret": "YOUR_APP_SECRET",
      "allow_from": []
    }
  }
}

Để allow_from trống để cho phép tất cả người dùng, hoặc chỉ định số QQ để giới hạn quyền truy cập.

3. Chạy

picoclaw gateway
DingTalk

1. Tạo bot

  • Truy cập Open Platform
  • Tạo ứng dụng nội bộ
  • Sao chép Client ID và Client Secret

2. Cấu hình

{
  "channels": {
    "dingtalk": {
      "enabled": true,
      "client_id": "YOUR_CLIENT_ID",
      "client_secret": "YOUR_CLIENT_SECRET",
      "allow_from": []
    }
  }
}

Để allow_from trống để cho phép tất cả người dùng, hoặc chỉ định ID để giới hạn quyền truy cập.

3. Chạy

picoclaw gateway
LINE

1. Tạo tài khoản LINE Official

  • Truy cập LINE Developers Console
  • Tạo provider → Tạo Messaging API channel
  • Sao chép Channel SecretChannel Access Token

2. Cấu hình

{
  "channels": {
    "line": {
      "enabled": true,
      "channel_secret": "YOUR_CHANNEL_SECRET",
      "channel_access_token": "YOUR_CHANNEL_ACCESS_TOKEN",
      "webhook_path": "/webhook/line",
      "allow_from": []
    }
  }
}

3. Thiết lập Webhook URL

LINE yêu cầu HTTPS cho webhook. Sử dụng reverse proxy hoặc tunnel:

# Ví dụ với ngrok
ngrok http 18790

Sau đó cài đặt Webhook URL trong LINE Developers Console thành https://your-domain/webhook/line và bật Use webhook.

4. Chạy

picoclaw gateway

Trong nhóm chat, bot chỉ phản hồi khi được @mention. Các câu trả lời sẽ trích dẫn tin nhắn gốc.

Docker Compose: Nếu bạn cần mở port webhook cục bộ, hãy thêm một rule chuyển tiếp từ port Gateway (mặc định 18790) tới host. Lưu ý: LINE webhook được phục vụ bởi Gateway HTTP chung (mặc định 127.0.0.1:18790).

WeCom (WeChat Work)

PicoClaw hỗ trợ ba loại tích hợp WeCom:

Tùy chọn 1: WeCom Bot (Robot) - Thiết lập dễ dàng hơn, hỗ trợ chat nhóm Tùy chọn 2: WeCom App (Ứng dụng Tùy chỉnh) - Nhiều tính năng hơn, nhắn tin chủ động, chỉ chat riêng tư Tùy chọn 3: WeCom AI Bot (Bot Thông Minh) - Bot AI chính thức, phản hồi streaming, hỗ trợ nhóm và riêng tư

Xem Hướng dẫn Cấu hình WeCom AI Bot để biết hướng dẫn chi tiết.

Thiết lập Nhanh - WeCom Bot:

1. Tạo bot

  • Truy cập Bảng điều khiển Quản trị WeCom → Chat Nhóm → Thêm Bot Nhóm
  • Sao chép URL webhook (định dạng: https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=xxx)

2. Cấu hình

{
  "channels": {
    "wecom": {
      "enabled": true,
      "token": "YOUR_TOKEN",
      "encoding_aes_key": "YOUR_ENCODING_AES_KEY",
      "webhook_url": "https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=YOUR_KEY",
      "webhook_path": "/webhook/wecom",
      "allow_from": []
    }
  }
}

Lưu ý: Các endpoint webhook của WeCom Bot được phục vụ bởi máy chủ Gateway HTTP dùng chung (mặc định 127.0.0.1:18790). Nếu bạn cần truy cập từ bên ngoài, hãy cấu hình reverse proxy hoặc mở cổng Gateway tương ứng.

Thiết lập Nhanh - WeCom App:

1. Tạo ứng dụng

  • Truy cập Bảng điều khiển Quản trị WeCom → Quản lý Ứng dụng → Tạo Ứng dụng
  • Sao chép AgentIdSecret
  • Truy cập trang "Công ty của tôi", sao chép CorpID

2. Cấu hình nhận tin nhắn

  • Trong chi tiết ứng dụng, nhấp vào "Nhận Tin nhắn" → "Thiết lập API"
  • Đặt URL thành http://your-server:18790/webhook/wecom-app
  • Tạo TokenEncodingAESKey

3. Cấu hình

{
  "channels": {
    "wecom_app": {
      "enabled": true,
      "corp_id": "wwxxxxxxxxxxxxxxxx",
      "corp_secret": "YOUR_CORP_SECRET",
      "agent_id": 1000002,
      "token": "YOUR_TOKEN",
      "encoding_aes_key": "YOUR_ENCODING_AES_KEY",
      "webhook_path": "/webhook/wecom-app",
      "allow_from": []
    }
  }
}

4. Chạy

picoclaw gateway

Lưu ý: WeCom App callback webhook được phục vụ bởi Gateway HTTP chung (mặc định 127.0.0.1:18790). Sử dụng proxy ngược để cung cấp HTTPS trong môi trường production nếu cần.

Thiết lập Nhanh - WeCom AI Bot:

1. Tạo AI Bot

  • Truy cập Bảng điều khiển Quản trị WeCom → Quản lý Ứng dụng → AI Bot
  • Cấu hình URL callback: http://your-server:18791/webhook/wecom-aibot
  • Sao chép Token và tạo EncodingAESKey

2. Cấu hình

{
  "channels": {
    "wecom_aibot": {
      "enabled": true,
      "token": "YOUR_TOKEN",
      "encoding_aes_key": "YOUR_43_CHAR_ENCODING_AES_KEY",
      "webhook_path": "/webhook/wecom-aibot",
      "allow_from": [],
      "welcome_message": "Xin chào! Tôi có thể giúp gì cho bạn?"
    }
  }
}

3. Chạy

picoclaw gateway

Lưu ý: WeCom AI Bot sử dụng giao thức pull streaming — không lo timeout phản hồi. Tác vụ dài (>5,5 phút) tự động chuyển sang gửi qua response_url.

ClawdChat Tham gia Mạng xã hội Agent

Kết nối PicoClaw với Mạng xã hội Agent chỉ bằng cách gửi một tin nhắn qua CLI hoặc bất kỳ ứng dụng Chat nào đã tích hợp.

Đọc https://clawdchat.ai/skill.md và làm theo hướng dẫn để tham gia ClawdChat.ai

⚙️ Cấu hình chi tiết

File cấu hình: ~/.picoclaw/config.json

Biến môi trường

Bạn có thể ghi đè các đường dẫn mặc định bằng cách sử dụng các biến môi trường. Điều này hữu ích cho việc cài đặt di động, triển khai container hóa hoặc chạy picoclaw như một dịch vụ hệ thống. Các biến này độc lập và kiểm soát các đường dẫn khác nhau.

Biến Mô tả Đường dẫn mặc định
PICOCLAW_CONFIG Ghi đè đường dẫn đến file cấu hình. Điều này trực tiếp yêu cầu picoclaw tải file config.json nào, bỏ qua tất cả các vị trí khác. ~/.picoclaw/config.json
PICOCLAW_HOME Ghi đè thư mục gốc cho dữ liệu picoclaw. Điều này thay đổi vị trí mặc định của workspace và các thư mục dữ liệu khác. ~/.picoclaw

Ví dụ:

# Chạy picoclaw bằng một file cấu hình cụ thể
# Đường dẫn workspace sẽ được đọc từ trong file cấu hình đó
PICOCLAW_CONFIG=/etc/picoclaw/production.json picoclaw gateway

# Chạy picoclaw với tất cả dữ liệu được lưu trữ trong /opt/picoclaw
# Cấu hình sẽ được tải từ ~/.picoclaw/config.json mặc định
# Workspace sẽ được tạo tại /opt/picoclaw/workspace
PICOCLAW_HOME=/opt/picoclaw picoclaw agent

# Sử dụng cả hai để có thiết lập tùy chỉnh hoàn toàn
PICOCLAW_HOME=/srv/picoclaw PICOCLAW_CONFIG=/srv/picoclaw/main.json picoclaw gateway

Cấu trúc Workspace

PicoClaw lưu trữ dữ liệu trong workspace đã cấu hình (mặc định: ~/.picoclaw/workspace):

~/.picoclaw/workspace/
├── sessions/          # Phiên hội thoại và lịch sử
├── memory/           # Bộ nhớ dài hạn (MEMORY.md)
├── state/            # Trạng thái lưu trữ (kênh cuối cùng, v.v.)
├── cron/             # Cơ sở dữ liệu tác vụ định kỳ
├── skills/           # Kỹ năng tùy chỉnh
├── AGENTS.md         # Hướng dẫn hành vi Agent
├── HEARTBEAT.md      # Prompt tác vụ định kỳ (kiểm tra mỗi 30 phút)
├── IDENTITY.md       # Danh tính Agent
├── SOUL.md           # Tâm hồn/Tính cách Agent
└── USER.md           # Tùy chọn người dùng

🔒 Hộp cát bảo mật (Security Sandbox)

PicoClaw chạy trong môi trường sandbox theo mặc định. Agent chỉ có thể truy cập file và thực thi lệnh trong phạm vi workspace.

Cấu hình mặc định

{
  "agents": {
    "defaults": {
      "workspace": "~/.picoclaw/workspace",
      "restrict_to_workspace": true
    }
  }
}
Tùy chọn Mặc định Mô tả
workspace ~/.picoclaw/workspace Thư mục làm việc của agent
restrict_to_workspace true Giới hạn truy cập file/lệnh trong workspace

Công cụ được bảo vệ

Khi restrict_to_workspace: true, các công cụ sau bị giới hạn trong sandbox:

Công cụ Chức năng Giới hạn
read_file Đọc file Chỉ file trong workspace
write_file Ghi file Chỉ file trong workspace
list_dir Liệt kê thư mục Chỉ thư mục trong workspace
edit_file Sửa file Chỉ file trong workspace
append_file Thêm vào file Chỉ file trong workspace
exec Thực thi lệnh Đường dẫn lệnh phải trong workspace

Bảo vệ bổ sung cho Exec

Ngay cả khi restrict_to_workspace: false, công cụ exec vẫn chặn các lệnh nguy hiểm sau:

  • rm -rf, del /f, rmdir /s — Xóa hàng loạt
  • format, mkfs, diskpart — Định dạng ổ đĩa
  • dd if= — Tạo ảnh đĩa
  • Ghi vào /dev/sd[a-z] — Ghi trực tiếp lên đĩa
  • shutdown, reboot, poweroff — Tắt/khởi động lại hệ thống
  • Fork bomb :(){ :|:& };:

Ví dụ lỗi

[ERROR] tool: Tool execution failed
{tool=exec, error=Command blocked by safety guard (path outside working dir)}
[ERROR] tool: Tool execution failed
{tool=exec, error=Command blocked by safety guard (dangerous pattern detected)}

Tắt giới hạn (Rủi ro bảo mật)

Nếu bạn cần agent truy cập đường dẫn ngoài workspace:

Cách 1: File cấu hình

{
  "agents": {
    "defaults": {
      "restrict_to_workspace": false
    }
  }
}

Cách 2: Biến môi trường

export PICOCLAW_AGENTS_DEFAULTS_RESTRICT_TO_WORKSPACE=false

⚠️ Cảnh báo: Tắt giới hạn này cho phép agent truy cập mọi đường dẫn trên hệ thống. Chỉ sử dụng cẩn thận trong môi trường được kiểm soát.

Tính nhất quán của ranh giới bảo mật

Cài đặt restrict_to_workspace áp dụng nhất quán trên mọi đường thực thi:

Đường thực thi Ranh giới bảo mật
Agent chính restrict_to_workspace
Subagent / Spawn Kế thừa cùng giới hạn ✅
Tác vụ Heartbeat Kế thừa cùng giới hạn ✅

Tất cả đường thực thi chia sẻ cùng giới hạn workspace — không có cách nào vượt qua ranh giới bảo mật thông qua subagent hoặc tác vụ định kỳ.

Heartbeat (Tác vụ định kỳ)

PicoClaw có thể tự động thực hiện các tác vụ định kỳ. Tạo file HEARTBEAT.md trong workspace:

# Tác vụ định kỳ

- Kiểm tra email xem có tin nhắn quan trọng không
- Xem lại lịch cho các sự kiện sắp tới
- Kiểm tra dự báo thời tiết

Agent sẽ đọc file này mỗi 30 phút (có thể cấu hình) và thực hiện các tác vụ bằng công cụ có sẵn.

Tác vụ bất đồng bộ với Spawn

Đối với các tác vụ chạy lâu (tìm kiếm web, gọi API), sử dụng công cụ spawn để tạo subagent:

# Tác vụ định kỳ

## Tác vụ nhanh (trả lời trực tiếp)
- Báo cáo thời gian hiện tại

## Tác vụ lâu (dùng spawn cho async)
- Tìm kiếm tin tức AI trên web và tóm tắt
- Kiểm tra email và báo cáo tin nhắn quan trọng

Hành vi chính:

Tính năng Mô tả
spawn Tạo subagent bất đồng bộ, không chặn heartbeat
Context độc lập Subagent có context riêng, không có lịch sử phiên
message tool Subagent giao tiếp trực tiếp với người dùng qua công cụ message
Không chặn Sau khi spawn, heartbeat tiếp tục tác vụ tiếp theo

Cách Subagent giao tiếp

Heartbeat kích hoạt
    ↓
Agent đọc HEARTBEAT.md
    ↓
Tác vụ lâu: spawn subagent
    ↓                           ↓
Tiếp tục tác vụ tiếp theo   Subagent làm việc độc lập
    ↓                           ↓
Tất cả tác vụ hoàn thành    Subagent dùng công cụ "message"
    ↓                           ↓
Phản hồi HEARTBEAT_OK       Người dùng nhận kết quả trực tiếp

Subagent có quyền truy cập các công cụ (message, web_search, v.v.) và có thể giao tiếp với người dùng một cách độc lập mà không cần thông qua agent chính.

Cấu hình:

{
  "heartbeat": {
    "enabled": true,
    "interval": 30
  }
}
Tùy chọn Mặc định Mô tả
enabled true Bật/tắt heartbeat
interval 30 Khoảng thời gian kiểm tra (phút, tối thiểu: 5)

Biến môi trường:

  • PICOCLAW_HEARTBEAT_ENABLED=false để tắt
  • PICOCLAW_HEARTBEAT_INTERVAL=60 để thay đổi khoảng thời gian

Nhà cung cấp (Providers)

Note

Groq cung cấp dịch vụ chuyển giọng nói thành văn bản miễn phí qua Whisper. Nếu đã cấu hình Groq, tin nhắn âm thanh từ bất kỳ kênh nào sẽ được tự động chuyển thành văn bản ở cấp độ agent.

Nhà cung cấp Mục đích Lấy API Key
gemini LLM (Gemini trực tiếp) aistudio.google.com
zhipu LLM (Zhipu trực tiếp) bigmodel.cn
volcengine LLM(Volcengine trực tiếp) volcengine.com
openrouter (Đang thử nghiệm) LLM (khuyên dùng, truy cập mọi model) openrouter.ai
anthropic (Đang thử nghiệm) LLM (Claude trực tiếp) console.anthropic.com
openai (Đang thử nghiệm) LLM (GPT trực tiếp) platform.openai.com
deepseek (Đang thử nghiệm) LLM (DeepSeek trực tiếp) platform.deepseek.com
groq LLM + Chuyển giọng nói (Whisper) console.groq.com
qwen LLM (Qwen trực tiếp) dashscope.console.aliyun.com
cerebras LLM (Cerebras trực tiếp) cerebras.ai
Cấu hình Zhipu

1. Lấy API key

2. Cấu hình

{
  "agents": {
    "defaults": {
      "workspace": "~/.picoclaw/workspace",
      "model": "glm-4.7",
      "max_tokens": 8192,
      "temperature": 0.7,
      "max_tool_iterations": 20
    }
  },
  "providers": {
    "zhipu": {
      "api_key": "Your API Key",
      "api_base": "https://open.bigmodel.cn/api/paas/v4"
    }
  }
}

3. Chạy

picoclaw agent -m "Xin chào"
Ví dụ cấu hình đầy đủ
{
  "agents": {
    "defaults": {
      "model": "anthropic/claude-opus-4-5"
    }
  },
  "providers": {
    "openrouter": {
      "api_key": "sk-or-v1-xxx"
    },
    "groq": {
      "api_key": "gsk_xxx"
    }
  },
  "channels": {
    "telegram": {
      "enabled": true,
      "token": "123456:ABC...",
      "allow_from": ["123456789"]
    },
    "discord": {
      "enabled": true,
      "token": "",
      "allow_from": [""]
    },
    "whatsapp": {
      "enabled": false
    },
    "feishu": {
      "enabled": false,
      "app_id": "cli_xxx",
      "app_secret": "xxx",
      "encrypt_key": "",
      "verification_token": "",
      "allow_from": []
    },
    "qq": {
      "enabled": false,
      "app_id": "",
      "app_secret": "",
      "allow_from": []
    }
  },
  "tools": {
    "web": {
      "brave": {
        "enabled": false,
        "api_key": "BSA...",
        "max_results": 5
      },
      "duckduckgo": {
        "enabled": true,
        "max_results": 5
      }
    }
  },
  "heartbeat": {
    "enabled": true,
    "interval": 30
  }
}

Cấu hình Mô hình (model_list)

Tính năng mới! PicoClaw hiện sử dụng phương pháp cấu hình đặt mô hình vào trung tâm. Chỉ cần chỉ định dạng nhà cung cấp/mô hình (ví dụ: zhipu/glm-4.7) để thêm nhà cung cấp mới—không cần thay đổi mã!

Thiết kế này cũng cho phép hỗ trợ đa tác nhân với lựa chọn nhà cung cấp linh hoạt:

  • Tác nhân khác nhau, nhà cung cấp khác nhau : Mỗi tác nhân có thể sử dụng nhà cung cấp LLM riêng
  • Mô hình dự phòng : Cấu hình mô hình chính và dự phòng để tăng độ tin cậy
  • Cân bằng tải : Phân phối yêu cầu trên nhiều endpoint khác nhau
  • Cấu hình tập trung : Quản lý tất cả nhà cung cấp ở một nơi

📋 Tất cả Nhà cung cấp được Hỗ trợ

Nhà cung cấp Prefix model API Base Mặc định Giao thức Khóa API
OpenAI openai/ https://api.openai.com/v1 OpenAI Lấy Khóa
Anthropic anthropic/ https://api.anthropic.com/v1 Anthropic Lấy Khóa
Zhipu AI (GLM) zhipu/ https://open.bigmodel.cn/api/paas/v4 OpenAI Lấy Khóa
DeepSeek deepseek/ https://api.deepseek.com/v1 OpenAI Lấy Khóa
Google Gemini gemini/ https://generativelanguage.googleapis.com/v1beta OpenAI Lấy Khóa
Groq groq/ https://api.groq.com/openai/v1 OpenAI Lấy Khóa
Moonshot moonshot/ https://api.moonshot.cn/v1 OpenAI Lấy Khóa
Qwen (Alibaba) qwen/ https://dashscope.aliyuncs.com/compatible-mode/v1 OpenAI Lấy Khóa
NVIDIA nvidia/ https://integrate.api.nvidia.com/v1 OpenAI Lấy Khóa
Ollama ollama/ http://localhost:11434/v1 OpenAI Local (không cần khóa)
OpenRouter openrouter/ https://openrouter.ai/api/v1 OpenAI Lấy Khóa
VLLM vllm/ http://localhost:8000/v1 OpenAI Local
Cerebras cerebras/ https://api.cerebras.ai/v1 OpenAI Lấy Khóa
VolcEngine (Doubao) volcengine/ https://ark.cn-beijing.volces.com/api/v3 OpenAI Lấy Khóa
ShengsuanYun shengsuanyun/ https://router.shengsuanyun.com/api/v1 OpenAI -
BytePlus byteplus/ https://ark.ap-southeast.bytepluses.com/api/v3 OpenAI Lấy Khóa
LongCat longcat/ https://api.longcat.chat/openai OpenAI Lấy Key
ModelScope (魔搭) modelscope/ https://api-inference.modelscope.cn/v1 OpenAI Lấy Token
Azure OpenAI azure/ https://{resource}.openai.azure.com Azure Lấy Khóa
Antigravity antigravity/ Google Cloud Tùy chỉnh Chỉ OAuth
GitHub Copilot github-copilot/ localhost:4321 gRPC -

Cấu hình Cơ bản

{
  "model_list": [
    {
      "model_name": "ark-code-latest",
      "model": "volcengine/ark-code-latest",
      "api_key": "sk-your-api-key"
    },
    {
      "model_name": "gpt-5.4",
      "model": "openai/gpt-5.4",
      "api_key": "sk-your-openai-key"
    },
    {
      "model_name": "claude-sonnet-4.6",
      "model": "anthropic/claude-sonnet-4.6",
      "api_key": "sk-ant-your-key"
    },
    {
      "model_name": "glm-4.7",
      "model": "zhipu/glm-4.7",
      "api_key": "your-zhipu-key"
    }
  ],
  "agents": {
    "defaults": {
      "model": "gpt-5.4"
    }
  }
}

Ví dụ theo Nhà cung cấp

OpenAI

{
  "model_name": "gpt-5.4",
  "model": "openai/gpt-5.4",
  "api_key": "sk-..."
}

VolcEngine (Doubao)

{
  "model_name": "ark-code-latest",
  "model": "volcengine/ark-code-latest",
  "api_key": "sk-..."
}

Zhipu AI (GLM)

{
  "model_name": "glm-4.7",
  "model": "zhipu/glm-4.7",
  "api_key": "your-key"
}

Anthropic (với OAuth)

{
  "model_name": "claude-sonnet-4.6",
  "model": "anthropic/claude-sonnet-4.6",
  "auth_method": "oauth"
}

Chạy picoclaw auth login --provider anthropic để thiết lập thông tin xác thực OAuth.

Proxy/API tùy chỉnh

{
  "model_name": "my-custom-model",
  "model": "openai/custom-model",
  "api_base": "https://my-proxy.com/v1",
  "api_key": "sk-...",
  "request_timeout": 300
}

Cân bằng Tải tải

Định cấu hình nhiều endpoint cho cùng một tên mô hình—PicoClaw sẽ tự động phân phối round-robin giữa chúng:

{
  "model_list": [
    {
      "model_name": "gpt-5.4",
      "model": "openai/gpt-5.4",
      "api_base": "https://api1.example.com/v1",
      "api_key": "sk-key1"
    },
    {
      "model_name": "gpt-5.4",
      "model": "openai/gpt-5.4",
      "api_base": "https://api2.example.com/v1",
      "api_key": "sk-key2"
    }
  ]
}

Chuyển đổi từ Cấu hình providers

Cấu hình providers cũ đã ngừng sử dụng nhưng vẫn được hỗ trợ để tương thích ngược.

Cấu hình Cũ (đã ngừng sử dụng):

{
  "providers": {
    "zhipu": {
      "api_key": "your-key",
      "api_base": "https://open.bigmodel.cn/api/paas/v4"
    }
  },
  "agents": {
    "defaults": {
      "provider": "zhipu",
      "model": "glm-4.7"
    }
  }
}

Cấu hình Mới (khuyến nghị):

{
  "model_list": [
    {
      "model_name": "glm-4.7",
      "model": "zhipu/glm-4.7",
      "api_key": "your-key"
    }
  ],
  "agents": {
    "defaults": {
      "model": "glm-4.7"
    }
  }
}

Xem hướng dẫn chuyển đổi chi tiết tại docs/migration/model-list-migration.md.

Tham chiếu CLI

Lệnh Mô tả
picoclaw onboard Khởi tạo cấu hình & workspace
picoclaw agent -m "..." Trò chuyện với agent
picoclaw agent Chế độ chat tương tác
picoclaw gateway Khởi động gateway (cho bot chat)
picoclaw status Hiển thị trạng thái
picoclaw cron list Liệt kê tất cả tác vụ định kỳ
picoclaw cron add ... Thêm tác vụ định kỳ

Tác vụ định kỳ / Nhắc nhở

PicoClaw hỗ trợ nhắc nhở theo lịch và tác vụ lặp lại thông qua công cụ cron:

  • Nhắc nhở một lần: "Remind me in 10 minutes" (Nhắc tôi sau 10 phút) → kích hoạt một lần sau 10 phút
  • Tác vụ lặp lại: "Remind me every 2 hours" (Nhắc tôi mỗi 2 giờ) → kích hoạt mỗi 2 giờ
  • Biểu thức Cron: "Remind me at 9am daily" (Nhắc tôi lúc 9 giờ sáng mỗi ngày) → sử dụng biểu thức cron

Các tác vụ được lưu trong ~/.picoclaw/workspace/cron/ và được xử lý tự động.

🤝 Đóng góp & Lộ trình

Chào đón mọi PR! Mã nguồn được thiết kế nhỏ gọn và dễ đọc. 🤗

Lộ trình sắp được công bố...

Nhóm phát triển đang được xây dựng. Điều kiện tham gia: Ít nhất 1 PR đã được merge.

Nhóm người dùng:

Discord: https://discord.gg/V4sAZ9XWpN

PicoClaw

🐛 Xử lý sự cố

Tìm kiếm web hiện "API 配置问题"

Điều này là bình thường nếu bạn chưa cấu hình API key cho tìm kiếm. PicoClaw sẽ cung cấp các liên kết hữu ích để tìm kiếm thủ công.

Để bật tìm kiếm web:

  1. Tùy chọn 1 (Khuyên dùng): Lấy API key miễn phí tại https://brave.com/search/api (2000 truy vấn miễn phí/tháng) để có kết quả tốt nhất.
  2. Tùy chọn 2 (Không cần thẻ tín dụng): Nếu không có key, hệ thống tự động chuyển sang dùng DuckDuckGo (không cần key).

Thêm key vào ~/.picoclaw/config.json nếu dùng Brave:

{
  "tools": {
    "web": {
      "brave": {
        "enabled": false,
        "api_key": "YOUR_BRAVE_API_KEY",
        "max_results": 5
      },
      "duckduckgo": {
        "enabled": true,
        "max_results": 5
      }
    }
  }
}

Gặp lỗi lọc nội dung (Content Filtering)

Một số nhà cung cấp (như Zhipu) có bộ lọc nội dung nghiêm ngặt. Thử diễn đạt lại câu hỏi hoặc sử dụng model khác.

Telegram bot báo "Conflict: terminated by other getUpdates"

Điều này xảy ra khi có một instance bot khác đang chạy. Đảm bảo chỉ có một tiến trình picoclaw gateway chạy tại một thời điểm.


📝 So sánh API Key

Dịch vụ Gói miễn phí Trường hợp sử dụng
OpenRouter 200K tokens/tháng Đa model (Claude, GPT-4, v.v.)
Volcengine CodingPlan ¥9.9/tháng đầu Tốt nhất cho người dùng Trung Quốc, nhiều mô hình SOTA (Doubao, DeepSeek, v.v.)
Zhipu 200K tokens/tháng Phù hợp cho người dùng Trung Quốc
Brave Search 2000 truy vấn/tháng Chức năng tìm kiếm web
Groq Có gói miễn phí Suy luận siêu nhanh (Llama, Mixtral)
ModelScope 2000 yêu cầu/ngày Suy luận miễn phí (Qwen, GLM, DeepSeek, v.v.)

PicoClaw Meme