使用 kubeadm init 后如何以编程方式获取 Kubernetes 在 --discovery-token-ca-cert-hash 中打印的值

问题描述

我有一个特定的用例,其中我们在大量机器上远程创建 Kubernetes 集群。当我们在最后运行 kubeadm init 时,join 命令被打印为:

kubeadm join [IPv6-Address]:6443 --token TOKEN_VALUE --discovery-token-ca-cert-hash CERT_HASH

为了以编程方式加入工作节点,我们有一个需要 TOKEN_VALUECERT_HASH 的脚本。

现在我正在使用以下命令获取 TOKEN_VALUEsudo kubeadm token list | awk 'NR == 2 {print $1}'。但是,我还没有找到获得 CERT_HASH 的简单方法(或根本没有任何方法)。

任何帮助或指针将不胜感激。

解决方法

对于那些有同样问题的人来说,似乎没有一种超级干净或简单的方法来解决它。但看了一些地方后,对我有用的是openssl x509 -in /etc/kubernetes/pki/ca.crt -noout -pubkey | openssl rsa -pubin -outform DER 2>/dev/null | sha256sum | cut -d' ' -f1