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/