1、常规操作
由于k3s证书的默认过期时间是12个月,因此到期之前或不小心到期,需要轮换
其实官网有明确的说明以及处理办法——但是你会发现按照官方处理办法,基本上无法生效
这里给一个一定可行的办法
# 在其中一个节点上执行
k3s kubectl --insecure-skip-tls-verify=true delete secret k3s-serving -n kube-system
# 在每个节点上执行
rm -rf /var/lib/rancher/k3s/server/tls/dynamic-cert.json
systemctl restart k3s
以上的关键点就是 --insecure-skip-tls-verify=true
重点来了
2、黑科技:改证书时间为10年(或自定义时间)
上面的办法虽好,但是生产环境我们肯定不愿意每年都去搞一次,如何做?
我们知道,每一个证书,是有根证书签发的,k3s服务证书,有自己的根证书
因此,我们只需要
1、找到k3s的根证书
2、设置正确的信任域和IP,设置你想要的时间,然后用来签发一个新的证书
3、替换现有的k3s证书
就可以达到效果
说了一堆废话,这里给出最终办法(由于大家都会用rancher,我这里就以操作rancher来说明了,没有rancher,通过kubectl命令也可以完成操作,具体我就不写了,自行思考)
详细步骤:
- 进入rancher,找到
集群->system->证书列表->k3s-serving- 点开
k3s-serving,拷贝域名中的所有内容做准备- 使用本文最后的shell脚本,拷贝到服务器上执行该脚本。其中参数要注意
–ssl-domain,需要指定为’k3s’。脚本默认值已经设定好了
–ssl-trusted-domain,【【【需要指定为第二步拷贝的内容中,除了k3s的所有域名】】】
–ssl-trusted-ip,【【【需要指定为第二步拷贝的内容中的所有ip】】】
样例参考为:./mktls.sh --ssl-domain=k3s --ssl-trusted-domain=kubernetes,kubernetes.default,kubernetes.default.svc,kubernetes.default.svc.cluster.local,localhost --ssl-trusted-ip=10.43.0.1,127.0.0.1,172.16.148.200,172.16.148.201,172.16.148.203,172.16.148.204 --ssl-size=2048 --ssl-date=3650 --k3s-server-ca-key=./CA.key --k3s-server-ca=./CA.crt
样例中我专门指定了–k3s-server-ca-key和–k3s-server-ca(其默认值在脚本中有描述),其实想说的是,我们把k3s的根证书和key内容拷贝出来到任何地方都可以执行- 在rancher中编辑
k3s-serving,用第三步生成的key和crt内容,更新对应的内容即可
至此,就完成了证书更新,妈妈再也不用担心k3s过期了
附上详细步骤中所述的脚本
拷贝到机器上,chmod +x 之后执行即可
#!/bin/bash -e
# 用于制作k3s的服务证书。默认情况下,k3s证书一年内过期
# 通过官方说法,可以通过删除 `k3s-serving`这个密文
# 以及删除主机的/var/lib/rancher/k3s/server/tls/dynamic-cert.json文件
# 之后,重启k3s服务可以达到轮换证书的目标
# 但是这样太麻烦,这里提供的就是根据k3s的根证书制作一个新的证书,时间可自定义
# 然后把这个证书的key和crt在rancher界面上更换`k3s-serving`这个密文内容即可
help ()
{
echo ' ================================================================ '
echo ' --ssl-domain: 生成ssl证书需要的主域名,如不指定则默认为www.rancher.local,如果是ip访问服务,则可忽略;'
echo ' --ssl-trusted-ip: 一般ssl证书只信任域名的访问请求,有时候需要使用ip去访问server,那么需要给ssl证书添加扩展IP,多个IP用逗号隔开;'
echo ' --ssl-trusted-domain: 如果想多个域名访问,则添加扩展域名(SSL_TRUSTED_DOMAIN),多个扩展域名用逗号隔开;'
echo ' --ssl-size: ssl加密位数,默认2048;'
echo ' --ssl-cn: 国家代码(2个字母的代号),默认CN;'
echo ' --ssl-date: 有效天数;'
echo ' --k3s-server-ca-key: k3s根证书的key。默认在/var/lib/rancher/k3s/server/tls/server-ca.key'
echo ' --k3s-server-ca: k3s根证书。默认在/var/lib/rancher/k3s/server/tls/server-ca.crt'
echo

本文介绍了如何管理和更新K3s集群的证书,包括常规的证书轮换方法以及如何将证书有效期延长至10年。通过修改K3s的根证书,创建新的服务证书并替换现有证书,可以避免每年手动操作。提供了一个shell脚本来简化此过程,并给出了详细的执行步骤和示例。
&spm=1001.2101.3001.5002&articleId=124389172&d=1&t=3&u=d99278992f8e4904a82bfff9d5d45cd4)
240

被折叠的 条评论
为什么被折叠?



