首頁 >Java >java教程 >怎麼使用Kubernetes部署Springboot或Nginx

怎麼使用Kubernetes部署Springboot或Nginx

PHPz
PHPz轉載
2023-05-12 09:25:131142瀏覽

1 前言

這非常簡單,一個yaml檔案即可。

2 一鍵部署springboot

2.1 準備yaml檔案

當準備好鏡像檔案後,要部署到kubernetes就非常容易了,只需要一個yaml格式的檔案即可,這個檔案能描述你所需要的元件,如deploymentserviceingress等。定義如下:

apiversion: apps/v1
kind: deployment
metadata:
 name: pkslow-springboot-deployment
spec:
 selector:
 matchlabels:
  app: springboot
 replicas: 2
 template:
 metadata:
  labels:
  app: springboot
 spec:
  containers:
  - name: springboot
   image: pkslow/springboot-mongo:0.0.6
   ports:
   - containerport: 8080

---
apiversion: v1
kind: service
metadata:
 labels:
 app: springboot
 name: pkslow-springboot-service
spec:
 ports:
 - port: 8080
  name: springboot-service
  protocol: tcp
  targetport: 8080
  nodeport: 30080
 selector:
 app: springboot
 type: nodeport

kind:類型,有deploymentservicepodingress等,非常豐富;

metadata:用於定義一些元件信息,如名字、標籤等;

labels:標籤功能,非常有用,用於選擇關聯;但label不提供唯一性,可以使用組合來選擇;

nodeport:對於需要給外部暴露的服務,有三種方式:nodeportsloadbalanceringress,這裡使用nodeports;需要注意的是,預設它的連接埠範圍是[3000-32767],需要其它範圍則需要修改相關參數。

2.2 透過kubectl指令部署

yaml檔案準備好之後,就可以透過以下指令部署:

$ kubectl create -f pksow-springboot.yaml 
deployment.apps/pkslow-springboot-deployment created
service/pkslow-springboot-service created

看控制台日誌則表明成功創建了deploymentservice。查看dashboard如下:

怎麼使用Kubernetes部署Springboot或Nginx

訪問web服務:

怎麼使用Kubernetes部署Springboot或Nginx

透過命令列檢查一下:

$ kubectl get deployment
name       ready up-to-date available age
pkslow-springboot-deployment 2/2  2   2   8m2s

$ kubectl get service
name      type  cluster-ip  external-ip port(s)   age
kubernetes     clusterip 10.96.0.1  <none>  443/tcp   10m
pkslow-springboot-service nodeport 10.102.218.119 <none>  8080:30080/tcp 8m7s

$ kubectl get pod
name           ready status restarts age
pkslow-springboot-deployment-68dffc6795-874tp 1/1  running 0   8m15s
pkslow-springboot-deployment-68dffc6795-89xww 1/1  running 0   8m15s

至此,我們已經成功把springboot發佈到kubernetes了。

2.3 試試殺死一個pod?

kubernetes最小管理元素並不是容器,而是pod

怎麼使用Kubernetes部署Springboot或Nginx

我們試著刪掉一個pod,看看會發生什麼事?

$ kubectl delete pod pkslow-springboot-deployment-68dffc6795-89xww
pod "pkslow-springboot-deployment-68dffc6795-89xww" deleted

$ kubectl get pod
name           ready status restarts age
pkslow-springboot-deployment-68dffc6795-874tp 1/1  running 0   13m
pkslow-springboot-deployment-68dffc6795-gpw67 1/1  running 0   46s

可以發現,刪除了其它一個pod後,會自動為我們新產生一個pod,這樣能提高整個服務的高可用。

2.4 試試殺死一個容器?

我們再來探索一下如果殺死一個容器實例,會有什麼反應。

$ docker ps
$ docker rm -f 57869688a226
57869688a226

$ docker ps

經過實驗,殺死一個容器後,也會自動為我們重新產生一個容器實例。而pod並不會變化,也不會重新生成。

2.5 快速擴容pod

用戶請求突增,服務要撐不住了,這時需要增加pod的數量。只需要修改yaml設定檔的replicas,將它更新為replicas: 4。接著執行下列指令:

$ kubectl apply -f pksow-springboot.yaml

檢視dashboard,在原有兩個pod的基礎上,增加了兩個。

怎麼使用Kubernetes部署Springboot或Nginx

3 一鍵部署nginx

#如果大家沒有springboot的鏡像,可以使用官方的nginx鏡像,yaml檔案如下:

apiversion: apps/v1
kind: deployment
metadata:
 name: nginx-deployment
spec:
 selector:
 matchlabels:
  app: nginx
 replicas: 3
 template:
 metadata:
  labels:
  app: nginx
 spec:
  containers:
  - name: nginx
   image: nginx:1.19.0
   ports:
   - containerport: 80

---
apiversion: v1
kind: service
metadata:
 labels:
 app: nginx
 name: nginx-service
spec:
 ports:
 - port: 80
  name: nginx-service1
  protocol: tcp
  targetport: 80
  nodeport: 30000
 - port: 81
  name: nginx-service2
  protocol: tcp
  targetport: 80
  nodeport: 30001
 selector:
 app: nginx
 type: nodeport

執行部署指令:

$ kubectl apply -f nginx-deployment-scale.yaml 
deployment.apps/nginx-deployment created
service/nginx-service created

檢視dashboard如下:

怎麼使用Kubernetes部署Springboot或Nginx

存取服務: 或 。因為我們設定了兩個。

怎麼使用Kubernetes部署Springboot或Nginx

以上是怎麼使用Kubernetes部署Springboot或Nginx的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除