Chuyển đến nội dung chính
🤖 Consolidated, AI-optimized BMAD docs: llms-full.txt. Fetch this plain text file for complete context.

Ngăn xung đột giữa các agent

Khi nhiều agent AI cùng triển khai các phần khác nhau của hệ thống, chúng có thể đưa ra các quyết định kỹ thuật mâu thuẫn nhau. Tài liệu kiến trúc ngăn điều đó bằng cách thiết lập các tiêu chuẩn dùng chung.

Không có kiến trúc:

  • Agent A dùng REST với /users/{id}
  • Agent B dùng GraphQL mutations
  • Kết quả: pattern API không nhất quán, người dùng API bị rối

Có kiến trúc:

  • ADR quy định: “Dùng GraphQL cho mọi giao tiếp client-server”
  • Tất cả agent theo cùng một mẫu

Xung đột về thiết kế cơ sở dữ liệu

Phần tiêu đề “Xung đột về thiết kế cơ sở dữ liệu”

Không có kiến trúc:

  • Agent A dùng tên cột theo snake_case
  • Agent B dùng camelCase
  • Kết quả: schema không nhất quán, truy vấn khó hiểu

Có kiến trúc:

  • Tài liệu standards quy định quy ước đặt tên
  • Tất cả agent theo cùng một pattern

Không có kiến trúc:

  • Agent A dùng Redux cho global state
  • Agent B dùng React Context
  • Kết quả: nhiều cách quản lý state song song, độ phức tạp tăng cao

Có kiến trúc:

  • ADR quy định cách quản lý state
  • Tất cả agent triển khai thống nhất

Mỗi lựa chọn công nghệ quan trọng đều được ghi lại với:

  • Context (vì sao quyết định này quan trọng)
  • Các lựa chọn đã cân nhắc (có những phương án nào)
  • Quyết định (ta đã chọn gì)
  • Lý do (tại sao lại chọn như vậy)
  • Hệ quả (các đánh đổi được chấp nhận)

Kiến trúc ánh xạ mỗi functional requirement sang cách tiếp cận kỹ thuật:

  • FR-001: User Management → GraphQL mutations
  • FR-002: Mobile App → Truy vấn tối ưu

Tài liệu hóa rõ ràng về:

  • Cấu trúc thư mục
  • Quy ước đặt tên
  • Cách tổ chức code
  • Pattern kiểm thử

Hãy xem kiến trúc là bối cảnh dùng chung mà tất cả agent đều đọc trước khi triển khai:

PRD: "Cần xây gì"
Kiến trúc: "Xây như thế nào"
Agent A đọc kiến trúc → triển khai Epic 1
Agent B đọc kiến trúc → triển khai Epic 2
Agent C đọc kiến trúc → triển khai Epic 3
Kết quả: Triển khai nhất quán

Những quyết định phổ biến giúp tránh xung đột:

Chủ đềVí dụ quyết định
API StyleGraphQL hay REST hay gRPC
DatabasePostgreSQL hay MongoDB
AuthJWT hay Session
State ManagementRedux hay Context hay Zustand
StylingCSS Modules hay Tailwind hay Styled Components
TestingJest + Playwright hay Vitest + Cypress