1. 程式人生 > 其它 >k8s——yaml資源清單

k8s——yaml資源清單

目錄

一、yaml檔案詳解

1.Kubernetes支援YAML和JSON格式管理資源物件
2.JSON格式:主要用於api介面之間訊息的傳遞
3.YAML格式:用於配置和管理,YAML是一種簡潔的非標記性語言,內容格式人性化,較易讀

1.1 YAML語法格式

1.大小寫敏感
2.使用縮排表示層級關係
3.不支援Tab鍵製表符縮排,只使用空格縮排
4.縮排的空格數目不重要,只要相同層級的元素左側對齊即可,通常開頭縮排兩個空格
5.:字元後縮排一個空格,如冒號,逗號,短橫杆(-)等
6."—"表示YAML格式,一個檔案的開始,用於分隔檔案間
7.“#"表示註釋

1.2 檢視api資源版本標籤

kubectl api-versions
==========================================================
apps/v1
#如果是業務場景一般首選使用apps/v1
apps/v1beta1
#帶有beta字樣的代表的是測試版本,不用在生產環境中
==========================================================

1.3 編寫yaml檔案demo

1.3.1 編寫nginx-deployment的清單檔案

mkdir /opt/demo/
cd /opt/demo/
==========================================================
vim nginx-deployment.yaml
apiVersion: apps/v1   #指定api版本標籤
kind: Deployment   #定義資源的型別/角色,deployment為副本控制器,此處資源型別可以是Deployment、Job、Ingress、Service等
metadata:   #定義資源的元資料資訊,比如資源的名稱、namespace、標籤等資訊
  name: nginx-deployment   #定義資源的名稱,在同一個namespace空間中必須是唯一的
  namespace: kube-public   #定義名稱空間
  labels:          #定義資源標籤(Pod的標籤)
    app: nginx
spec:        #定義deployment資源需要的引數屬性,諸如是否在容器失敗時重新啟動容器的屬性
 replicas: 3     #定義副本數量
 selector :      #定義標籤選擇器
  matchLabels:   #定義匹配標籤
    app: nginx-111   #匹配下面的標籤,需與.spec.template.metadata.labels定義的標籤一致
 template:        #定義業務模板,如果有多個副本,所有副本的屬性會按照模板的相關配置進行匹配
  metadata:
    labels:       #定義pod副本將使用的標籤,需與.spec.selector.matchLabels定義的標籤保持一致
      app: nginx-111
  spec:
   containers:            #定義容器屬性
   - name: nginx          #定義一個容器名,一個- name: 定義一個容器
    image: nginx:1.15   #定義容器使用的映象以及版本
    ports:
    - containerPort: 80   #定義容器的對外的埠
=========================================================
#建立資源物件
kubectl apply -f nginx-deployment.yaml 
#檢視建立的pod資源
kubectl get pods -o wide -n kube-public --show-labels


1.3.2 編寫service服務的資源清單

vim nginx-service.yaml
apiVersion: v1
kind: Service
metadata :
  name: nginx-service
  namespace: kube-public
  labels:
    app: sb 
spec:
  type: NodePort
  ports :
  - port: 7777
   targetPort: 80
   nodePort: 31111
  selector :
   app: nginx-111 
==========================================================
#建立資源物件
kubectl create -f nginx-service.yaml
#檢視建立的service
kubectl get pods,svc -o wide -n kube-public --show-labels
#在瀏覽器輸入nodeIP:nodePort即可訪問
http://192.168.80.11:31111
http://192.168.80.12:31111
==========================================================
詳解k8s中的port:
●port
port是k8s叢集內部訪問service的埠,即通過clusterIP: port可以從Pod所在的Node. 上訪問到service 
●nodePort
nodePort是外部訪問k8s叢集中service的埠,通過nodeIP: nodePort 可以從外部訪問到某個service。
●targetPort
targetPort是Pod的埠,從port或nodePort來的流量經過kube-proxy 反向代理負載均衡轉發到後端Pod的targetPort上,最後進入容器。
●containerPort
containerPort是Pod內部容器的埠,targetPort對映到containerPort




1.4 用--dry-run命令生成yaml資源清單

//kubectl run --dry-run 列印相應的API物件而不執行建立
kubectl run nginx-test --image=nginx --port=80 --replicas=3 --dry-run

//檢視生成yaml格式
kubectl run nginx-test --image=nginx --port=80 --replicas=3 --dry-run -o yaml

//檢視生成json格式
kubectl run nginx-test --image=nginx --port=80 --replicas=3 --dry-run -o json 

//使用yaml格式匯出生成模板,並進行修改以及刪除一些不必要的引數
kubectl run nginx-test --image=nginx --port=80 --replicas=3 --dry-run -o yaml > nginx-test.yaml
==========================================================
vim nginx-test.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    run: nginx-test
  name: nginx-test
spec:
  replicas: 3
  selector:
    matchLabels:
      run: nginx-test
  template:
    metadata:
      labels:
        run: nginx-test
    spec:
      containers:
      - image: nginx
        name: nginx-test
        ports:
        - containerPort: 80
==========================================================
//建立資源物件
kubectl create -f nginx-test.yaml
#檢視建立的service
kubectl get pods -o wide --show-labels




1.5 將現有的資源生成模板匯出生成yaml檔案

//將現有的資源生成模板匯出I
kubectl get deployment nginx-test --export -o yaml

//儲存到檔案中
kubectl get deployment nginx-test --export -o yaml > gxd.yaml
==========================================================
vim gxd.yaml
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  labels:
    run: nginx-123
  name: nginx-456
spec:
  replicas: 3
  selector:
    matchLabels:
      run: nginx-gxd
  template:
    metadata:
      labels:
        run: nginx-gxd
    spec:
      containers:
      - image: nginx
        name: nginx-789
        ports:
        - containerPort: 80
          protocol: TCP
==========================================================
//建立資源物件
kubectl create -f gxd.yaml
#檢視建立的service
kubectl get pods -o wide --show-labels