All checks were successful
star-cloud-deploy-demo / deploy-demo (push) Successful in 57s
1. 將 B014 (參數下載) 與 B017 (貨道同步) 路由從 POST 改為 GET。 2. 移除 B017 冗餘的 machine 參數,改由 Bearer Token 自動識別。 3. 修正 B017 回傳資料中 expiry_date 的 ISO 8601 格式問題,統一為 Y-m-d。 4. 同步更新所有技術規格文件 (.agents/ 規範) 與 API 說明配置 (config/api-docs.php)。
4.7 KiB
4.7 KiB
name, description
| name | description |
|---|---|
| IoT 通訊與高併發處理規範 | 規範智能販賣機與 Cloud 平台間的高頻通訊處理流程,包含 API 接收、異步隊列、業務邏輯拆分與日誌記錄。 |
IoT 通訊與高併發處理規範 (IoT Communication Skill)
本規範確保 Star-Cloud 系統在處理成千上萬台機台的高頻發報時,能維持伺服器響應速度與資料一致性。
1. 處理管線 (Processing Pipeline)
所有來自機台的非即時性資料(日誌、心跳、狀態上報)必須遵循以下 pipeline。依據通訊協議不同,進入點有兩條路徑:
1.1 HTTP 管線 (低頻/大檔操作)
適用於 B000, B009, B012, B014, B017 等低頻、同步需求或大資料量的端點:
- API Controller (接收層):驗證 Request 合法性,隨即分派 (Dispatch) 任務至 Queue,並回傳
202 Accepted。 - Job (異步層):由背景 Worker 讀取隊列任務,呼叫對應 Service 處理。
- Service (邏輯層):封裝商業邏輯,更新資料庫。
- Model (儲存層):執行資料存取。
1.2 MQTT 管線 (高頻/即時操作)
適用於 B010 (心跳), B013 (異常), B600 (交易) 等高頻或即時性端點:
- Go Gateway (接收層):訂閱 EMQX Topic,提取
serial_no,包裝成標準 JSON。 - Redis List (橋接層):Go 執行
RPUSH mqtt_incoming_jobs {json}。 - Laravel
mqtt:listen(消費層):常駐指令BLPOP取出 JSON,根據type分派至對應 Job。 - Job ➜ Service ➜ Model:與 HTTP 管線後半段相同。
Tip
兩條管線的 Job / Service / Model 層完全共用,差異僅在「進入點」。這確保了業務邏輯不會因為通訊協議不同而分裂。
Important
嚴禁在 API Controller 直接進行資料庫寫入操作(針對機台發訊端點)。
2. 異步任務實作範例
2.1 API Endpoint
public function storeLog(Request $request, int $id): JsonResponse
{
// 1. 驗證
$data = $request->validate([...]);
// 2. 異步分派
ProcessMachineLog::dispatch($id, $data);
// 3. 快速回應
return $this->successResponse([], 'Accepted', 202);
}
2.2 Job 處理邏輯
Job 應保持單純,僅作為 Service 的觸發點:
public function handle(MachineService $service): void
{
$service->recordLog($this->machineId, $this->logData);
}
3. 隊列配置規範
- 連接驅動 (Driver):預設使用
Redis以確保高併發吞吐量。 - 重試機制 (Retry):IoT 任務應設定合理的重試次數,避免因網路短暫波動遺失日誌。
- 失敗處理 (Failed Jobs):關鍵業務(如訂單同步)必須監控
failed_jobs。
4. 速率限制 (Rate Limiting)
4.1 HTTP 端點
- 所有的 IoT HTTP API 必須在
routes/api.php中使用throttle:api或自定義 Middleware。 - 針對單一機台 ID 應限制其每一分鐘的最高連線數,防止遭受攻擊或機台 Bug 導致的連線暴衝。
4.2 MQTT 端點
- 限速由 EMQX Broker 的 Rate Limiting 功能負責(非 Laravel Middleware)。
- Go Gateway 層可額外實作簡易的 Token Bucket,當某台機台每秒超過閾值時丟棄訊息並記錄 Warning Log。
5. 檢核項目 (Checklist)
- 是否使用了
ApiResponseTrait? - 業務邏輯是否已封裝至
App\Services? - 是否使用了 Redis Queue 進行非同步處理?
6. API 規格定義 (API Specifications)
Important
規格分離原則:本技能僅規範「通訊處理邏輯」。關於具體的欄位定義與資料格式,請參閱對應的專屬技能規範:
- HTTP 端點:API 技術規格與通訊協議規範
- MQTT 端點:MQTT 即時通訊與 Topic 規範
常見端點處理模式
- B010 (心跳):高頻點,走 MQTT 管線 (
machine/+/heartbeat)。更新last_heard_at與感測器快照。 - B013 (異常):事件驅動點,走 MQTT 管線 (
machine/+/error)。寫入machine_logs並觸發告警。 - B600 (交易):高價值點,走 MQTT 管線 (
machine/+/transaction)。建立Transaction紀錄並支援重試。 - B012 (商品同步):大資料量,走 HTTP 管線。應確保 Service 層具備緩存 (Cache) 機制。
- B055 (遠端出貨):雲端下發指令,走 MQTT 下行管線 (
machine/{id}/command)。
Caution
身份識別機制:禁止在 Body 傳輸
machine或key。系統強制透過Bearer Token識別並自動關聯資料。