文章段落
Cloud Run 是 Google 推出的全代管的無伺服器平台,並可以在上面開發及部署具備高擴充性的容器化應用程式。
本文將帶大家利用 Docker 建立一個簡易的 API Server 並部署到 Cloud Run。
準備應用程式
我們使用 Python & FastAPI 來快速製作一個簡易的 API Server。
本文章的所使用開發環境及工具
- Python 3.8
- FastAPI
- Docker
- Git
先從 GitHub Clone 一份範例程式碼到你的主機
$ git clone https://github.com/CATaiwan/cloud-run-api-demo
Clone 完畢後進入 cloud-run-api-demo 資料夾
$ cd cloud-run-api-demo
使用 Docker 在你的主機上 build image
$ docker build -t cloud-run-api-demo:latest .
data:image/s3,"s3://crabby-images/504d6/504d6384444e551d74aa1a169bac8998229904f3" alt=""
完成後,接下來我們在主機上將剛建置完成的 docker image 跑起來並測試
$ docker run --rm -p 8000:8000 cloud-run-api-demo:latest
data:image/s3,"s3://crabby-images/1ad13/1ad1342eb57d5c346853676bc257fdf376b1649b" alt=""
在瀏覽器上測試: http://localhost:8000
data:image/s3,"s3://crabby-images/f4b8b/f4b8ba1342ad6c5ededf5acc29ffd1786b853ebb" alt=""
做到這裡我們的應用程式就準備完成了,
下一步我們將應用程式部署到 Cloud Run 。
部署前準備
開啟 Cloud Build Api
需要使用 Cloud Build 在 GCP 上建構 Docker image 並上傳至 GCR,
所以必需先到 GCP console 開啟 Cloud Build API。
開啟 GCP console > 選擇 Cloud Build > 點擊 Enable 按鈕。
data:image/s3,"s3://crabby-images/c0669/c066981d1217d130ab426dc9444368711a073622" alt=""
API 開啟完畢之後就可以使用 Cloud Build 囉。
安裝 Google Cloud SDK (gcloud)
接下來步驟我們會用到 gcloud 的指令來執行,所以需要先安裝https://cloud.google.com/sdk/docs/install
部署至 Cloud Run
初始化及設定 gcloud (設定 project, 權限)
$ gcloud init
使用 Cloud build 建置 docker image 並推送到 Container Registry
$ gcloud builds submit --tag asia.gcr.io/{project_id}/cloud-run-api-demo
data:image/s3,"s3://crabby-images/7bd63/7bd63ffc4ec5f4e1b9521b757e30459de0ed4679" alt=""
Cloud build 完成後就可以在 Container Registry 看到我們剛剛建置的 image
data:image/s3,"s3://crabby-images/6d23a/6d23ac688f111546acb95e605a84e637f726fa36" alt=""
將建置好的 Docker image 部署到 Cloud Run
$ gcloud run deploy --image asia.gcr.io/{project_id}/cloud-run-api-demo \
--platform managed \
--port 8000 \
--memory 1Gi \
--timeout=2m \
data:image/s3,"s3://crabby-images/c53bb/c53bb394fbcc29cdf2d7601f46d196ec9bd51a65" alt=""
部署完成後,會回傳 Service URL 在 Console 上可以直接連線做測試
data:image/s3,"s3://crabby-images/28a56/28a5692afca8d5d7e6ec530a2638aaf9faef1493" alt=""
從 GCP console 檢查 Cloud Run Service 有成功建置
data:image/s3,"s3://crabby-images/47f76/47f761c239025b29705a541707f2bc5c0354f493" alt=""
以上就是部署 API Service 至 Cloud Run 的介紹。
Source Code : https://github.com/CATaiwan/cloud-run-api-demo