2017-04-14 17:39:40 +08:00
|
|
|
|
# 创建 kubeconfig 文件
|
|
|
|
|
|
2017-07-27 21:44:27 +08:00
|
|
|
|
注意:请先参考 [安装kubectl命令行工具](kubectl-installation.md),先在 master 节点上安装 kubectl 然后再进行下面的操作。
|
|
|
|
|
|
2017-04-14 17:39:40 +08:00
|
|
|
|
`kubelet`、`kube-proxy` 等 Node 机器上的进程与 Master 机器的 `kube-apiserver` 进程通信时需要认证和授权;
|
|
|
|
|
|
|
|
|
|
kubernetes 1.4 开始支持由 `kube-apiserver` 为客户端生成 TLS 证书的 [TLS Bootstrapping](https://kubernetes.io/docs/admin/kubelet-tls-bootstrapping/) 功能,这样就不需要为每个客户端生成证书了;该功能**当前仅支持为 `kubelet`** 生成证书;
|
|
|
|
|
|
2017-06-01 10:30:57 +08:00
|
|
|
|
因为我的master节点和node节点复用,所有在这一步其实已经安装了kubectl。参考[安装kubectl命令行工具](kubectl-installation.md)。
|
|
|
|
|
|
|
|
|
|
以下操作只需要在master节点上执行,生成的`*.kubeconfig`文件可以直接拷贝到node节点的`/etc/kubernetes`目录下。
|
|
|
|
|
|
2017-04-14 17:39:40 +08:00
|
|
|
|
## 创建 TLS Bootstrapping Token
|
|
|
|
|
|
|
|
|
|
**Token auth file**
|
|
|
|
|
|
2018-02-05 20:28:17 +08:00
|
|
|
|
Token可以是任意的包含128 bit的字符串,可以使用安全的随机数发生器生成。
|
2017-04-14 17:39:40 +08:00
|
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
|
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
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
> 后三行是一句,直接复制上面的脚本运行即可。
|
|
|
|
|
|
2017-08-31 22:28:55 +08:00
|
|
|
|
**注意:在进行后续操作前请检查 `token.csv` 文件,确认其中的 `${BOOTSTRAP_TOKEN}` 环境变量已经被真实的值替换。**
|
|
|
|
|
|
2017-04-28 13:16:28 +08:00
|
|
|
|
**BOOTSTRAP_TOKEN** 将被写入到 kube-apiserver 使用的 token.csv 文件和 kubelet 使用的 `bootstrap.kubeconfig` 文件,如果后续重新生成了 BOOTSTRAP_TOKEN,则需要:
|
|
|
|
|
|
|
|
|
|
1. 更新 token.csv 文件,分发到所有机器 (master 和 node)的 /etc/kubernetes/ 目录下,分发到node节点上非必需;
|
|
|
|
|
2. 重新生成 bootstrap.kubeconfig 文件,分发到所有 node 机器的 /etc/kubernetes/ 目录下;
|
|
|
|
|
3. 重启 kube-apiserver 和 kubelet 进程;
|
|
|
|
|
4. 重新 approve kubelet 的 csr 请求;
|
2017-04-14 17:39:40 +08:00
|
|
|
|
|
|
|
|
|
``` bash
|
2017-08-31 14:19:36 +08:00
|
|
|
|
cp token.csv /etc/kubernetes/
|
2017-04-14 17:39:40 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## 创建 kubelet bootstrapping kubeconfig 文件
|
|
|
|
|
|
2017-12-15 19:44:39 +08:00
|
|
|
|
执行下面的命令时需要先安装kubectl命令,请参考[安装kubectl命令行工具](kubectl-installation.md)。
|
|
|
|
|
|
2017-04-14 17:39:40 +08:00
|
|
|
|
``` bash
|
2017-08-31 14:19:36 +08:00
|
|
|
|
cd /etc/kubernetes
|
|
|
|
|
export KUBE_APISERVER="https://172.20.0.113:6443"
|
|
|
|
|
|
|
|
|
|
# 设置集群参数
|
|
|
|
|
kubectl config set-cluster kubernetes \
|
2017-04-14 17:39:40 +08:00
|
|
|
|
--certificate-authority=/etc/kubernetes/ssl/ca.pem \
|
|
|
|
|
--embed-certs=true \
|
|
|
|
|
--server=${KUBE_APISERVER} \
|
|
|
|
|
--kubeconfig=bootstrap.kubeconfig
|
2017-08-31 14:19:36 +08:00
|
|
|
|
|
|
|
|
|
# 设置客户端认证参数
|
|
|
|
|
kubectl config set-credentials kubelet-bootstrap \
|
2017-04-14 17:39:40 +08:00
|
|
|
|
--token=${BOOTSTRAP_TOKEN} \
|
|
|
|
|
--kubeconfig=bootstrap.kubeconfig
|
2017-08-31 14:19:36 +08:00
|
|
|
|
|
|
|
|
|
# 设置上下文参数
|
|
|
|
|
kubectl config set-context default \
|
2017-04-14 17:39:40 +08:00
|
|
|
|
--cluster=kubernetes \
|
|
|
|
|
--user=kubelet-bootstrap \
|
|
|
|
|
--kubeconfig=bootstrap.kubeconfig
|
2017-08-31 14:19:36 +08:00
|
|
|
|
|
|
|
|
|
# 设置默认上下文
|
|
|
|
|
kubectl config use-context default --kubeconfig=bootstrap.kubeconfig
|
2017-04-14 17:39:40 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
+ `--embed-certs` 为 `true` 时表示将 `certificate-authority` 证书写入到生成的 `bootstrap.kubeconfig` 文件中;
|
|
|
|
|
+ 设置客户端认证参数时**没有**指定秘钥和证书,后续由 `kube-apiserver` 自动生成;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## 创建 kube-proxy kubeconfig 文件
|
|
|
|
|
|
|
|
|
|
``` bash
|
2017-08-31 14:19:36 +08:00
|
|
|
|
export KUBE_APISERVER="https://172.20.0.113:6443"
|
|
|
|
|
# 设置集群参数
|
|
|
|
|
kubectl config set-cluster kubernetes \
|
2017-04-14 17:39:40 +08:00
|
|
|
|
--certificate-authority=/etc/kubernetes/ssl/ca.pem \
|
|
|
|
|
--embed-certs=true \
|
|
|
|
|
--server=${KUBE_APISERVER} \
|
|
|
|
|
--kubeconfig=kube-proxy.kubeconfig
|
2017-08-31 14:19:36 +08:00
|
|
|
|
# 设置客户端认证参数
|
|
|
|
|
kubectl config set-credentials kube-proxy \
|
2017-04-14 17:39:40 +08:00
|
|
|
|
--client-certificate=/etc/kubernetes/ssl/kube-proxy.pem \
|
|
|
|
|
--client-key=/etc/kubernetes/ssl/kube-proxy-key.pem \
|
|
|
|
|
--embed-certs=true \
|
|
|
|
|
--kubeconfig=kube-proxy.kubeconfig
|
2017-08-31 14:19:36 +08:00
|
|
|
|
# 设置上下文参数
|
|
|
|
|
kubectl config set-context default \
|
2017-04-14 17:39:40 +08:00
|
|
|
|
--cluster=kubernetes \
|
|
|
|
|
--user=kube-proxy \
|
|
|
|
|
--kubeconfig=kube-proxy.kubeconfig
|
2017-08-31 14:19:36 +08:00
|
|
|
|
# 设置默认上下文
|
|
|
|
|
kubectl config use-context default --kubeconfig=kube-proxy.kubeconfig
|
2017-04-14 17:39:40 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
+ 设置集群参数和客户端认证参数时 `--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 文件
|
|
|
|
|
|
|
|
|
|
将两个 kubeconfig 文件分发到所有 Node 机器的 `/etc/kubernetes/` 目录
|
|
|
|
|
|
|
|
|
|
``` bash
|
2017-08-31 14:19:36 +08:00
|
|
|
|
cp bootstrap.kubeconfig kube-proxy.kubeconfig /etc/kubernetes/
|
2017-08-16 10:53:06 +08:00
|
|
|
|
```
|
|
|
|
|
## 参考
|
|
|
|
|
|
2018-02-05 20:28:17 +08:00
|
|
|
|
关于 kubeconfig 文件的更多信息请参考 [使用 kubeconfig 文件配置跨集群认证](../guide/authenticate-across-clusters-kubeconfig.md)。
|