
pod是容器化的基礎,好比大樓的地基,
Pod跟容器的關系
類比一下:
POD: 物理機
容器: 物理機上的一個行程;
容器只是Pod的一個普通欄位,
Pod的作用范圍
跟容器的linux namespace相關的東西一定是Pod級別的,pod,
比如:
網路: hostAliases : 寫入/ect/hosts內容 ; sharePrcessNamespace: 共享PID 空間
存盤: vlume
安全: secret
調度: NodeSelector 用戶指定pod跟node的對應關系 ; NodeName 標識調度過了,可用來除錯pod;
Pod的Container元素
containers和initContainers關系
initContainers先于containers創建 ; sidecar實作的重要基礎;按照定義的順序來執行;
containers: 容器定義
元素如下:
| 元素 | 說明 |
|---|---|
| image | 鏡像地址 |
| ports | 埠定義 |
| command | 啟動指令 |
| workingDir | 作業目錄 |
| volumeMounts | 資料卷掛載 |
| imagePullPolicy | 鏡像拉取策略 |
| lifecycle | 容器生命周期鉤子定義 preStop postStart |
Pod的問題定位
通過 spec.status.phase來定位;
pending:創建程序中,由于某些原因調度失敗
running: 正常運行中
succeed: 一次性調度成功
failed: 調度失敗
unknow: 未知
還可以結合 condition來定位:
unscheduled: 沒有調度
podScheduled: pod調度中
ready: 準備好
initalized: 初始化中
其它指令
attach: 進入容器的tty 命令列,如果有安裝的話;
kubectl attach -it youpodname -c youcontainername
小結
圍繞pod的核心欄位做了介紹,
示例組態檔:
apiVersion: apps/v1
kind: Pod
metadata:
name: my-pod
spec:
shareProcessNamespace: true
nodeSelector:
diskType: ssd
hostAliases:
- ip: "10.10.10.9"
hostnames:
- "a.b.com"
- "ac.b.com"
lifecycle:
postStart:
exec:
command: ["/bin/bash","-c","echo 'xxxx'> /usr/share/messages"]
preStop:
exec:
command: ["/usr/sbin/nginx","-t","quit"]

原創不易,關注誠可貴,轉發價更高!轉載請注明出處,讓我們互通有無,共同進步,歡迎溝通交流,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/260243.html
標籤:Java
上一篇:自制IOC容器(3)
下一篇:第一個Mybatis程式
