การพัฒนาเอเจนต์ ADK ที่ขับเคลื่อนด้วยข้อมูลจำเพาะด้วย Antigravity และ Spec-kit

1. บทนำ

การเพิ่มฟีเจอร์ลงใน Agent ที่มีอยู่ ซึ่งเป็นความสามารถใหม่ที่ใช้ฐานข้อมูลมักหมายถึงการเขียนโค้ดต้นแบบ การเชื่อมต่อการผสานรวม และการทำให้ทุกอย่างสอดคล้องกับรูปแบบที่มีอยู่แล้วในฐานของโค้ด Antigravity เร่งกระบวนการนี้ในทุกขั้นตอน โดยจะวิเคราะห์ฐานของโค้ดเพื่อสร้างบริบทที่จำเป็น สร้างข้อกำหนดที่มีโครงสร้างและแผนการติดตั้งใช้งานเพื่อให้คุณตรวจสอบ และดำเนินการเปลี่ยนแปลงโค้ด ทั้งหมดนี้จะได้รับการแนะนำโดยความรู้เกี่ยวกับโดเมนที่ช่วยให้คุณบันทึกเป็นทักษะที่นำกลับมาใช้ใหม่ได้ และธรรมนูญของโปรเจ็กต์ที่บังคับใช้หลักการที่ต่อรองไม่ได้ Codelab นี้จะแนะนำวิธีเพิ่มประสิทธิภาพกระบวนทัศน์การพัฒนาที่ขับเคลื่อนด้วยข้อมูลจำเพาะของ Antigravity โดยการแนะนำวงจรใหม่เพื่อเพิ่มเอกสารประกอบข้อมูลจำเพาะที่อ้างอิง spec-kit อย่างมาก

สิ่งที่คุณจะสร้าง

แอปพลิเคชันเลขานุการร้านอาหารที่ทำงานในพื้นที่พร้อมการจองที่เพิ่มผ่านวงจร SDD ที่สมบูรณ์

  • การจอง - แขกจองโต๊ะและตรวจสอบการจอง โดยมีเครื่องมือฐานข้อมูล MCP Toolbox ใหม่และตาราง reservations Cloud SQL เป็นข้อมูลสนับสนุน
  • (ความท้าทาย) - พัฒนา UI ของ Agent ของคุณเอง
  • (การท้าทาย) – ทำให้ Google Cloud ใช้งานได้โดยใช้ Agent Antigravity

โค้ดเริ่มต้นมี Agent ADK ที่ใช้งานได้พร้อมการค้นหาเมนู (คีย์เวิร์ด + ความหมายผ่าน MCP Toolbox) และการติดตามค่ากำหนดด้านอาหาร (ผ่าน ToolContext) คุณขยายได้โดยไม่ต้องเขียนโค้ดของแอปพลิเคชันด้วยตนเอง เนื่องจาก Antigravity จะจัดการการติดตั้งใช้งานตามข้อกำหนดของคุณ

404869b603fff6ab.png

สิ่งที่คุณจะได้เรียนรู้

  • วิธีเริ่มต้นบริบทของโปรเจ็กต์เพื่อให้ Antigravity เข้าใจโค้ดเบสที่มีอยู่
  • วิธีสร้างทักษะ Antigravity ที่รวมความรู้เฉพาะด้าน (เช่น รูปแบบ Codelab ของ ADK) เพื่อนำกลับมาใช้ใหม่
  • วิธีตั้งค่าธรรมนูญของโปรเจ็กต์ที่เวิร์กโฟลว์ SDD จะตรวจสอบเทียบระหว่างการวางแผนและการวิเคราะห์
  • วิธีใช้เวิร์กโฟลว์ Spec-Driven Development (SDD) ใน Antigravity เพื่อเพิ่มฟีเจอร์อย่างเป็นระบบ
  • วิธีขยาย Agent ADK ด้วยเครื่องมือใหม่ที่ใช้ฐานข้อมูลผ่าน MCP Toolbox

ข้อกำหนดเบื้องต้น

2. ตั้งค่าสภาพแวดล้อม

ขั้นตอนนี้จะโคลนที่เก็บเริ่มต้น ตรวจสอบสิทธิ์กับ Google Cloud จัดสรรฐานข้อมูล Cloud SQL และเตรียมสภาพแวดล้อม Antigravity ในเครื่อง

โคลนที่เก็บเริ่มต้น

เปิดเทอร์มินัลใน Antigravity (หรือเทอร์มินัลของระบบ) โคลนที่เก็บข้อมูลเสริมและเข้าสู่ไดเรกทอรี

git clone https://github.com/alphinside/sdd-adk-antigravity-starter.git sdd-adk-agents-agy
cd sdd-adk-agents-agy

เปิดที่เก็บที่โคลนใน Antigravity File->Open Folder->เลือกไดเรกทอรีที่โคลน sdd-adk-agents-agy

นำรีโมตต้นทางออก เวิร์กโฟลว์ SDD จะสร้างกิ่ง Git สำหรับข้อกำหนดของฟีเจอร์ การนำรีโมตออกจะช่วยป้องกันไม่ให้มีการพุชไปยังที่เก็บเริ่มต้นโดยไม่ตั้งใจ

git remote remove origin

ติดตั้งข้อกำหนดเบื้องต้น

เรียกใช้สคริปต์ข้อกำหนดเบื้องต้น โดยจะตรวจสอบ (และติดตั้งหากไม่มี) git, curl, gcloud, uv, Python 3.12 และ MCP Toolbox ดังนี้

bash scripts/setup_prerequisites.sh

2aa671856eee1085.png

ตรวจสอบสิทธิ์ด้วย Google Cloud

เรียกใช้คำสั่งการตรวจสอบสิทธิ์ 2 คำสั่ง ทั้ง 2 วิธีจะเปิดเบราว์เซอร์สำหรับ OAuth

gcloud auth login
gcloud auth application-default login

เนื่องจากคุณทำงานในพื้นที่ด้วย Antigravity คุณจึงต้องตรวจสอบสิทธิ์ด้วยตนเอง auth login จะตรวจสอบสิทธิ์ gcloud CLI application-default login ตรวจสอบสิทธิ์ Google Cloud SDK ที่แอปพลิเคชันของคุณใช้ ซึ่งการเรียก Vertex AI ของ ADK และตัวเชื่อมต่อ Python ของ Cloud SQL ต่างก็ต้องใช้ข้อมูลรับรองเริ่มต้นของแอปพลิเคชัน

ตั้งค่าโปรเจ็กต์ Google Cloud

เขียนตัวแปรตำแหน่งไปยัง .env ก่อนเรียกใช้สคริปต์การตั้งค่าโปรเจ็กต์

echo "GOOGLE_CLOUD_LOCATION=global" > .env
echo "REGION=us-central1" >> .env
  • GOOGLE_CLOUD_LOCATION=global ใช้สำหรับการเรียก Vertex AI / Gemini API
  • REGION=us-central1 ใช้สำหรับ Cloud SQL และโครงสร้างพื้นฐานอื่นๆ ของ GCP

ดาวน์โหลดและเรียกใช้สคริปต์การตั้งค่าโปรเจ็กต์ โดยจะสร้างหรือตรวจสอบโปรเจ็กต์ Google Cloud ที่มีการเรียกเก็บเงินแบบทดลองใช้ และบันทึกรหัสโปรเจ็กต์ไปยัง .env จากนั้นจึงส่งไปยังแหล่งที่มา

curl -sL https://raw.githubusercontent.com/alphinside/cloud-trial-project-setup/main/setup_verify_trial_project.sh -o setup_verify_trial_project.sh

bash setup_verify_trial_project.sh && source .env

เปิดใช้ API ที่จำเป็น

gcloud services enable \
  aiplatform.googleapis.com \
  sqladmin.googleapis.com \
  compute.googleapis.com \
  cloudresourcemanager.googleapis.com

จัดสรร Cloud SQL

ตั้งรหัสผ่านฐานข้อมูลและเพิ่มลงใน .env โดยทำดังนี้

export DB_PASSWORD=codelabpassword
echo "DB_PASSWORD=${DB_PASSWORD}" >> .env

สร้างอินสแตนซ์ Cloud SQL โดยทำดังนี้

gcloud sql instances create restaurant-db \
  --database-version=POSTGRES_17 \
  --edition=ENTERPRISE \
  --region=${REGION} \
  --availability-type=ZONAL \
  --tier=db-custom-1-3840 \
  --root-password=${DB_PASSWORD} \
  --enable-google-ml-integration \
  --database-flags cloudsql.enable_google_ml_integration=on &

ระดับ db-custom-1-3840 เป็นระดับขั้นต่ำที่จำเป็นสำหรับการผสานรวม Vertex AI ML แฟล็ก --enable-google-ml-integration ช่วยให้ Cloud SQL เรียกใช้โมเดลการฝัง Gemini จาก SQL ได้โดยตรง ซึ่งจะขับเคลื่อนฟีเจอร์การค้นหาเชิงความหมาย

ติดตั้งการอ้างอิง

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

source .env

เราจะใช้ uv เป็นเครื่องมือจัดการโปรเจ็กต์ Python uv เป็นเครื่องมือจัดการแพ็กเกจและโปรเจ็กต์ Python ที่รวดเร็วซึ่งเขียนด้วย Rust ( เอกสาร ) Codelab นี้ใช้เพื่อความเร็วและความเรียบง่าย ติดตั้งการอ้างอิง Python ด้วยคำสั่งต่อไปนี้

uv sync

จากนั้นอัปเดตไฟล์ .env ของตัวแทน ADK ด้วยการกำหนดค่าโปรเจ็กต์

cat > restaurant_concierge/.env <<EOF
GOOGLE_CLOUD_PROJECT=${GOOGLE_CLOUD_PROJECT}
GOOGLE_CLOUD_LOCATION=global
GOOGLE_GENAI_USE_VERTEXAI=True
EOF

ตอนนี้เราควรมีที่เก็บตัวแทน ADK เริ่มต้นที่จำเป็นทั้งหมดเพื่อใช้ทำงาน ตอนนี้มาพูดถึง Antigravity และการพัฒนาที่อิงตามข้อกำหนดในส่วนถัดไปกันในขณะที่รอให้ทุกอย่างพร้อม

3. สำรวจโค้ดเริ่มต้นและทำความเข้าใจการพัฒนาที่ขับเคลื่อนด้วยข้อกำหนด

ขั้นตอนนี้จะอธิบายโครงสร้างโค้ดเริ่มต้น แนะนำวิธีการพัฒนาที่ขับเคลื่อนด้วยข้อกำหนด สร้างฐานข้อมูล และยืนยันว่าเอเจนต์พื้นฐานทำงานได้ก่อนที่คุณจะเริ่มขยาย

โครงสร้างโปรเจ็กต์

เปิดโปรเจ็กต์ที่เก็บที่โคลนไว้ในโปรแกรมแก้ไข Antigravity แล้วตรวจสอบเลย์เอาต์ไดเรกทอรี

sdd-adk-agents-agy/
├── .agents/
│   ├── workflows/                 # SDD slash commands (/speckit.*) – manual trigger
│   │   ├── speckit.specify.md
│   │   ├── speckit.clarify.md
│   │   ├── speckit.plan.md
│   │   ├── speckit.tasks.md
│   │   ├── speckit.analyze.md
│   │   ├── speckit.implement.md
│   │   ├── speckit.checklist.md
│   │   └── speckit.constitution.md
│   ├── skills/                   # Antigravity skills (loaded on demand, agent determined)
│   │   ├── adk-agent-development/
│   │   │   ├── SKILL.md     # ADK patterns
│   │   │   └── examples/
│   │   │       ├── basic_agent.py
│   │   │       ├── Dockerfile
│   │   │       ├── server.py
│   │   │       ├── stateful_agent.py
│   │   │       ├── toolbox_agent.py
│   │   │       ├── tools_agent.py
│   │   │       └── tools.yaml
│   │   └── repo-research/
│   │       └── SKILL.md     # Repo analysis 
│   └── rules/               # Always-active context
├── .specify/                # spec-kit SDD templates and memory
│   ├── memory/constitution.md
│   ├── templates/
│   └── scripts/
├── restaurant_concierge/    # ADK agent package
│   ├── __init__.py
│   ├── agent.py             # LlmAgent + ToolContext tools + Toolbox integration
│   └── .env                 # Vertex AI configuration
├── server.py                # FastAPI server wrapping the agent
├── tools.yaml               # MCP Toolbox tool definitions
├── scripts/                 # Setup scripts
└── pyproject.toml

ไฟล์สำคัญ

ไฟล์การสมัครเป็นตัวแทน

  • restaurant_concierge/agent.py - Agent หลัก LlmAgent ที่รวมเครื่องมือฐานข้อมูล MCP Toolbox เข้ากับการติดตามค่ากำหนดด้านอาหารที่อิงตาม ToolContext เอเจนต์จะโหลดเครื่องมือทั้งหมดจากเซิร์ฟเวอร์กล่องเครื่องมือและเพิ่มฟังก์ชัน Python 2 รายการ (save_dietary_preference, get_dietary_preferences) ที่ใช้ ToolContext เพื่อจัดการสถานะ
  • tools.yaml — คำจำกัดความของเครื่องมือกล่องเครื่องมือ MCP เครื่องมือค้นหาในเมนู 3 รายการ ได้แก่ การค้นหาคีย์เวิร์ด (search_menu) การค้นหาเชิงความหมายผ่าน pgvector (semantic_search_menu) และตัวกรองหมวดหมู่ (get_menu_by_category) ยังไม่มีเครื่องมือการจอง คุณจะเพิ่มเครื่องมือเหล่านั้นได้ในภายหลัง
  • server.py — เซิร์ฟเวอร์ FastAPI ขนาดเล็กที่แสดงวิธีเข้าถึง ADK เป็นออบเจ็กต์ FastAPI get_fast_api_app() จาก ADK มีปลายทางในตัว ซึ่งรวมถึง /run_sse สำหรับ API การสตรีม SSE และการจัดการเซสชัน

Antigravity Files

  • .agents/skills/adk-agent-development/SKILL.md - ทักษะที่กำหนดค่าไว้ล่วงหน้า ( สร้างโดย Antigravity) ซึ่งมีรูปแบบอ้างอิงแบบย่อจาก Codelab ทั้ง 4 รายการของ ADK ขณะนี้ไม่ได้ใช้งาน (ไม่มี Frontmatter ของ YAML) คุณจะต้องอัปเดตในภายหลัง Antigravity จะโหลดทักษะนี้โดยอัตโนมัติเมื่อตรวจพบงานที่เกี่ยวข้องกับฟีเจอร์ของเอเจนต์ ADK และตัวอย่างของฟีเจอร์ ซึ่งเป็นความรู้ที่ช่วยแนะนำ Antigravity เมื่อวางแผนฟีเจอร์การจองในภายหลัง
  • .agents/skills/repo-research/SKILL.md — ทักษะที่สอน Antigravity วิธีวิเคราะห์ที่เก็บอย่างค่อยเป็นค่อยไปและสร้างเอกสารบริบทของโปรเจ็กต์ที่มีโครงสร้าง โดยจะใช้วิธีการ 4 ระยะ ได้แก่ การสแกนพื้นผิว (เฉพาะโครงสร้างไดเรกทอรี) ไฟล์การกำหนดค่าและข้อมูลเมตา จุดแรกเข้าและโมเดลข้อมูล จากนั้นจึงเจาะลึกแบบกำหนดเป้าหมาย โดยแต่ละระยะจะหยุดและเขียนผลการค้นพบก่อนที่จะไปยังระยะถัดไป เช่นเดียวกับทักษะ ADK ทักษะนี้จะไม่ได้ใช้งานจนกว่าคุณจะเพิ่ม YAML Frontmatter ในภายหลัง เมื่อเปิดใช้งานแล้ว ให้เรียกใช้เพื่อสร้าง .agents/rules/project-context.md ซึ่งเป็นเอกสารการเริ่มต้นใช้งานที่ครอบคลุมสถาปัตยกรรม การขึ้นต่อกันของรันไทม์ พื้นผิว API และอภิธานศัพท์ของโดเมน

การพัฒนาที่ขับเคลื่อนด้วยข้อมูลจำเพาะ: ตั้งแต่การวางแผนในตัวของ Antigravity ไปจนถึง SDD ที่มีโครงสร้าง

ผู้ช่วยเขียนโค้ด AI ช่วยให้สร้างโค้ดจากพรอมต์ได้อย่างง่ายดาย ความเสี่ยง: คุณอธิบายฟีเจอร์ในประโยคเดียว ผู้ช่วยเขียนโค้ดหลายร้อยบรรทัด และคุณยอมรับเพราะดูเหมือนจะถูกต้อง บางครั้งจะเรียกกรณีเช่นนี้ว่า "Vibe Coding" ซึ่งก็คือการเขียนโค้ดตามความรู้สึก โดยยอมรับหรือปฏิเสธเอาต์พุตตามความเหมาะสม ซึ่งเหมาะสำหรับต้นแบบและสคริปต์ที่ใช้แล้วทิ้ง ซึ่งจะทำให้เกิดปัญหาเมื่อโค้ดเบสมีขนาดใหญ่ขึ้น เมื่อฟีเจอร์ต่างๆ มีการโต้ตอบกัน หรือเมื่อคุณกลับมาดูโค้ดในอีกหลายสัปดาห์ต่อมาและไม่สามารถสร้างเหตุผลที่ใช้ในการตัดสินใจขึ้นมาใหม่ได้

b2a0753229d08ef3.png

การพัฒนาที่ขับเคลื่อนด้วยข้อกำหนด (SDD) จะเพิ่มโครงสร้างให้กับลูปนี้ ก่อนที่จะสร้างโค้ด คุณต้องเขียนข้อกำหนดก่อนว่าฟีเจอร์นี้ทำอะไร ใครเป็นผู้ใช้ และเกณฑ์ความสำเร็จคืออะไร ผู้ช่วย AI จะทำงานตามข้อกำหนดดังกล่าว และคุณก็เช่นกันเมื่อตรวจสอบเอาต์พุตของ AI ข้อกำหนดจะกลายเป็นแหล่งข้อมูลที่เชื่อถือได้เพียงแหล่งเดียวสำหรับเจตนา หากโค้ดแตกต่างจากข้อกำหนด คุณจะเห็นในรีวิว หากมีการเปลี่ยนแปลงข้อกำหนด คุณจะต้องอัปเดตข้อกำหนดก่อน แล้วจึงสร้างใหม่ การตัดสินใจจะได้รับการบันทึกไว้ ไม่ใช่การตัดสินใจแบบฉุกเฉิน

การแลกเปลี่ยนนี้เกิดขึ้นจริง โดย SDD จะช้ากว่า Vibe Coding ต่อฟีเจอร์ คุณเขียนเอกสารก่อนเขียนโค้ด แต่ผลตอบแทนจะเพิ่มขึ้นเรื่อยๆ การเปลี่ยนแปลงในอนาคตทุกครั้งในฐานของโค้ดจะมีบริบท การติดตั้งใช้งานที่ AI สร้างขึ้นทุกครั้งจะมีสัญญาที่ตรวจสอบได้ และคุณสามารถเริ่มตั้งค่าร่วมกับผู้ทำงานร่วมกัน (มนุษย์หรือ AI) ได้โดยชี้ให้ดูข้อกำหนดแทนที่จะอธิบายการตัดสินใจจากความทรงจำ

Antigravity ปฏิบัติตามหลักการพัฒนาที่อิงตามข้อกำหนดอยู่แล้ว เมื่อตั้งค่า Agent เป็นโหมดการวางแผน Agent จะสร้างอาร์ติแฟกต์ 2 รายการก่อนที่จะเขียนโค้ด

  • แผนการติดตั้งใช้งาน - ภาพรวมของแนวทางเทคนิคที่เสนอ การเปลี่ยนแปลงไฟล์ และการตัดสินใจด้านสถาปัตยกรรม 632169a236bc62cc.png
  • รายการงาน - รายละเอียดของรายการงานที่มีโครงสร้าง

795e47f4d98ae074.png

Antigravity ขอให้คุณตรวจสอบและอนุมัติอาร์ติแฟกต์เหล่านี้ก่อนดำเนินการ วงจรการวางแผนแล้วจึงนำไปใช้เป็นหัวใจสำคัญของการพัฒนาที่ขับเคลื่อนด้วยข้อกำหนด เนื่องจากข้อกำหนดเป็นตัวนำทางโค้ด ไม่ใช่ในทางกลับกัน

Codelab นี้จะต่อยอดจากพื้นฐานดังกล่าวด้วยเวิร์กโฟลว์ที่มีข้อจำกัดและมีการควบคุมเวอร์ชันโดยอิงตาม spec-kit ซึ่งเป็นเฟรมเวิร์กการพัฒนาที่อิงตามข้อกำหนดจาก GitHub ฟีเจอร์ทุกอย่างจะผ่านไปป์ไลน์ที่ตั้งใจไว้ โดยแต่ละอาร์ติแฟกต์จะเป็นเอกสารแบบสแตนด์อโลนที่คุณสามารถตรวจสอบ แก้ไข และติดตามใน git ได้ ไปป์ไลน์มี 2 เฟสที่เป็นตัวเลือกในการตรวจสอบคุณภาพ (ชี้แจงและวิเคราะห์) ซึ่งจะตรวจพบปัญหาต่างๆ ก่อนที่จะกลายเป็นปัญหาในการติดตั้งใช้งาน

ระยะ

อาร์ติแฟกต์

Purpose

/speckit.specify

spec.md

กำหนดสิ่งที่จะสร้าง (แสดงต่อผู้ใช้ ไม่ขึ้นกับเทคโนโลยี)

/speckit.clarify (ไม่บังคับ)

อัปเดตเมื่อ spec.md

ระบุส่วนที่ไม่ได้ระบุรายละเอียด ถามคำถามที่เจาะจงเพื่อขอคำชี้แจง และเข้ารหัสคำตอบกลับลงในข้อกำหนด

/speckit.plan

plan.md, data-model.md, research.md

ออกแบบวิธีการสร้าง (แนวทางด้านเทคนิค รูปแบบข้อมูล การวิจัย)

/speckit.tasks

tasks.md

แบ่งแผนออกเป็นขั้นตอนที่เรียงตามลำดับและนำไปใช้ได้จริง

/speckit.analyze (ไม่บังคับ)

รายงานการวิเคราะห์

ตรวจสอบงานเพื่อหาความเสี่ยง ช่องว่าง หรือกรณีขอบที่ขาดหายไปก่อนการติดตั้งใช้งาน

/speckit.implement

การเปลี่ยนแปลงโค้ด

ทำงานโดยทำเครื่องหมายแต่ละงาน

c0164b540ee0afa1.png

ระบบจะบันทึกอาร์ติแฟกต์ทุกรายการเป็นไฟล์ใน specs/<feature-branch>/ ควบคุมเวอร์ชันใน Git และนำกลับมาใช้ใหม่ได้ หากการสนทนาถูกขัดจังหวะหรือคุณต้องการกลับมาดูการตัดสินใจในภายหลัง เอกสารข้อกำหนดจะพร้อมให้คุณดูเสมอ โดยจะไม่ฝังอยู่ในประวัติการแชท

ที่เก็บเริ่มต้นมีเวิร์กโฟลว์ SDD เหล่านี้ใน .agents/workflows/ และเทมเพลตใน .specify/templates/ คุณจะใช้ฟังก์ชันเหล่านี้ในภายหลังเพื่อเพิ่มฟีเจอร์ลงในเอเจนต์

4. ตั้งค่า Cloud SQL ให้เสร็จสมบูรณ์และตรวจสอบว่า Base Agent ทำงานได้

กลับไปที่แท็บเทอร์มินัลที่คำสั่งสร้าง Cloud SQL กำลังทำงานอยู่ เมื่อเสร็จแล้ว ให้ตรวจสอบว่าอินสแตนซ์พร้อมใช้งาน

gcloud sql instances describe restaurant-db --format="value(state)"

หากเอาต์พุตแสดง RUNNABLE ให้ดำเนินการต่อ หากแสดง PENDING_CREATE ให้รอสักครู่แล้วเรียกใช้คำสั่งอีกครั้ง

ให้สิทธิ์เข้าถึง Vertex AI แก่บัญชีบริการ Cloud SQL (จำเป็นสำหรับฟังก์ชันการฝังในฐานข้อมูล) โดยทำดังนี้

SERVICE_ACCOUNT=$(gcloud sql instances describe restaurant-db --format="value(serviceAccountEmailAddress)")

gcloud projects add-iam-policy-binding $GOOGLE_CLOUD_PROJECT \
  --member="serviceAccount:$SERVICE_ACCOUNT" \
  --role="roles/aiplatform.user" \
  --quiet

สร้างฐานข้อมูล

gcloud sql databases create restaurant_db --instance=restaurant-db

คุณควรเห็นเอาต์พุตดังนี้

Creating Cloud SQL database...done.
Created database [restaurant_db].
instance: restaurant-db
name: restaurant_db
project: <your-project-id>

เริ่มต้นฐานข้อมูล

โหลดตัวแปรสภาพแวดล้อมและเรียกใช้สคริปต์การเริ่มต้นฐานข้อมูลเพื่อสร้างสคีมาและแทรกรายการในเมนู 16 รายการ

source .env
uv run python scripts/seed_db.py

ผลลัพธ์ที่คาดไว้

Creating extensions...
Creating menu_items table...
Inserting 16 menu items...
Seeded 16 menu items.
Done.

สร้างการฝังเวกเตอร์สำหรับการค้นหาเชิงความหมาย

uv run python scripts/generate_embeddings.py

ผลลัพธ์ที่คาดไว้

Generating embeddings for 16 menu items...
Generated embeddings for 16 menu items.

ซึ่งใช้ฟังก์ชัน embedding() ในตัวของ Cloud SQL (ผ่านส่วนขยาย google_ml_integration) เพื่อเรียกใช้ gemini-embedding-001 โดยตรงจาก SQL ระบบจะจัดเก็บเวกเตอร์ 3072 มิติในคอลัมน์ embedding ของ menu_items โดยไม่จำเป็นต้องใช้โค้ดฝังในฝั่งแอปพลิเคชัน

ทดสอบ Agent พื้นฐาน

เริ่ม MCP Toolbox เป็นกระบวนการเบื้องหลัง

set -a; source .env; set +a # Export env variables to child process
toolbox --tools-file tools.yaml --address 127.0.0.1 --port 5000 &

กล่องเครื่องมือจะให้บริการเครื่องมือฐานข้อมูลผ่าน HTTP ตัวแทนจะเชื่อมต่อกับคุณในเวลา http://127.0.0.1:5000

เปิด UI สำหรับนักพัฒนาแอป ADK โดยทำดังนี้

uv run adk web .

เปิด UI สำหรับนักพัฒนาซอฟต์แวร์ในเบราว์เซอร์ จากนั้นทดสอบ Agent ด้วยพรอมต์ต่อไปนี้

What appetizers do you have?
I'm vegetarian
Can I make a reservation for tomorrow?

fc693b9435b93493.png

หยุด UI สำหรับนักพัฒนาแอป ADK โดยกด Ctrl+C 2 ครั้ง ปล่อยให้กล่องเครื่องมือทำงานในเบื้องหลัง เนื่องจากคุณจะต้องใช้กล่องเครื่องมืออีกในภายหลัง

5. บริบทของโปรเจ็กต์ Bootstrap ด้วย Antigravity

ตอนนี้มาจำลองสถานการณ์ด้วยเงื่อนไขที่ "ค่อนข้างใกล้เคียง" กับงานประจำของเรากัน

  • ที่เก็บที่ไม่ได้จัดการอย่างดี
  • README ล้าสมัย
  • เอกสารประกอบที่ไม่ได้อัปเดตบ่อย

สิ่งแรกที่เราต้องการทำในสถานการณ์เช่นนี้คือการสร้างแผนที่หรือบริบทเกี่ยวกับโปรเจ็กต์ที่เราต้องการให้ Antigravity ทำ ขั้นตอนนี้แสดงตัวอย่างแนวทางในการช่วยให้ Antigravity เข้าใจฐานของโค้ดที่มีอยู่ได้อย่างลึกซึ้งโดยการสร้างทักษะที่วิเคราะห์ที่เก็บและสร้างเอกสารบริบทของโปรเจ็กต์

นอกจากนี้ ยังกำหนดธรรมนูญของโปรเจ็กต์ ซึ่งเป็นหลักการที่ต่อรองไม่ได้ซึ่งเวิร์กโฟลว์ SDD จะตรวจสอบ ซึ่งจะช่วยให้ Antigravity มีบริบทและข้อจำกัดที่จำเป็นสำหรับรอบ SDD ในภายหลัง

ลำดับชั้นบริบทของ Antigravity

Antigravity ใช้บริบท 3 ระดับ โดยแต่ละระดับมีขอบเขตที่แตกต่างกัน ดังนี้

  • กฎ (.agents/rules/): คำสั่งที่ใช้งานอยู่เสมอ ทุกการสนทนาในพื้นที่ทำงานนี้จะเห็นกฎ ( หากคุณเปิดใช้งาน) ใช้กฎสำหรับบริบททั่วทั้งโปรเจ็กต์ เช่น การตัดสินใจด้านสถาปัตยกรรม มาตรฐานการเขียนโค้ด หรือข้อมูล Technology Stack
  • ทักษะ (.agents/skills/): ความรู้แบบออนดีมานด์ Antigravity จะโหลดทักษะเมื่องานปัจจุบันตรงกับฟิลด์ description ของทักษะเท่านั้น ใช้ทักษะสำหรับข้อมูลอ้างอิงเฉพาะโดเมน
  • เวิร์กโฟลว์ (.agents/workflows/): พรอมต์ที่บันทึกไว้ซึ่งทริกเกอร์ด้วยคำสั่ง / ใช้เวิร์กโฟลว์สำหรับกระบวนการแบบหลายขั้นตอนที่ทำซ้ำได้ เช่น ไปป์ไลน์ SDD

เปิดใช้งานสกิล

ที่เก็บเริ่มต้นมีทักษะที่เขียนไว้ล่วงหน้า 2 รายการใน .agents/skills/ โดยจะมีวิธีการโดยละเอียด แต่จะเริ่มต้นด้วยTODO(codelab)ความคิดเห็นแทนที่จะเป็น Frontmatter ของ YAML ที่จำเป็น หากไม่มี Frontmatter Antigravity จะค้นหาไม่ได้

ทักษะการต้านแรงโน้มถ่วงต้องมีบล็อก Frontmatter ของ YAML ที่ด้านบนของไฟล์ที่มี 2 ฟิลด์ดังนี้

  • name — ตัวระบุที่ไม่ซ้ำกันสำหรับทักษะ
  • description - ข้อมูลสรุปภาษาธรรมชาติที่ Antigravity จะจับคู่เมื่อตัดสินใจว่าจะโหลดทักษะใดสำหรับคำขอที่ระบุ

เปิด

.agents/skills/adk-agent-development/SKILL.md

ในเครื่องมือแก้ไข แทนที่บรรทัดความคิดเห็น 2 บรรทัดที่ด้านบนด้วย Frontmatter นี้TODO(codelab)

---
name: adk-agent-development
description: Comprehensive guide for building, developing, and deploying AI agents using Google's Agent Development Kit (ADK) with Gemini models, covering agent creation, tools, state management, persistence, deployment, and database integration via MCP Toolbox.
---

เปิด

.agents/skills/repo-research/SKILL.md

ในเครื่องมือแก้ไข แทนที่บรรทัดความคิดเห็น 2 บรรทัดที่ด้านบนด้วย Frontmatter นี้TODO(codelab)

---
name: repo-research
description: Analyze a repository's structure, technologies, and patterns to create or update a project context document. Use when asked to research, analyze, or understand a codebase.
---

ตรวจสอบว่าทักษะทั้ง 2 มี Frontmatter ที่ถูกต้อง

head -4 .agents/skills/adk-agent-development/SKILL.md
head -4 .agents/skills/repo-research/SKILL.md

แต่ละรายการควรแสดงตัวคั่น --- ที่ครอบฟิลด์ name: และ description: หากไม่มีตัวคั่นหรือฟิลด์ Antigravity จะไม่รู้จักทักษะ

โดยระบบจะโหลดทั้ง 2 ทักษะตามความต้องการ ซึ่ง Antigravity จะจับคู่คำขอของคุณกับฟิลด์ description และดึงวิธีการทั้งหมดเมื่อเกี่ยวข้องเท่านั้น

สร้างบริบทของโปรเจ็กต์

ตรวจสอบว่ามีไดเรกทอรีของกฎอยู่

mkdir -p .agents/rules

ในกล่อง Agent Manager/Chat ของ Antigravity (ในโหมดเอดิเตอร์ ให้กด ctrl + L) ให้เริ่มการสนทนาใหม่ ประเภท:

Research this repository and create a project context document

Antigravity จะจับคู่คำขอของคุณกับทักษะ repo-research และเริ่มวิเคราะห์ฐานของโค้ดอย่างเป็นระบบ โดยจะอ่านไฟล์การกำหนดค่า ซอร์สโค้ด และเอกสารประกอบ จากนั้นจะป้อนข้อมูลลงในเทมเพลตบริบทของโปรเจ็กต์ด้วยสิ่งที่พบ

เมื่อเสร็จแล้ว ให้เปิด .agents/rules/project-context.md ในเอดิเตอร์ ซึ่งมีข้อมูลที่ชัดเจนเกี่ยวกับโปรเจ็กต์ ได้แก่ Technology Stack (Python 3.12, ADK, MCP Toolbox, Cloud SQL), โครงสร้างโปรเจ็กต์, โมเดลข้อมูล (ตาราง menu_items ที่มี pgvector) และการผสานรวมภายนอก

9949388b3e1f401a.png

กำหนดธรรมนูญของโปรเจ็กต์

เวิร์กโฟลว์ SDD อ้างอิงถึงธรรมนูญของโปรเจ็กต์ที่ .specify/memory/constitution.md ระหว่างการวางแผนและการวิเคราะห์ /speckit.plan เวิร์กโฟลว์จะเรียกใช้ "การตรวจสอบรัฐธรรมนูญ" กับข้อความดังกล่าว และ/speckit.analyze จะแจ้งว่ามีการละเมิดเป็น "วิกฤต" หากปล่อยให้รัฐธรรมนูญเป็นเทมเพลตเปล่าที่มีโทเค็นตัวยึดตำแหน่ง การตรวจสอบเหล่านี้จะไม่มีสิ่งใดให้ตรวจสอบ แผนและการวิเคราะห์จะทำงานโดยไม่มีการควบคุม

รัฐธรรมนูญกำหนดหลักการของโปรเจ็กต์ที่ต่อรองไม่ได้ ที่เก็บนี้เป็นที่เก็บขนาดเล็กที่ดูแลโดยนักพัฒนาซอฟต์แวร์เพียงคนเดียว ดังนั้นรัฐธรรมนูญควรสะท้อนถึงขอบเขตดังกล่าว นั่นคือทำให้เรียบง่าย สอดคล้องกัน และหลีกเลี่ยงการออกแบบที่ซับซ้อนเกินไป

ใน Agent Manager ของ Antigravity ให้เริ่มการสนทนาใหม่ เรียกใช้เวิร์กโฟลว์รัฐธรรมนูญ

/speckit.constitution This is a small restaurant concierge ADK agent maintained by one developer. Set 3 principles: (1) All database operations go through MCP Toolbox tool definitions in tools.yaml  no raw SQL in Python code, no ORM. (2) Session state uses ADK ToolContext  no custom state management, no external state stores. (3) Keep it simple  follow existing file and naming conventions exactly.

Antigravity จะกรอกเทมเพลตรัฐธรรมนูญด้วยหลักการที่เป็นรูปธรรม กำหนดเวอร์ชัน (1.0.0) และเรียกใช้การตรวจสอบความสอดคล้องในเทมเพลต SDD

ตรวจสอบรัฐธรรมนูญที่สร้างขึ้นได้ที่ .specify/memory/constitution.md ตรวจสอบว่ามีหลักการทั้ง 3 ข้อและระบุไว้อย่างชัดเจน

276113749cd30834.png

6. วงจร SDD - เพิ่มฟีเจอร์การจอง

ขั้นตอนนี้จะอธิบายวงจร SDD ทั้งหมดเพื่อเพิ่มการจองห้องพักไปยังตัวแทนอำนวยความสะดวกของร้านอาหาร คุณขับเคลื่อน Antigravity ผ่านแต่ละเฟส ได้แก่ ระบุ ชี้แจง วางแผน งาน วิเคราะห์ และนำไปใช้ โดยสังเกตว่าอาร์ติแฟกต์แต่ละรายการสร้างขึ้นจากรายการก่อนหน้าอย่างไร ซึ่งเป็นประสบการณ์การเรียนรู้หลักของ Codelab

ระบุฟีเจอร์

ใน Agent Manager ของ Antigravity ให้เริ่มการสนทนาใหม่ พิมพ์/speckit.specifyคำสั่งเวิร์กโฟลว์พร้อมรายละเอียดฟีเจอร์

/speckit.specify Add reservation booking capability to the restaurant concierge agent. Guests should be able to make a table reservation by providing their name, party size, date, and time. They should also be able to check existing reservations. The agent should confirm reservation details before booking and handle special requests (e.g., "window seat", "birthday celebration").

Antigravity สร้างกิ่งก้านฟีเจอร์ สร้างเอกสารข้อกำหนด และเรียกใช้การตรวจสอบคุณภาพ หาก Antigravity ถามคำถามเพื่อขอคำชี้แจง ให้ตอบคำถามตามรายละเอียดฟีเจอร์ด้านบน

ข้อกำหนดจะเน้นที่ "อะไร" และ "ทำไม" ไม่ใช่ "อย่างไร" โดยอธิบายประสบการณ์ของผู้ใช้ ("แขกรับเชิญสามารถจองได้โดยระบุชื่อ จำนวนคน วันที่ และเวลา") โดยไม่ต้องพูดถึงตาราง SQL, tools.yaml หรือ ADK API รายละเอียดการใช้งานจะอยู่ในระยะการวางแผน

ตรวจสอบข้อกำหนดที่สร้างขึ้นที่ specs/<branch-name>/spec.md ตรวจสอบว่าข้อกำหนดดังกล่าวครอบคลุมข้อกำหนดด้านฟังก์ชันและเกณฑ์ความสำเร็จ

4ea3f72f9dfb4d35.png

ชี้แจงข้อกำหนด (ไม่บังคับ)

เรียกใช้เวิร์กโฟลว์การชี้แจงเพื่อระบุและแก้ไขพื้นที่ที่ระบุไม่ชัดเจนในข้อกำหนด

/speckit.clarify

Antigravity จะสแกนข้อกำหนดเพื่อหาความคลุมเครือ เกณฑ์การยอมรับที่ขาดหายไป และข้อกำหนดที่ระบุไม่ครบ โดยจะถามคำถามที่มุ่งเน้นการชี้แจง ซึ่งแต่ละคำถามสามารถตอบได้ด้วยการเลือกหรือวลีสั้นๆ ระบบจะเข้ารหัสคำตอบของคุณกลับลงในข้อกำหนดโดยตรง ซึ่งจะช่วยให้ข้อกำหนดมีความแม่นยำมากขึ้นก่อนที่จะเริ่มวางแผน

วางแผนการติดตั้งใช้งาน

เรียกใช้เวิร์กโฟลว์การวางแผน

/speckit.plan

Antigravity สร้างแผนทางเทคนิคผ่าน 2 ระยะดังนี้

  1. ระยะการวิจัย - แก้ไขสิ่งที่ไม่ทราบเกี่ยวกับโค้ดเบสที่มีอยู่ สร้าง research.md
  2. ช่วงออกแบบ - สร้าง data-model.md (คำจำกัดความของเอนทิตีการจอง) และอัปเดต project-context.md

Antigravity ควรใช้ทักษะ adk-agent-development ในระหว่างการวางแผน ตรวจสอบอาร์ติแฟกต์ที่สำคัญ

  • specs/<branch-name>/plan.md - แนวทางด้านเทคนิค: ไฟล์ที่จะแก้ไข รูปแบบที่ต้องทำตาม
  • specs/<branch-name>/data-model.md — คำจำกัดความของเอนทิตีการจอง (คอลัมน์ ประเภท ความสัมพันธ์)
  • specs/<branch-name>/research.md — การตัดสินใจและเหตุผล

d9996ccbb3211078.png

สร้างงาน

เรียกใช้เวิร์กโฟลว์ของงาน

/speckit.tasks

Antigravity จะแบ่งแผนออกเป็นรายการงานที่เรียงตามลำดับใน specs/<branch-name>/tasks.md งานจะเป็นไปตามรูปแบบรายการตรวจสอบที่เข้มงวดโดยมีรหัส เครื่องหมายลำดับความสำคัญ และเส้นทางไฟล์ เช่น

- [ ] [T001] [P] Create reservations table schema in scripts/seed_db.py
- [ ] [T002] [P] Add create_reservation tool to tools.yaml
- [ ] [T003] [P] Add list_reservations tool to tools.yaml
- [ ] [T004] [P] Update agent instruction in restaurant_concierge/agent.py

โดยงานจะจัดระเบียบเป็นระยะต่างๆ ได้แก่ การตั้งค่า → พื้นฐาน → สตอรี่ของผู้ใช้ → การปรับแต่ง สแกนรายการงานเพื่อทำความเข้าใจว่าระบบจะสร้างและแก้ไขอะไร

9fcdb822d8279ddf.png

วิเคราะห์งาน (ไม่บังคับ)

เรียกใช้เวิร์กโฟลว์การวิเคราะห์เพื่อตรวจสอบงานสำหรับความเสี่ยงและช่องว่าง

/speckit.analyze

Antigravity จะตรวจสอบรายการงานกับข้อกำหนดและแผน โดยมองหางานที่อาจขัดแย้งกัน หรือช่องว่างระหว่างข้อกำหนดของข้อกำหนดกับงานที่วางแผนไว้ แก้ไขปัญหาร้ายแรงก่อนที่จะนำไปใช้

7. ใช้งาน

เรียกใช้เวิร์กโฟลว์การติดตั้งใช้งาน

/speckit.implement

Antigravity จะนำเสนอแผนการติดตั้งใช้งานขั้นสุดท้ายและอาร์ติแฟกต์ของงาน ตรวจสอบและอนุมัติเพื่อดำเนินการต่อ

adc1e3d098bd1638.png

306448e70f61ab51.png

Antigravity จะดำเนินการตามงานและทำเครื่องหมายแต่ละงานเมื่อเสร็จสิ้น เมื่อเสร็จแล้ว ระบบจะแสดงคำแนะนำแบบทีละขั้นที่สมบูรณ์

48cc7752817a54c7.png

ทดสอบการเปลี่ยนแปลงโค้ด

หลังจากติดตั้งใช้งานเสร็จแล้ว ให้ยืนยันว่ามีการเปลี่ยนแปลงคีย์ ชื่อไฟล์และเนื้อหาที่แน่นอนอาจแตกต่างกันไป แต่ควรมีรูปแบบเหล่านี้เหมือนใน tools.yaml และ agent.py

# Verify reservation tools were added to tools.yaml
grep -i "reservation" tools.yaml

คุณจะเห็นเอาต์พุตบางอย่างในลักษณะนี้

...
get_reservations_by_name:
      Retrieve all reservations for a guest by their name. Uses case-insensitive
      SELECT id, guest_name, party_size, reservation_datetime, special_requests, created_at
      FROM reservations
      ORDER BY reservation_datetime DESC
...

และสำหรับ agent.py

# Verify agent instruction was updated
grep -i "reservation" restaurant_concierge/agent.py

# Check what files changed
git diff --name-only

คุณอาจเห็นการเปลี่ยนแปลงเช่นนี้

...
- **Table Reservations**: Help guests book a table or check their existing reservations.
## Reservation Booking Rules
When a guest wants to make a reservation, collect ALL of the following before confirming:
**IMPORTANT**: Before calling `book_reservation`, you MUST:
- Only call `book_reservation` after the guest says "yes" or "confirm"
## Checking Reservations
When a guest asks to check their reservations:
- Use `get_reservations_by_name` to find their bookings
        book_reservation,
...

การเปลี่ยนแปลงควรส่งผลต่อสคริปต์ฐานข้อมูลเริ่มต้น ลองเรียกใช้สคริปต์กัน

source .env
uv run python scripts/seed_db.py

สคริปต์ที่อัปเดตแล้วควรสร้างตาราง reservations หากยังไม่มี คุณควรเห็นเอาต์พุตที่ยืนยันว่าได้สร้างตารางใหม่แล้ว (menu_itemsข้อมูลที่มีอยู่จะยังคงอยู่)

หากทุกอย่างเป็นไปด้วยดีจนถึงตอนนี้ เราจะทดสอบฟีเจอร์ใน UI สำหรับนักพัฒนาซอฟต์แวร์ของตัวแทน ADK ได้ รีสตาร์ทกล่องเครื่องมือเพื่อรับคำจำกัดความเครื่องมือใหม่ใน tools.yaml หยุดกระบวนการ Toolbox ที่มีอยู่ แล้วเริ่มกระบวนการใหม่โดยทำดังนี้

pkill -f toolbox 2>/dev/null
toolbox --tools-file tools.yaml --address 127.0.0.1 --port 5000 &

เปิด UI สำหรับนักพัฒนาแอป ADK โดยทำดังนี้

uv run adk web .

เปิด http://localhost:8000 ในเบราว์เซอร์ แล้วทดสอบด้วยพรอมต์ต่อไปนี้

I'd like to book a table for 4 people on Friday at 7pm under the name Timmy
Do I have any upcoming reservations?

d9815389df37ed1a.png

f38a944851e28c29.png

ตอนนี้ให้หยุด UI สำหรับนักพัฒนาแอป ADK โดยกด Ctrl+C 2 ครั้ง

8. ชาเลนจ์ (ไม่บังคับ)

ตอนนี้คุณก็ทราบเวิร์กโฟลว์ SDD ทั้งหมดแล้ว ลองทดสอบดู

  • เรียกใช้รอบ SDD ที่ 2 เพื่อสร้างอินเทอร์เฟซแชทบนเว็บสำหรับเจ้าหน้าที่อำนวยความสะดวกของร้านอาหาร โดยครั้งนี้ไม่ต้องมีคำแนะนำแบบทีละขั้นตอน
  • ทำให้ Agent ใช้งานได้ใน Cloud Run สำหรับสถานการณ์ Production

คำแนะนำ

  • โปรเจ็กต์ไม่มีเฟรมเวิร์กส่วนหน้า Antigravity ควรเสนอ HTML/CSS/JS แบบดั้งเดิม หากแนะนำ React หรือคล้ายกัน ให้โน้มน้าวให้ใช้แบบเรียบง่าย (หลักการ "ทำให้เรียบง่าย" ของรัฐธรรมนูญควรจับประเด็นนี้ได้)
  • เซิร์ฟเวอร์ ADK จะแสดง /run_sse สำหรับการสตรีมและ /apps/{app_name}/users/{user_id}/sessions สำหรับการจัดการเซสชัน Antigravity จะค้นพบสิ่งเหล่านี้จากบริบทของโปรเจ็กต์
  • หลังจากติดตั้งใช้งานแล้ว ให้เริ่มเซิร์ฟเวอร์ด้วย uv run uvicorn server:app --host 0.0.0.0 --port 8080 (ไม่ใช่ adk web) เพื่อให้การต่อเชื่อมไฟล์แบบคงที่ทำงานได้
  • ทดสอบที่ http://localhost:8080/static/index.html
  • Codelab อ้างอิงแสดงวิธีทำให้ใช้งานได้และคงอยู่ของ ADK Agent อยู่แล้ว โปรดอ้างอิง Antigravity ถึง Codelab นี้

9. ยินดีด้วย

คุณได้ขยายตัวแทน ADK ของเจ้าหน้าที่อำนวยความสะดวกในร้านอาหารด้วยการจองที่นั่งผ่านเวิร์กโฟลว์ SDD ของ Antigravity โดยไม่ต้องเขียนโค้ดของแอปพลิเคชันด้วยตนเอง

สิ่งที่คุณสร้าง

  • เอเจนต์ ADK ของเจ้าหน้าที่อำนวยความสะดวกในร้านอาหารที่มีการค้นหาเมนู การค้นหาเชิงความหมาย การติดตามค่ากำหนดด้านอาหาร และการจอง
  • ทักษะ Antigravity สำหรับการวิจัยที่เก็บข้อมูลซึ่งสร้างและดูแลเอกสารบริบทของโปรเจ็กต์
  • ธรรมนูญของโปรเจ็กต์ที่บังคับใช้หลักการที่ต่อรองไม่ได้ในระหว่างการวางแผนและการวิเคราะห์
  • วงจร SDD ที่สมบูรณ์ซึ่งแสดงเวิร์กโฟลว์ระบุ → ชี้แจง → วางแผน → งาน → วิเคราะห์ → นำไปใช้

สิ่งที่คุณได้เรียนรู้

  • วิธีใช้เวิร์กโฟลว์ Spec-Driven Development ใน Antigravity เพื่อเพิ่มฟีเจอร์ลงในฐานของโค้ดที่มีอยู่แล้วอย่างเป็นระบบ
  • วิธีสร้างทักษะ Antigravity ที่รวมความรู้เฉพาะด้านเพื่อนำไปใช้ซ้ำในการสนทนา
  • วิธีเริ่มต้นบริบทของโปรเจ็กต์เพื่อให้ Antigravity ตัดสินใจอย่างมีข้อมูลเกี่ยวกับการเลือกสถาปัตยกรรม รูปแบบ และเทคโนโลยี
  • วิธีตั้งค่าธรรมนูญของโปรเจ็กต์ที่เวิร์กโฟลว์ SDD ตรวจสอบ
  • วิธีขยาย Agent ADK ด้วยเครื่องมือใหม่ที่ใช้ฐานข้อมูลผ่าน MCP Toolbox

ล้างข้อมูล

หยุดกระบวนการที่ทำงานในเครื่อง (กล่องเครื่องมือ)

pkill -f toolbox 2>/dev/null

ลบอินสแตนซ์ Cloud SQL เพื่อหลีกเลี่ยงการเรียกเก็บเงินอย่างต่อเนื่อง โดยทำดังนี้

gcloud sql instances delete restaurant-db --quiet

หากต้องการ คุณสามารถลบทั้งโปรเจ็กต์ได้โดยทำดังนี้

gcloud projects delete $GOOGLE_CLOUD_PROJECT