ติดตั้ง OpenClaw (Moltbot/Clawdbot) บน Raspberry Pi อย่างไร

Ashley Innocent

Ashley Innocent

12 February 2026

ติดตั้ง OpenClaw (Moltbot/Clawdbot) บน Raspberry Pi อย่างไร

OpenClaw เคลื่อนที่อย่างรวดเร็ว: จากความวุ่นวายในการตั้งชื่อ Moltbot เป็น Clawdbot สู่เอกลักษณ์ที่มั่นคงและการยอมรับจากชุมชนที่เติบโตอย่างรวดเร็ว หากคุณมาที่นี่ คุณอาจต้องการผลลัพธ์ที่เป็นรูปธรรมอย่างหนึ่ง: โหนด OpenClaw ที่เชื่อถือได้ซึ่งทำงานบน Raspberry Pi ที่คุณสามารถไว้วางใจได้ที่บ้านหรือที่ Edge

คู่มือนี้เหมาะสำหรับนักพัฒนาเชิงเทคนิคที่เชี่ยวชาญ คุณจะตั้งค่า OpenClaw ด้วย:

ระหว่างนี้ ผมจะแสดงให้เห็นว่า Apidog มีประโยชน์อย่างไร: ในการตรวจสอบความถูกต้องของ Endpoint ของ OpenClaw, การสร้าง Regression Test, และการจัดทำเอกสาร API ในเครื่องของคุณเพื่อการใช้งานของทีม

ปุ่ม

1) การตัดสินใจด้านสถาปัตยกรรมก่อนการติดตั้ง

ก่อนที่จะแตะต้อง apt ให้ตัดสินใจว่า Pi ของคุณจะรันเวิร์กโฟลว์การอนุมาน (inference) อย่างไร

ตัวเลือก A: Pi เป็นตัวประสานงาน, โมเดลถูกออฟโหลด (Offloaded)

ดีที่สุดสำหรับ Raspberry Pi 4/5 ที่มี RAM จำกัด

ตัวเลือก B: Pi สำหรับโมเดลท้องถิ่นแบบเบาเท่านั้น

เหมาะสำหรับความเป็นส่วนตัวที่เข้มงวดและงานแบบออฟไลน์

ตัวเลือก C: การกำหนดเส้นทางแบบไฮบริด

สถาปัตยกรรมที่ใช้งานได้จริงที่สุด

รูปแบบ "ตรวจสอบแบบง่ายก่อน, ใช้โมเดลเมื่อจำเป็นเท่านั้น" นี้ได้กลายเป็นกลยุทธ์หลักของ OpenClaw ในด้านความน่าเชื่อถือ เนื่องจากช่วยควบคุมต้นทุน, แรงกดดันด้านความร้อน, และความหน่วงที่สูงขึ้น

2) ฮาร์ดแวร์และ OS พื้นฐาน

ฮาร์ดแวร์ที่แนะนำ

ระบบปฏิบัติการ (OS)

ใช้ Raspberry Pi OS Lite (64-bit) หรือ Ubuntu Server 24.04 สำหรับ ARM64

จากนั้นอัปเดต:

bash sudo apt update && sudo apt upgrade -y sudo reboot

ตั้งค่าชื่อโฮสต์และการซิงค์เวลา (สำคัญสำหรับบันทึกและวันหมดอายุของโทเค็น):

bash sudo hostnamectl set-hostname openclaw-pi sudo timedatectl set-ntp true

3) ติดตั้งการพึ่งพารันไทม์ (Runtime Dependencies)

สแต็ค OpenClaw มักจะใช้ Python และ/หรือ Node Workers ขึ้นอยู่กับปลั๊กอิน ติดตั้งทั้งสองเพื่อให้เข้ากันได้กับโมดูลที่พัฒนาขึ้น

sudo apt install -y   git curl wget jq build-essential pkg-config   python3 python3-venv python3-pip   nodejs npm   redis-server sqlite3

ตรวจสอบเวอร์ชัน:

bash python3 --version node --version npm --version redis-server --version

ทำไมต้อง Redis + SQLite?

สำหรับการตั้งค่าแบบหลายโหนดในภายหลัง ให้ย้ายการจัดเก็บข้อมูลแบบถาวรไปที่ Postgres


4) สร้างผู้ใช้บริการเฉพาะ

หลีกเลี่ยงการรันเอเจนต์ในฐานะ pi หรือ root

sudo useradd -m -s /bin/bash openclaw sudo usermod -aG sudo openclaw sudo mkdir -p /opt/openclaw sudo chown -R openclaw:openclaw /opt/openclaw

เปลี่ยนผู้ใช้:

bash sudo su - openclaw cd /opt/openclaw

5) โคลนและกำหนดค่า OpenClaw

bash git clone https://github.com//.git app cd app

แทนที่ด้วยพาธของ Repository อย่างเป็นทางการปัจจุบันจากหน้าโปรเจกต์ OpenClaw

สร้างสภาพแวดล้อม Python:

python3 -m venv .venv source .venv/bin/activate pip install --upgrade pip pip install -r requirements.txt

หากมีบริการ Node:

npm ci

คัดลอกเทมเพลตสภาพแวดล้อม:

cp .env.example .env

โครงสร้าง .env ทั่วไป:

env OPENCLAW_HOST=0.0.0.0 OPENCLAW_PORT=8080 OPENCLAW_LOG_LEVEL=info
STATE_BACKEND=redis REDIS_URL=redis://127.0.0.1:6379 DB_URL=sqlite:////opt/openclaw/app/data/openclaw.db
MODEL_ROUTER=hybrid LOCAL_MODEL_ENABLED=true REMOTE_MODEL_ENABLED=true REMOTE_MODEL_API_KEY=your_key_here
HEARTBEAT_INTERVAL_SEC=15 HEARTBEAT_TIMEOUT_SEC=5 CHEAP_CHECKS_ENABLED=true
SANDBOX_MODE=on SANDBOX_PROVIDER=process

ใช้ chmod 600 .env เพื่อป้องกันความลับ


6) เพิ่มบริการ systemd เพื่อความน่าเชื่อถือ

สร้าง /etc/systemd/system/openclaw.service:

ini [Unit] Description=OpenClaw Agent Service After=network-online.target redis.service Wants=network-online.target
[Service] Type=simple User=openclaw WorkingDirectory=/opt/openclaw/app Environment="PYTHONUNBUFFERED=1" ExecStart=/opt/openclaw/app/.venv/bin/python -m openclaw.server Restart=always RestartSec=3 TimeoutStartSec=30 TimeoutStopSec=20

การเสริมความปลอดภัยขั้นพื้นฐาน

NoNewPrivileges=true PrivateTmp=true ProtectSystem=full ProtectHome=true ReadWritePaths=/opt/openclaw/app/data /opt/openclaw/app/logs

[Install] WantedBy=multi-user.target

เปิดใช้งานและเริ่มต้น:

sudo systemctl daemon-reload sudo systemctl enable openclaw sudo systemctl start openclaw sudo systemctl status openclaw

ดูบันทึก (Tail logs):

bash journalctl -u openclaw -f

7) ใช้กลยุทธ์ Heartbeat (ตรวจสอบแบบง่ายก่อน)

บทเรียนที่เกิดขึ้นซ้ำๆ จากชุมชน: อย่าใช้โทเค็นโมเดลเพื่อตรวจจับข้อผิดพลาดที่ชัดเจน

Heartbeat แบบหลายชั้นที่แนะนำ

  1. ตรวจสอบกระบวนการ L0: บริการทำงานอยู่, พอร์ตเปิด
  2. ตรวจสอบการพึ่งพา L1: Redis/DB เข้าถึงได้, คิวดีเลย์อยู่ในเกณฑ์ที่ยอมรับได้
  3. ตรวจสอบงานแบบกำหนดได้ L2: รันสคริปต์การตรวจสอบแบบคงที่
  4. การตรวจสอบที่ใช้โมเดล L3: เฉพาะเมื่อการตรวจสอบก่อนหน้านี้ผ่านแต่ความมั่นใจต่ำ

ตัวอย่างการกำหนดค่าเสมือน:

yaml heartbeat: interval_sec: 15 timeout_sec: 5 stages: - name: process type: tcp target: 127.0.0.1:8080 - name: deps type: internal checks: [redis_ping, db_read] - name: deterministic type: task command: "python scripts/selfcheck.py" - name: model_probe type: llm enabled_on: degraded_only

รูปแบบนี้ช่วยลดต้นทุนและการแจ้งเตือนที่ผิดพลาด พร้อมทั้งปกป้องช่วงเวลาการทำงานบนฮาร์ดแวร์ที่มีข้อจำกัด

8) การรันอย่างปลอดภัยด้วยขอบเขต Sandbox

หาก OpenClaw รันเครื่องมือ (เชลล์, เบราว์เซอร์, การเขียนไฟล์) ให้แยกการทำงานออก

พื้นฐานขั้นต่ำบน Pi:

หากสแต็คของคุณรองรับ Sandbox ที่แข็งแกร่ง (คล้ายกับโมเดล Sandbox ของ secure-agent) ให้ใช้สิ่งนั้นสำหรับการเรียกใช้เครื่องมือที่ไม่น่าเชื่อถือ

แนวทางป้องกันที่ใช้งานได้จริง:

env TOOL_EXEC_TIMEOUT_MS=12000 TOOL_MAX_STDOUT_KB=256 TOOL_ALLOWED_PATHS=/opt/openclaw/app/workdir TOOL_BLOCK_NETWORK_BY_DEFAULT=true

สำหรับเครื่องมือที่เปิดใช้งานเครือข่าย ให้ระบุรายการโฮสต์ที่อนุญาตเท่านั้น

9) ตรวจสอบความถูกต้องของ OpenClaw API ด้วย Apidog

เมื่อ OpenClaw ทำงานแล้ว ให้ปฏิบัติกับมันเหมือนผลิตภัณฑ์ API ทั่วไป: กำหนดสัญญา, ทดสอบพฤติกรรม, และติดตาม Regression

เหตุผลที่ใช้ Apidog ที่นี่

คุณสามารถใช้ Apidog เพื่อ:

ตัวอย่างการทดสอบ Endpoint สถานะสุขภาพ

สมมติ Endpoint:

GET /healthz

การตอบสนองที่คาดหวัง:

{ "status": "ok", "checks": { "redis": "ok", "db": "ok", "queue_lag_ms": 12 } }

ใน Apidog ให้สร้างสถานการณ์ทดสอบ:

  1. ยืนยัน HTTP 200
  2. ยืนยัน status == ok
  3. ยืนยัน checks.queue_lag_ms < 100
  4. เพิ่มสภาพแวดล้อมเชิงลบที่ Redis ถูกหยุด; คาดว่าสถานะจะลดลง (degraded state)

สิ่งนี้เปลี่ยนคำว่า “ดูเหมือนจะดี” ให้เป็นการรับรองคุณภาพ API ที่สามารถทำซ้ำได้

10) การปรับแต่งประสิทธิภาพบน Raspberry Pi

การควบคุม CPU และอุณหภูมิ

ตรวจสอบ:

bash vcgencmd measure_temp uptime top

หากอุณหภูมิเกินขีดจำกัดที่ปลอดภัยและต่อเนื่อง ความหน่วงในการอนุมาน (inference latency) จะพุ่งสูงขึ้นเนื่องจากการควบคุมความเร็ว (throttling)

แรงกดดันด้านหน่วยความจำ

เปิดใช้งาน zram หรือ swap ขนาดพอประมาณหากจำเป็น แต่หลีกเลี่ยงเวิร์กโหลดที่ใช้ swap มากสำหรับกระบวนการแบบเรียลไทม์

คิวและการทำงานพร้อมกัน (Concurrency)

เริ่มแบบอนุรักษ์นิยม:

env WORKER_CONCURRENCY=1 MAX_INFLIGHT_TASKS=4

จากนั้นค่อยเพิ่มหลังจากสังเกตความหน่วง p95 และอัตราข้อผิดพลาด

การหมุนเวียนบันทึก (Log Rotation)

ป้องกันการสึกหรอของ SD/SSD:

bash sudo apt install -y logrotate

เพิ่มกฎการหมุนเวียนสำหรับ /opt/openclaw/app/logs/*.log

11) คู่มือการแก้ไขปัญหา

บริการทำงานผิดปกติบ่อยครั้ง

bash sudo su - openclaw cd /opt/openclaw/app source .venv/bin/activate python -m openclaw.server

การเชื่อมต่อ Redis ถูกปฏิเสธ

bash sudo systemctl status redis redis-cli ping

หากไม่ใช่ PONG ให้แก้ไข Redis ก่อนที่จะดีบัก OpenClaw

ความหน่วงสูงหลังจากไม่กี่นาที

น่าจะเกิดจากการควบคุมความเร็วจากความร้อน (thermal throttling) หรือแรงกดดันด้านหน่วยความจำ

Heartbeat ผ่านแต่ Task ล้มเหลว

การตรวจสอบของคุณตื้นเกินไป เพิ่มการตรวจสอบ Task แบบกำหนดได้ที่เลียนแบบเวิร์กโฟลว์จริง (เช่น การอ่านไฟล์, การแยกวิเคราะห์, การสรุป, การเข้ารหัสการตอบกลับ)

12) รายการตรวจสอบการเสริมความปลอดภัยสำหรับการใช้งานที่ Edge ใกล้ระดับ Production

หากคุณทำงานร่วมกันในทีม Backend, QA, และ Frontend ให้ใส่ OpenClaw API spec ลงใน Apidog Workspace ที่ใช้ร่วมกัน คุณจะรักษาสนามของการเปลี่ยนแปลง Schema, การทดสอบ, Mock, และเอกสารให้ซิงโครไนซ์กัน แทนที่จะกระจัดกระจายไปตามเครื่องมือต่างๆ

13) ตัวอย่างแผนที่ Endpoint ที่คุณควรเปิดเผย

รักษาสนามให้เล็กและชัดเจน:

จัดทำเอกสารเหล่านี้ใน OpenAPI จากนั้นใช้เวิร์กโฟลว์แบบ Schema-first ของ Apidog เพื่อบังคับใช้ความสอดคล้องของการตอบสนองและหลีกเลี่ยงการทำให้ผู้บริโภคเสียหายเมื่อโมดูล OpenClaw พัฒนาขึ้น

บทสรุป

การรัน OpenClaw บน Raspberry Pi เป็นไปได้แน่นอนเมื่อคุณออกแบบโดยคำนึงถึงข้อจำกัด:

การผสมผสานดังกล่าวทำให้คุณได้โหนดที่มีราคาไม่แพง, เป็นส่วนตัว, และมีเสถียรภาพเพียงพอสำหรับการทำงานอัตโนมัติในชีวิตประจำวัน

หากคุณต้องการขั้นตอนต่อไปที่ชัดเจน ให้นำเข้า Endpoint ของ OpenClaw ของคุณเข้าสู่ Apidog และสร้างการทดสอบอัตโนมัติสามอย่างในวันนี้: healthz, readyz, และเวิร์กโฟลว์งานแบบ End-to-End หนึ่งรายการ คุณจะตรวจจับ Regression ได้ตั้งแต่เนิ่นๆ และทำให้การใช้งาน Pi ของคุณน่าเชื่อถือเมื่อสแต็คเอเจนต์ของคุณเติบโตขึ้น

ปุ่ม

ฝึกการออกแบบ API แบบ Design-first ใน Apidog

ค้นพบวิธีที่ง่ายขึ้นในการสร้างและใช้ API