生成 Inventory 檔 (交互命令生成)

此處我們使用工具來自動生成 Inventory 檔案 (YAML 格式),請根據提示輸入對應資訊即可

  /outputs/gen-inventory.sh
  

執行後,該指令會將該鏡像內最新的參數檔放置到:

  • /inventory: Kubespray 安裝時會使用的參數檔 (實際會存放在前個步驟的 Host 位置)

  • /inventory/config.sh: 環境變數設定檔

  • Kubespray 不同版本間參數檔會有微幅修改,建議更換版本時能執行此指令以保證參數檔為最新內容

問答過程之參數解說與設定檔詳細說明

Deploy Server IP Address

部署時,各節點會連線至部署主機下載所需的安裝檔案/鏡像,設定時務必確定部署主機的 IP 地址可以被目標主機所連線

遠端 Container Registry

Kubernetes 啟動後,相關元件會嘗試從安裝時的 Registry 下載鏡像,因此需要在部署前將此次所用的到鏡像推送到企業內部 Container Registry 儲存,避免後續正常運作

修改腳本執行時套件下載路徑

執行生成腳本 (gen-inventory.sh) 後,會自動生成 /inventory/group_vars/all/offline.yml,以下僅為範例 (實際內容根據輸入參數會有所異動,切勿 Copy/Paste)

`L1`: 為 Container Registry
`L4`-`L6`: 請務必確認 `REGISTRY_HOST` 與 `REGISTRY_PORT` 是否與前面 Container Registry 設定相同
`L2`-`L17`: 請務必確認 `REGISTRY_REPO` 是否與前面 Container Repository 設定相同
registry_host: "<REGISTRY_HOST>:<REGISTRY_PORT>"

containerd_insecure_registries:
"<REGISTRY_HOST>:<REGISTRY_PORT>": "http://<REGISTRY_HOST>:<REGISTRY_PORT>"

files_repo: "<HOST_IP>/files"
yum_repo: "<HOST_IP>/rpms"
ubuntu_repo: "<HOST_IP>/debs"

# Registry overrides
kube_image_repo: "{{ registry_host }}/<REGISTRY_REPO>"
gcr_image_repo: "{{ registry_host }}/<REGISTRY_REPO>"
docker_image_repo: "{{ registry_host }}/<REGISTRY_REPO>"
quay_image_repo: "{{ registry_host }}/<REGISTRY_REPO>"
github_image_repo: "{{ registry_host }}/<REGISTRY_REPO>"

...

設定 Kubernetes CNI

  • 儘管內部驗證三者可以切換安裝,但考量到生產環境複雜度仍不建議隨意更換

推送鏡像

此處會自動讀取參數,將鏡像推送到對應 Container Registry。以下為參數來源 (按優先級排序,越前面者越高)

  • /inventory/config.sh
  • 環境變數 (env)
  /outputs/start-serving.sh
  
/inventory/config.sh 內容範例
  #!/bin/bash

REGISTRY_HOST=registry.example.com
REGISTRY_PORT=445
REGISTRY_REPO=library

REGISTRY_USER=robot_token
REGISTRY_PASSWORD=foobar

# Do NOT change the following lines as they are auto-generated.
KUBESPRAY_VERSION=v2.22.0-1.26.11-71b6fa13

KUBESPRAY_IMAGE=registry.srcmesh.dev/kubespray/kubespray:v2.22.0-1.26.11-71b6fa13

KUBE_VERSION=v1.26.13
  

調整 Inventory 設定

請務必先執行 gen-inventory.sh 生成 Inventory 設定檔

產生部署節點設定檔

增加 (或修改) /inventory/hosts.yml

  1. 修改 ansible_user,請填寫前面步驟創建的部署專用帳號名稱
  2. 設定各節點 Hostname (範例為:master1, worker1, worker2)
  3. 決定各目標節點功能,如控制節點 (Control Plane)、運算節點 (Worker Node)、etcd 執行節點

以下為範例 (請根據實際狀況調整,切勿 Copy/Paste)

  all:
    vars:
      ansible_user: <部署專用帳號>
    hosts:
      master1:
        ansible_host: <Master Node IP>
        ip: <Master Node IP>
        access_ip: <Master Node IP>
      worker1:
        ansible_host: <Worker Node 1 IP>
        ip: <Worker Node 1 IP>
        access_ip: <Worker Node 1 IP>
      worker2:
        ansible_host: <Worker Node 2 IP>
        ip: <Worker Node 2 IP>
        access_ip: <Worker Node 2 IP>
    children:
      kube_control_plane:
        hosts:
          master1:
      kube_node:
        hosts:
          worker1:
          worker2:
      etcd:
        hosts:
          master1:
      k8s_cluster:
        children:
          kube_control_plane:
          kube_node:
      calico_rr:
        hosts: {}
  

設定 Cluster CIDR

/inventory/group_vars/k8s_cluster/k8s-cluster.yml 修改下列設定

  # 範例,請根據實際環境調整
kube_service_addresses: 10.233.0.0/18
kube_pods_subnet: 10.234.0.0/16
kube_network_node_prefix: 24
  

設定 HA

/inventory/group_vars/all/all.yml 修改下列設定

  # 範例,請根據實際環境調整
apiserver_loadbalancer_domain_name: "my-apiserver-lb.example.com"
loadbalancer_apiserver:
  address: <VIP>
  port: 8383
  

實際 HAProxy 設置,請參考官方文件說明


其他參數調整

修正 RHEL 訂閱錯誤

如果出現 RHEL 訂閱錯誤 (subscription error) 時才需要進行以下設定調整

/inventory/group_vars/all/all.yml 增加下列設定

  cat >> /inventory/group_vars/all/all.yml << EOF
rhel_enable_repos: false
EOF
  

調整 hostNetwork: true 模式下 DNS 解析設定

如目標主機並未指定上游 DNS 主機時可能會出現部分異常,請調整 /inventory/group_vars/k8s_cluster/k8s-cluster.ymlresolvconf_mode 改成下列樣式

  # Can be docker_dns, host_resolvconf or none
resolvconf_mode: none
  

如該環境皆有指定 DNS 主機,可以保持官方原始設定 host_resolvconf,詳細參數設定含義請參考官方文件

沒有設定上游 DNS 查詢主機時

原本的設定檔並未設定 upstream_dns_servers,將導致 Local DNS => Global DNS => Local DNS 一直循環。

Was this page helpful?