Files

GCP K8s 部署指南

概述

GCP 環境使用本地映像部署,不依賴 Docker Registry。

部署架構

本地/CI ──> docker build ──> docker save ──> scp ──> GCP VM
                                                      │
                                                      ▼
                                              k3s ctr images import
                                                      │
                                                      ▼
                                              kubectl rollout restart

快速部署

方法一:在 GCP VM 上執行

# SSH 到 GCP
gcloud compute ssh momo-pro-gcp --zone=asia-east1-b --project=astral-gateway-484913-d7

# 同步程式碼
cd ~/momo-pro-system
git pull

# 執行部署
./k8s/gcp/deploy.sh --full

方法二:從本地推送

# 在本地建構映像
docker build -t momo-pro-system:latest .

# 儲存並傳輸
docker save momo-pro-system:latest | gzip > /tmp/momo.tar.gz
scp /tmp/momo.tar.gz wooo@35.194.233.141:/tmp/

# SSH 到 GCP 執行匯入
ssh wooo@35.194.233.141 << 'EOF'
gunzip -c /tmp/momo.tar.gz | sudo k3s ctr images import -
sudo kubectl rollout restart deployment/momo-app deployment/momo-scheduler -n momo
rm /tmp/momo.tar.gz
EOF

方法三:透過 GitLab CI/CD

推送到 main 分支後,在 GitLab UI 手動觸發 deploy-gcp Job。

配置檔案說明

檔案 說明
00-namespace.yaml Kubernetes namespace
01-secrets.yaml 密碼和敏感資訊
02-configmap.yaml 環境變數配置
03-postgres.yaml PostgreSQL StatefulSet
04-momo-app.yaml 主應用 Deployment
05-scheduler.yaml 排程器 Deployment
deploy.sh 一鍵部署腳本

與 UAT 的差異

項目 UAT GCP
映像來源 Registry (registry.wooo.work) 本地構建
imagePullPolicy Always Never
imagePullSecrets registry-secret
Ollama AI http://192.168.0.188:11434 不可用 (內網)
AI Provider ollama gemini
域名 mo.wooo.work momo.wooo.work

常用命令

# 查看 Pod 狀態
sudo kubectl get pods -n momo

# 查看日誌
sudo kubectl logs -f deployment/momo-app -n momo

# 進入 Pod
sudo kubectl exec -it deployment/momo-app -n momo -- /bin/bash

# 重啟服務
sudo kubectl rollout restart deployment/momo-app -n momo

# 查看服務
sudo kubectl get svc -n momo

資料庫管理

# 進入 PostgreSQL
sudo kubectl exec -it momo-postgres-0 -n momo -- psql -U momo -d momo_analytics

# 備份資料庫
sudo kubectl exec momo-postgres-0 -n momo -- pg_dump -U momo momo_analytics > backup.sql

# 還原資料庫
cat backup.sql | sudo kubectl exec -i momo-postgres-0 -n momo -- psql -U momo momo_analytics

故障排除

Pod 無法啟動

# 查看詳細狀態
sudo kubectl describe pod -n momo <pod-name>

# 查看事件
sudo kubectl get events -n momo --sort-by='.lastTimestamp'

映像找不到

# 檢查映像是否已匯入
sudo k3s ctr images list | grep momo

# 重新匯入
docker save momo-pro-system:latest -o /tmp/momo.tar
sudo k3s ctr images import /tmp/momo.tar

連線問題

# 檢查服務
sudo kubectl get svc -n momo

# 測試內部連線
sudo kubectl exec -it deployment/momo-app -n momo -- curl -s http://momo-postgres:5432