kubelet
、kube-proxy
等 Node 機器上的進程與 Master 機器的 kube-apiserver
進程通訊時須要認證和受權;node
kubernetes 1.4 開始支持由 kube-apiserver
爲客戶端生成 TLS 證書的 TLS Bootstrapping 功能,這樣就不須要爲每一個客戶端生成證書了;該功能當前僅支持爲 kubelet
生成證書;bootstrap
Token auth fileapi
Token能夠是任意的包涵128 bit的字符串,能夠使用安全的隨機數發生器生成安全
export BOOTSTRAP_TOKEN=$(head -c 16 /dev/urandom | od -An -t x | tr -d ' ') cat > token.csv <<EOF ${BOOTSTRAP_TOKEN},kubelet-bootstrap,10001,"system:kubelet-bootstrap" EOF
後三行是一句,直接複製上面的腳本運行便可。bash
將token.csv發到全部機器(Master 和 Node)的 /etc/kubernetes/
目錄。app
# cp token.csv /etc/kubernetes/ # scp token.csv xxxx:/etc/kubernetes/
# cd /etc/kubernetes # export KUBE_APISERVER="https://192.168.1.121:6443" # # 設置集羣參數 # kubectl config set-cluster kubernetes \ --certificate-authority=/etc/kubernetes/ssl/ca.pem \ --embed-certs=true \ --server=${KUBE_APISERVER} \ --kubeconfig=bootstrap.kubeconfig # # 設置客戶端認證參數 # kubectl config set-credentials kubelet-bootstrap \ --token=${BOOTSTRAP_TOKEN} \ --kubeconfig=bootstrap.kubeconfig # # 設置上下文參數 # kubectl config set-context default \ --cluster=kubernetes \ --user=kubelet-bootstrap \ --kubeconfig=bootstrap.kubeconfig # # 設置默認上下文 # kubectl config use-context default --kubeconfig=bootstrap.kubeconfig
--embed-certs
爲 true
時表示將 certificate-authority
證書寫入到生成的 bootstrap.kubeconfig
文件中;kube-apiserver
自動生成;# export KUBE_APISERVER="https://192.168.1.121:6443" # # 設置集羣參數 # kubectl config set-cluster kubernetes \ --certificate-authority=/etc/kubernetes/ssl/ca.pem \ --embed-certs=true \ --server=${KUBE_APISERVER} \ --kubeconfig=kube-proxy.kubeconfig # # 設置客戶端認證參數 # kubectl config set-credentials kube-proxy \ --client-certificate=/etc/kubernetes/ssl/kube-proxy.pem \ --client-key=/etc/kubernetes/ssl/kube-proxy-key.pem \ --embed-certs=true \ --kubeconfig=kube-proxy.kubeconfig # # 設置上下文參數 # kubectl config set-context default \ --cluster=kubernetes \ --user=kube-proxy \ --kubeconfig=kube-proxy.kubeconfig 3 # 設置默認上下文 # kubectl config use-context default --kubeconfig=kube-proxy.kubeconfig
--embed-certs
都爲 true
,這會將 certificate-authority
、client-certificate
和 client-key
指向的證書文件內容寫入到生成的 kube-proxy.kubeconfig
文件中;kube-proxy.pem
證書中 CN 爲 system:kube-proxy
,kube-apiserver
預約義的 RoleBinding cluster-admin
將User system:kube-proxy
與 Role system:node-proxier
綁定,該 Role 授予了調用 kube-apiserver
Proxy 相關 API 的權限;將兩個 kubeconfig 文件分發到全部 Node 機器的 /etc/kubernetes/
目錄dom
# cp bootstrap.kubeconfig kube-proxy.kubeconfig /etc/kubernetes/ # scp bootstrap.kubeconfig kube-proxy.kubeconfig xxxx:/etc/kubernetes/