這邊介紹如何在GCP上安裝k8s cluster,整體而言,會參考之前GCP架構。
data:image/s3,"s3://crabby-images/eaf88/eaf8825c7ce107177dd3972776efd8f77fda87ee" alt="label"
整體步驟
1.準備一支Node.js應用程式
2.建立 Docker container image
3.把image推送並儲存在Container Registry
4.建立GKE Cluster,部署Hello Node
5.讓應用程式上線expose
開始前準備好GCP帳號與gcloud的client安裝
可以參考之前寫的內容
#開啟 cloud shell
data:image/s3,"s3://crabby-images/62567/6256745726ca99d6b7d3c3699da734bf74fa804f" alt="label"
用vi指令建一個Node.js檔案
vi server.js
1 | var http = require('http'); |
接著執行
1 | node server.js |
並在右上角的網頁預覽,可以進行預覽
data:image/s3,"s3://crabby-images/e3531/e35310febd24156413eedc115f9ba8ed9ad647ae" alt="label"
data:image/s3,"s3://crabby-images/49233/49233de4f2cb00661595fee733a5c509caa909f4" alt="label"
開始建立image
vi Dockerfile
1 | FROM node:6.9.2 |
用以下指令建立image,andylab-343008是你的projectID
1 | docker build -t gcr.io/andylab-343008/hello-node:v1 . |
過程中會要求授權
data:image/s3,"s3://crabby-images/d4247/d4247377d3a82e40fb02c99622d3089ed245e10e" alt="label"
等待並且看到成功建立image
data:image/s3,"s3://crabby-images/3b685/3b68575221340ab1b3b0779b11d91f9f830d50f4" alt="label"
data:image/s3,"s3://crabby-images/fdb0e/fdb0e88258c5e5918f477e6176ef34fe50a0160e" alt="label"
你可以執行一下docker指令,確認是否正常
1 | docker run -d -p 8080:8080 gcr.io/andylab-343008/hello-node:v1 |
data:image/s3,"s3://crabby-images/a7fda/a7fdaaaa5d92c18dee82384372a7981587762ff7" alt="label"
一樣透過網頁預覽,可以開啟網頁,同樣是看到Hello,World!就是成功了,就可以先暫時停止~
docker stop <CONTAINER ID>
把建立的image上傳到GCR
GCR (Google Container Registry),它是一個專門放image的地方。
這時候要用我們上面提到的gcloud來進行了~
先啟用GCR API服務
data:image/s3,"s3://crabby-images/c7b3e/c7b3ec4cea7f030c36c2cb724bcb321a4a376eb9" alt="label"
如果沒有啟用會收到錯誤訊息
data:image/s3,"s3://crabby-images/30717/30717a6594f1f0a7551ad020cff8daf9ab78bfbe" alt="label"
gcloud docker -- push gcr.io/andylab-343008/hello-node:v1
等待
data:image/s3,"s3://crabby-images/b54f7/b54f7a0559b83d17fec444c01dc7b0bf66b89f50" alt="label"
結束後至GCR的GUI介面查看,會發現多了一個image
data:image/s3,"s3://crabby-images/b56d9/b56d9addd0502cf2ba91751f2bbc67d0e50d8fb1" alt="label"
建立K8s Cluster
一樣要使用厲害的gcloud來建置, 首先先確保你的gcloud 所在的project是你想要的。
1 | gcloud config set project YOUR_PROJECT_ID |
先開啟 API service - container.googleapis.com 不然會無法建立cluster唷~
1 | gcloud services enable container.googleapis.com |
data:image/s3,"s3://crabby-images/10804/10804998f8c93cd18ba7dac1b76dc8c08da3a420" alt="label"
開始建立cluster,等待~
1 | gcloud container clusters create hello-world --num-nodes 2 --zone asia-east1-a --machine-type n1-standard-1 |
data:image/s3,"s3://crabby-images/96878/96878e64684823a419fc2ac580fc4222fe91c3eb" alt="label"
成功拉~
data:image/s3,"s3://crabby-images/fdbd2/fdbd2be230a689905bf3bf9475cf57045e2d999e" alt="label"
前往GKE確認一下
data:image/s3,"s3://crabby-images/b25c2/b25c2b8eb6e47db0e77d751c8234a3b04b05a349" alt="label"
將image 部署至 GKE上
先建立簡單的yaml試驗,之後再針對k8s講解~
vi deployment-hello.yaml
1 | apiVersion: apps/v1 |
1 | kubectl apply -f deployment-hello.yaml |
確認有建立了deployment
data:image/s3,"s3://crabby-images/d8d10/d8d10f404b5fadb8fdeacfbd3c6e3ffab404e45a" alt="label"
為了讓你的image對外露出,建立service
1 | kubectl expose deployment web-deployment --type LoadBalancer --port 8080 |
需等待一下,你會先看到Pending,這是很正常的~
data:image/s3,"s3://crabby-images/dd97f/dd97fcdb490edf8e525391fb90bd7fcd48661510" alt="label"
過幾分鐘後,會發現Pending變成IP了~
data:image/s3,"s3://crabby-images/555ff/555ffc3a798edab21b0712fbcead3863e71fa4b5" alt="label"
去GCP的網路服務-負載平衡確認,跑出一個LB拉~
data:image/s3,"s3://crabby-images/54335/5433535f57a927176e8f563ed3d923d19b2bbb42" alt="label"
於瀏覽器執行IP~
data:image/s3,"s3://crabby-images/87eb1/87eb120b946464291732fad45f79349b83cd32a7" alt="label"
結語
於公有雲上建立K8S相對容易許多,
這邊大家僅需要學習如何於GCP上建立K8S既可,
對於不熟悉K8S的人,可以先照著做~
後續在詳細的介紹docker與K8S。