根证书是全部证书的基础,后面的证书都是根据此证书而来(其实Kubernetes难就难在证书和受权,理解起来不容易),centos默认自带的1.5.2默认不采用证书,就会简单得多。linux
wget https://pkg.cfssl.org/R1.2/cfssl_linux-amd64
wget https://pkg.cfssl.org/R1.2/cfssljson_linux-amd64
wget https://pkg.cfssl.org/R1.2/cfssl-certinfo_linux-amd64
chmod +x cfssl_linux-amd64 cfssljson_linux-amd64 cfssl-certinfo_linux-amd64
mv cfssl_linux-amd64 /usr/local/bin/cfssl
mv cfssljson_linux-amd64 /usr/local/bin/cfssljson
mv cfssl-certinfo_linux-amd64 /usr/bin/cfssl-certinfo复制代码
准备证书文件,设置5年有效期json
cd /etc/ssl/
cat > /etc/ssl/ca-config.json <<EOF
{
"signing": {
"default": {
"expiry": "87600h"
},
"profiles": {
"kubernetes": {
"usages": [
"signing",
"key encipherment",
"server auth",
"client auth"
],
"expiry": "87600h"
}
}
}
}
EOF
复制代码
cat > /etc/ssl/ca-csr.json <<EOF
{
"CN": "kubernetes",
"key": {
"algo": "rsa",
"size": 2048
},
"names": [
{
"C": "CN",
"ST": "ChengDu",
"L": "ChengDu",
"O": "k8s",
"OU": "dessler"
}
]
}
EOF
复制代码
cfssl gencert -initca ca-csr.json | cfssljson -bare ca -
复制代码
执行完成之后,当前目录会生成ca根证书,这个证书是后续证书的基础centos
ls
ca-config.json ca.csr ca-csr.json ca-key.pem ca.pem
复制代码