自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Kubernetes-Init容器的六個特性

云計算
本文主要從以下四個方面介紹Init容器:Init容器作用、Init容器特性、Init容器與應(yīng)用容器的區(qū)別、Init容器實戰(zhàn)。

本文主要從以下4個方面介紹Init容器:Init容器作用、Init容器特性、Init容器與應(yīng)用容器的區(qū)別、Init容器實戰(zhàn)。

Kubernetes中的Pod內(nèi)可以運行多個容器,主要分為2種:Init容器、應(yīng)用容器,Sidecar容器也是一種特殊的Init容器。

Init容器的作用

Init 容器是一種特殊容器,在Pod內(nèi)的應(yīng)用容器啟動之前運行。用于執(zhí)行一些初始化的任務(wù)或設(shè)置,或者用于延遲執(zhí)行應(yīng)用容器。

有不少場景都需要在應(yīng)用容器啟動之前進(jìn)行部分初始化操作,比如:等待某個服務(wù)需要等待其關(guān)聯(lián)的服務(wù)可用后才啟動、從配置中心獲取配置后再啟動 等。

Init容器的特性

  • Pod中的所有Init容器按定義的順序串行運行,直到它們?nèi)砍晒Y(jié)束后,才能啟動應(yīng)用容器。
  • Init容器通常很小,執(zhí)行簡單的邏輯,它們以輕量的方式快速運行。
  • Init容器與編程語言中的初始化對象類似,只會執(zhí)行一次。
  • 在所有的 Init 容器沒有成功完成之前,Pod不會變成 Ready 狀態(tài)。
  • 某個Init容器運行失敗后,會導(dǎo)致整個Pod重新啟動(重啟策略為 Never 時例外)。如果 Pod 對應(yīng)的重啟策略為Never,并且 Pod 的 Init 容器失敗,則Kubernetes會將Pod狀態(tài)設(shè)置為失敗。
  • Pod重啟后,初始化容器也會再次運行,因此需要確保所有Init容器的操作具有冪等性。這一點與應(yīng)用開發(fā)中要保證某個接口的冪等性類似。

Init容器與應(yīng)用容器的關(guān)系

Init 容器與應(yīng)用容器非常像,Init容器支持應(yīng)用容器的全部字段和特性,包括資源限制、數(shù)據(jù)卷和安全設(shè)置,Init容器與應(yīng)用容器共享數(shù)據(jù)卷和網(wǎng)絡(luò)。關(guān)系如下圖:

但是Init容器與應(yīng)用容器也有三點不同:

  • 應(yīng)用容器運行后沒有特殊情況不會停止,他們持續(xù)提供服務(wù),沒有運行完成的概念。但是Init容器的存在就是為了初始化任務(wù),所以必須是一個從開始到結(jié)束的過程。
  • 應(yīng)用容器可以多個并行運行。但是Init容器必須當(dāng)前這個啟動完成后,才能啟動下一個。
  • Init容器的設(shè)計是為了完成初始化任務(wù),所以Init容器必須要在 Pod 就緒之前運行完成。自然的Init容器就不支持 生命周期、存活探針、就緒探針。

Init容器使用實戰(zhàn)

實戰(zhàn)描述

  • 定義一個Pod,Pod里定義了Init容器和應(yīng)用容器。
  • Pod里的Init容器先從網(wǎng)絡(luò)上下載數(shù)據(jù),將下載的數(shù)據(jù)放到emptyDir。
  • 等待init容器執(zhí)行完畢后,應(yīng)用容器會自動啟動,在應(yīng)用容器中掛載emptyDir,此時應(yīng)用容器可以看到Init容器之前下載的數(shù)據(jù)。

yaml編排文件如下

apiVersion: v1
kind: Pod
metadata:
  name: init-container-test
  namespace: demo
  labels:
    app: init-container-test
spec:
  nodeName: k8s-worker-1
  initContainers:
    - name: download
      image: busybox
      command:
        - wget
        - -O
        - /temp-dir/index.html
        - http://www.baidu.com
      volumeMounts:
        - name: temp-dir
          mountPath: /temp-dir
  containers:
    - name: web-app
      image: nginx
      ports:
        - containerPort: 80
          hostPort: 8082
      volumeMounts:
        - name: temp-dir
          mountPath: /usr/share/nginx/html
  volumes:
    - name: temp-dir
      emptyDir: {}

執(zhí)行kubectl describe pod init-container-test -n demo命令,可以看到有兩處容器:

如果Init容器執(zhí)行有異常,可以看到Pod會被不停地重啟。

總結(jié)

本文主要從以下四個方面介紹Init容器:Init容器作用、Init容器特性、Init容器與應(yīng)用容器的區(qū)別、Init容器實戰(zhàn)。

重點要注意:

  • Init容器按定義的順序串行運行。
  • 確保所有Init容器的操作具有冪等性。
責(zé)任編輯:趙寧寧 來源: 不焦躁的程序員
相關(guān)推薦

2012-06-15 11:30:55

ibmdw

2021-10-27 10:15:25

Python新特性編程語言

2021-12-02 10:17:07

Kubernetes公共云云計算

2022-02-10 19:46:19

Kubernetes云原生云安全

2023-08-04 12:07:11

2022-05-26 11:11:19

Kubernetes容器云安全

2020-07-02 15:43:26

Kubernetes容器工作負(fù)載

2023-04-19 15:26:52

JavaScriptES13開發(fā)

2021-11-11 15:13:15

人工智能容器技術(shù)

2022-11-15 16:54:54

2023-05-16 16:03:10

2022-06-28 10:17:23

安全職位首席信息安全官

2024-03-06 10:50:30

云計算云實例云提供商

2021-07-16 10:27:07

ITIT領(lǐng)導(dǎo)IT管理

2022-04-07 12:03:28

云安全CSPM云計算

2012-09-19 16:09:43

2016-07-25 18:10:55

2016-12-15 09:53:07

自學(xué)編程技巧

2023-09-28 13:27:40

Tailwind瀏覽器CSS

2024-03-11 14:34:04

JavaScript開發(fā)
點贊
收藏

51CTO技術(shù)棧公眾號