通過二進制包一鍵部署 Kubernetes v1.15.0 集羣

通過二進制包一鍵部署 Kubernetes v1.15.0 集羣

一 概述

Kubernetes目前有兩種較爲流行的安裝方式:二進制和Kubeadm。二進制安裝過程有利於大家理解Kubernetes各組件的原理和詳細配置過程,安裝包容易獲取,不需要其他方式即可完成全部組件的下載。但是操作過程複雜而且冗長,令衆多初學者望而生畏。在解決了網絡問題後,Kubeadm這種安裝方式非常簡單快捷,唯一的缺點是不利於初學者理解Kubernetes各組件的原理與詳細配置過程。兩種安裝方案均能用於生產環境,根據實際情況選擇即可。

二 使用說明

2.1 前提條件及組件安裝規劃

腳執行後會刪除或修改相關目錄之前已經存在的文件或內容,無需手動處理。如需備份,請在腳本執行之前操作。相關操作路徑可以在 kube_config.sh 文件中查看。

操作系統 Docker版本 Kubernetes版本 Etcd版本 Flannel版本 CoreDNS
CentOS Linux release 7.6.1810 Docker version 18.09.7 v1.15.0 Version: 3.3.13 v0.11.0 v.1.5.0

|IP|主機名(Hostname)|角色(Role)|組件(Component)|
|:-:|:-:|:-:|:-:|
|172.31.2.10|gysl-master|Master|kube-apiserverkube-controller-managerkube-scheduleretcd,kubectl, docker,flannel|
|172.31.2.11|gysl-node1|Node|kubelet,kube-proxy,docker,flannel,etcd|
|172.31.2.12|gysl-node2|Node|kubelet,kube-proxy,docker,flannel,etcd|

2.2 源碼目錄結構

kubernetes-all-in-one/
├── configurations
│   ├── master
│   │   ├── etcd
│   │   │   ├── ca.d
│   │   │   │   ├── ca-config.json
│   │   │   │   ├── ca.csr
│   │   │   │   ├── ca-csr.json
│   │   │   │   ├── ca-key.pem
│   │   │   │   ├── ca.pem
│   │   │   │   ├── server.csr
│   │   │   │   ├── server-csr.json
│   │   │   │   ├── server-key.pem
│   │   │   │   └── server.pem
│   │   │   └── conf.d
│   │   │       └── etcd.conf
│   │   └── kubernetes
│   │       ├── ca.d
│   │       │   ├── bootstrap.kubeconfig
│   │       │   ├── ca-config.json
│   │       │   ├── ca.csr
│   │       │   ├── ca-csr.json
│   │       │   ├── ca-key.pem
│   │       │   ├── ca.pem
│   │       │   ├── kube-proxy.csr
│   │       │   ├── kube-proxy-csr.json
│   │       │   ├── kube-proxy-key.pem
│   │       │   ├── kube-proxy.kubeconfig
│   │       │   ├── kube-proxy.pem
│   │       │   ├── server.csr
│   │       │   ├── server-csr.json
│   │       │   ├── server-key.pem
│   │       │   ├── server.pem
│   │       │   └── token.csv
│   │       └── conf.d
│   │           ├── kube-apiserver.conf
│   │           ├── kube-controller-manager.conf
│   │           └── kube-scheduler.conf
│   └── node
│       ├── docker
│       │   ├── daemon.json
│       │   └── key.json
│       ├── etcd
│       │   ├── ca.d
│       │   │   ├── ca-key.pem
│       │   │   ├── ca.pem
│       │   │   ├── server-key.pem
│       │   │   └── server.pem
│       │   └── conf.d
│       │       └── etcd.conf
│       ├── flanneld.d
│       │   └── flanneld.conf
│       └── kubernetes
│           ├── ca.d
│           │   ├── kubelet-client-2019-07-11-17-25-43.pem
│           │   ├── kubelet-client-current.pem
│           │   ├── kubelet.crt
│           │   └── kubelet.key
│           └── conf.d
│               ├── bootstrap.kubeconfig
│               ├── kubelet.conf
│               ├── kubelet.kubeconfig
│               ├── kubelet.yaml
│               ├── kube-proxy.conf
│               └── kube-proxy.kubeconfig
├── coredns_installation.sh
├── docker_installation.sh
├── etcd_cluster_installation.sh
├── flannel_installation.sh
├── kube_api_installation.sh
├── kube_config.sh
├── kube_controller_installation.sh
├── kube_installation.sh
├── kubelet_installation.sh
├── kube_proxy_installation.sh
├── kube_scheduler_installation.sh
├── modules
│   ├── coredns.yaml
│   ├── create_etcd_ca.sh
│   ├── create_etcd_config.sh
│   ├── create_flanneld_config.sh
│   ├── create_kube_api_config.sh
│   ├── create_kube_ca.sh
│   ├── create_kubeconfig.sh
│   ├── create_kube_controller_config.sh
│   ├── create_kubelet_config.sh
│   ├── create_kube_proxy_config.sh
│   ├── create_kube_scheduler_config.sh
│   ├── deploy_coredns.sh
│   ├── init.sh
│   ├── last_config.sh
│   ├── no_passwd_login.sh
│   └── unzip_pkgs.sh
├── pkgs
│   ├── cfssl-v1.2-linux-amd64.tar.gz
│   ├── etcd-v3.3.13-linux-amd64.tar.gz
│   ├── flannel-v0.11.0-linux-amd64.tar.gz
│   ├── kubernetes-v1.15.0-linux-amd64-1.tar.gz
│   ├── kubernetes-v1.15.0-linux-amd64-2.tar.gz
│   └── README.md
├── README.md
└── services
    ├── master
    │   ├── docker.service
    │   ├── etcd.service
    │   ├── kube-apiserver.service
    │   ├── kube-controller-manager.service
    │   └── kube-scheduler.service
    └── node
        ├── docker.service
        ├── etcd.service
        ├── flanneld.service
        ├── kubelet.service
        └── kube-proxy.service

22 directories, 91 files

目錄中已經包含了安裝過程中所需要的所有組件,服務及配置文件無需自己手動準備,安裝過程中會自動配置,目錄中提供的服務及配置文件僅供參考。

2.3 腳本使用說明

根據個人需求修改 kube_config 文件。如果節點個數不是2的話還需要修改對應證書配置文件及 etcd 相關服務配置文件。在執行安裝腳本之前,需要在所有節點上部署 docker ,安裝腳本參考 docker_installation.sh 。可以根據需求選擇一鍵安裝或者分步驟安裝,kube_installation.sh 爲一鍵安裝腳本,在執行過程中也需要進行幾次密碼輸入或者手動確認。其餘所有組件均與 kube_config 在同一目錄,可以根據文件名稱直接區分。建議按照模塊,分步驟進行安裝,安裝配置完成一個組件之後立馬驗證,及時排障。分模塊安裝順序具體可以參考 kube_installation.sh 每一步均有註釋。

2.4 執行方式

建議使用 bash example_installation.sh 的方式執行。一鍵安裝及分模塊安裝的工作目錄均爲:kubernetes-all-in-one。例如: bash kube_installation.sh 。

2.5 驗證安裝是否成功

此步驟略,根據自身情況進行驗證。

三 源碼及意見反饋

3.1 源碼

GitHub

3.2 意見反饋

可以通過 GitHub、微信、郵件、文章評論向本人反饋。

四 參考資料

4.1 使用二進制包在生產環境部署 Kubernetes v1.13.2 集羣

4.2 二進制包20分鐘快速安裝部署 Kubernetes v1.14.0 集羣

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章