k8s應用配置詳解


1. 概述

k8s主要通過Object定義各種部署任務(例如:部署應用、部署Ingress路由規則、部署service等等),通過kubectl命令遠程操作k8s集群。

Object的定義通常以Yaml格式進行描述。

Yaml是一種直觀的數據序列化格式,主要通過縮進的方式組織數據。

Yaml例子:

 
#  注釋
house:
  family:
    name: Doe
    parents: # - 開始,表示數組元素
      - John
      - Jane
    children:
      - Paul
      - Mark
      - Simone
  address:
    number: 34
    street: Main Street
    city: Nowheretown
    zipcode: 12345

 

 

定義好object文件后就可以通過kubectl命令將object發送給k8s服務器執行。

Object格式:

 
apiVersion: apps/v1 # k8s api版本
kind: Deployment  # Object類型
metadata:   # Object元數據定義,例如定義名字
  name: nginx-deployment
spec:  # Object 內容定義
  .....
status: # Object 運行狀態, 通常不需要我們定義,k8s負責更新
  ....

 

 

2.  kubectl 命令詳解

2.1. kubectl安裝&配置

安裝kubectl命令

 
#LINUX
curl -LO https://storage.googleapis.com/kubernetes-release/release/v1.14.0/bin/linux/amd64/kubectl
chmod +x ./kubectl
mv ./kubectl /usr/bin/kubectl
 
#Windows, 下載kubectl命令,然后配置下環境變量PATH,將kubectl的路徑加入到PATH
https://storage.googleapis.com/kubernetes-release/release/v1.14.0/bin/windows/amd64/kubectl.exe

 

 

配置k8s集群連接憑證

kubectl命令連接遠程服務器的配置默認存放在$HOME/.kube/config文件中,也可以通過指定--kubeconfig參數執行配置文件,例子:kubectl --kubeconfig ./k8s.conf  get pods

 

k8s集群的憑證,以阿里雲為例展示如何獲取:

復制下圖中的憑證保存到指定的位置即可

 

2.2. kubectl命令常用操作

 
#應用一個object配置, 至於部署什么,就看yaml配置文件定義了什么, 這里部署一個pod
kubectl apply -f ./pod.yaml
 
#kubectl get子命令用戶展示k8s資源,k8s資源就是我們通過object部署的東西。
#展示所有pod
kubectl get pods
 
#展示kube-system名字空間下的所有pod, 默認kubectl命令只是操作default默認名字空間,可以通過-n參數指定名字空間
kubectl get pods -n kube-system
 
#展示所有deployment
kubectl get deploy
 
#展示所有service(服務)
kubectl get svc
 
#展示所有ingress
kubectl get ingress
 
#以yaml格式,展示具體的ingress資源的配置, 展示任意資源具體的yaml配置命令格式:kubectl get 資源類型 資源名字 -o yaml
kubectl get ingress 資源名字 -o yaml
 
#刪除指定的資源,具體刪除內容由配置文件object定義
kubectl delete -f ./pod.yaml
 
#在容器中執行命令格式
kubectl exec 容器id  命令
 
#在admin-app-5f84f57f7-vthlf容器中,執行ls /alidata/www 命令
kubectl exec admin-app-5f84f57f7-vthlf ls /alidata/www
 
#在admin-app-5f84f57f7-vthlf容器中,打開shell交互窗口, 需要加上-it參數
kubectl exec -it admin-app-5f84f57f7-vthlf bash

 

 

3. k8s常用對象(Object)類型

3.1. deployment

主要用於部署pod,支持滾動升級。

 
apiVersion: apps/v1
#對象類型
kind: Deployment
metadata:
  name: nginx-deployment  #deployment名字
  labels:
    app: nginx   #deployment標簽,可以自由定義
spec:
  replicas: 3   #pod 副本數量
  selector:     #pod選擇器定義,主要用於定義根據什么標簽搜索需要管理的pod
    matchLabels:
      app: nginx  #pod標簽
  template:  #pod模版定義
    metadata:
      labels:   #pod 標簽定義
        app: nginx
    spec: 
      containers: #容器數組定義
      - name: nginx  #容器名
        image: nginx:1.7.9  #鏡像地址
        command: #容器啟動命令,【可選】
            - /alidata/www/scripts/start.sh
        ports:  #定義容器需要暴露的端口
            - containerPort: 80
        env: #環境變量定義【可選】
            - name: CONSOLE_URL #變量名
              value: https://www.xxx.com #變量值   

 

 

3.2. service

服務定義,主要用於暴露pods容器中的服務。

 
apiVersion: v1
#對象類型
kind: Service
metadata:
  name: my-service #服務名
spec:
  selector: #pod選擇器定義,由這里決定請求轉發給那些pod處理
    app: nginx #pod 標簽
  ports: #服務端口定義
  - protocol: TCP  #協議類型,主要就是TCP和UDP
    port: 80 # 服務端口
    targetPort: 80 #pod 容器暴露的端口

 

 

3.3. ingress

http路由規則定義,主要用於將service暴露到外網中

apiVersion: extensions/v1beta1
#對象類型
kind: Ingress
metadata:
  name: my-ingress #ingress應用名
spec:
  rules: #路由規則
    - host: www.xxx.com  #域名
      http:
        paths:  #訪問路徑定義
          - path: /   #代表所有請求路徑
            backend:  #將請求轉發至什么服務,什么端口
              serviceName: my-service #服務名
              servicePort: 80 #服務端口

 

 

3.4. ConfigMap

主要用於容器配置管理。

apiVersion: v1
kind: ConfigMap
metadata:
  name: my-config #配置項名字
data:
    key1: value1
    key2: value2

 

 

定義完配置后,可以通過以下方式在容器中應用配置:

#通過環境變量注入配置
apiVersion: v1
kind: Pod
metadata:
   name: config-pod-1
spec:
   containers:
     - name: test-container
       image: busybox
       command: [ "/bin/sh", "-c", "env" ]
       env:
         - name: SPECIAL_LEVEL_KEY                ## 環境變量
           valueFrom:                             ##使用valueFrom來指定env引用配置項的value值
             configMapKeyRef:
               name: my-config           ##引用的配置文件名稱
               key: key1                 ##引用的配置項key
   restartPolicy: Never
#通過數據卷注入配置
apiVersion: v1
kind: Pod
metadata:
   name: config-pod-4
spec:
   containers:
     - name: test-container
       image: busybox
       command: [ "/bin/sh", "-c", "ls /etc/config/" ]   ##列出該目錄下的文件名
       volumeMounts:
       - name: config-volume    #配置項名字
         mountPath: /etc/config #容器中的掛載目錄
   volumes:         #數據卷定義
     - name: config-volume  #數據卷名
       configMap:           #數據卷類型
         name: my-config    #配置項名字
   restartPolicy: Never


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM