通過一個實際例子理解Kubernetes裡pod的自動scale - 水平自動伸縮
kubectl scale命令用於程式在負載加重或縮小時進行pod擴容或縮小,我們通過一些實際例子來觀察scale命令到底能達到什麼效果。
命令列建立一個deployment:
kubectl run jerry-nginx --image=nginx:1.12.2
kubectl get deploy檢視剛剛建立的deployment:
自動被deployment建立的pod:
kubectl get pod:
使用下列命令檢視生成的deployment明細:
kubectl get deployment jerry-nginx -o yaml
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
annotations:
deployment.kubernetes.io/revision: "1"
creationTimestamp: 2018-11-29T08:29:06Z
generation: 1
labels:
run: jerry-nginx
name: jerry-nginx
namespace: part-0110
resourceVersion: "7203445"
selfLink: /apis/extensions/v1beta1/namespaces/part-0110/deployments/jerry-nginx
uid: d5c64f72-f3b0-11e8-b308-a20cb743f347
spec:
progressDeadlineSeconds: 600
replicas: 1
revisionHistoryLimit: 2
selector:
matchLabels:
run: jerry-nginx
strategy:
rollingUpdate:
maxSurge: 25%
maxUnavailable: 25%
type: RollingUpdate
template:
metadata:
creationTimestamp: null
labels:
run: jerry-nginx
spec:
containers:
- image: nginx:1.12.2
imagePullPolicy: IfNotPresent
name: jerry-nginx
resources: {}
terminationMessagePath: /dev/termination-log
terminationMessagePolicy: File
dnsPolicy: ClusterFirst
restartPolicy: Always
schedulerName: default-scheduler
securityContext: {}
terminationGracePeriodSeconds: 30
status:
availableReplicas: 1
conditions:
-
lastTransitionTime: 2018-11-29T08:29:07Z
lastUpdateTime: 2018-11-29T08:29:07Z
message: Deployment has minimum availability.
reason: MinimumReplicasAvailable
status: "True"
type: Available -
lastTransitionTime: 2018-11-29T08:29:06Z
lastUpdateTime: 2018-11-29T08:29:07Z
message: ReplicaSet "jerry-nginx-69fd9f6c4" has successfully progressed.
reason: NewReplicaSetAvailable
status: "True"
type: Progressing
observedGeneration: 1
readyReplicas: 1
replicas: 1
updatedReplicas: 1
另一個有用的命令:
kubectl describe deployment jerry-nginx
Name: jerry-nginx
Namespace: part-0110
CreationTimestamp: Thu, 29 Nov 2018 16:29:06 +0800
Labels: run=jerry-nginx
Annotations: deployment.kubernetes.io/revision: 1
Selector: run=jerry-nginx
Replicas: 1 desired | 1 updated | 1 total | 1 available | 0 unavailable
StrategyType: RollingUpdate
MinReadySeconds: 0
RollingUpdateStrategy: 25% max unavailable, 25% max surge
Pod Template:
Labels: run=jerry-nginx
Containers:
jerry-nginx:
Image: nginx:1.12.2
Port: <none>
Host Port: <none>
Environment: <none>
Mounts: <none>
Volumes: <none>
Conditions:
Type Status Reason
Available True MinimumReplicasAvailable
Progressing True NewReplicaSetAvailable
OldReplicaSets: <none>
NewReplicaSet: jerry-nginx-69fd9f6c4 (1/1 replicas created)
Events:
Type Reason Age From Message
Normal ScalingReplicaSet 9m41s deployment-controller Scaled up replica set jerry-nginx-69fd9f6c4 to 1
現在我們使用下面的命令對deployment進行水平擴充套件:
kubectl scale deployment jerry-nginx --replicas=3
kubectl get pods -l run=jerry-nginx
下圖這個Age為15分鐘之前的是第一次建立deployment時生成的,其他兩個Age為1分鐘之前的是執行了scale命令後自動建立的。
選中一個才建立的pod,檢視其事件記錄:
kubectl describe pod jerry-nginx-69fd9f6c4-8dpvb
kubectl get replicaset
得到自動建立的replication set:
desired = 3意思就是我們水平擴充套件時指定的引數3.
即使手動刪除一個pod例項,replication set又會很快自動建立一個新的:
自動建立的新pod:
要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/24475491/viewspace-2222388/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 基於Kubernetes的hpa實現pod例項數量的自動伸縮
- k8s 自動伸縮 pod(HPA)K8S
- k8s HPA(HorizontalPodAutoscaler)--自動水平伸縮K8S
- kubernetes實踐之四十一:Pod自動擴容與縮容
- 通過一個例子學習Kubernetes裡的PersistentVolumeClaim的用法AI
- 支援自動伸縮的消費者模式模式
- 通過一個實際的例子學習 combineLatest
- 在微服務領域Spring Boot自動伸縮如何實現微服務Spring Boot
- 一個例子體會Kubernetes內容器的高可用性和彈性伸縮
- 用一個實際例子理解Dockervolume工作原理Docker
- KEDA將事件驅動的自動縮放功能引入Kubernetes -新堆疊事件
- redis自學(37)叢集伸縮Redis
- 用一個實際例子理解Docker volume工作原理Docker
- Flutter | 通過一個小例子帶你認識動畫 AnimationFlutter動畫
- 如何使用Kubernetes的configmap通過環境變數注入到pod裡變數
- 通過實際的例子,介紹 SAP ABAP 裡的 Repository Information System 的使用技巧ORM
- Kubernetes:應用自動擴容、收縮與穩定更新
- GitLab整合kubernetes實現自動釋出Gitlab
- Docker Swarm + Harbor + Portainer 打造高可用,高伸縮,叢集自動化部署,更新。DockerSwarmAI
- Kubernetes pod裡一個特殊的容器:pause-amd64
- findimage 支援自動縮放了
- Javascript 實現 Textarea 自動伸縮,相容IE6、IE7、IE8、IE9...JavaScriptIE9
- Angular 原理圖 Schematics 學習 - 動手開發一個實際的例子Angular
- SAP CRM裡Lead通過工作流自動建立Opportunity的原理講解Unity
- Qt實現遮罩效果並可以拖動伸縮QT遮罩
- 基於DotNetty實現一個介面自動釋出工具 - 通訊實現Netty
- K8S(17)二進位制的1.15版本部署hpa自動伸縮K8S
- 如何理解Java中的自動拆箱和自動裝箱?Java
- 通過GitHub Action自動部署Maven專案GithubMaven
- 通過 PXE 自動化安裝 Ubuntu ServerUbuntuServer
- 如何使用 Kubernetes 實現應用程式的彈性伸縮
- iOS 元件化開發(四):fastlane實現pod自動化iOS元件化AST
- 通過Gradle自動實現Android元件化模組構建GradleAndroid元件化
- 透過現實生活中一個例子來理解 JavaScript PromiseJavaScriptPromise
- 自動化測試理解
- 透過一個具體的例子理解 npm 的 peerDependencyNPM
- 深入理解springboot的自動注入Spring Boot
- 一個簡單的例子理解Kubernetes的三種IP地址型別型別