k8s配置资源管理
secret
Configmap*:1.2加入的新特征
secret:保存密码,token,保存敏感的k8s资源
这类数据可以存放在镜像当中,但是防止secret当中可以更方便的控制,减少暴露的风险
保存加密的信息
kubectl create secret
docker-registry:存储docker仓库认证信息以及docker组件认证信息(私有)
generic:是secret的默认模式,Opaque,base64加密编码的secret用户自定义的密码,密钥等等
tls:TLS/SSL,用于存储证书和私钥,https
pod如何来引用secret:
3种方式:
1、挂载的方式,secret挂载到pod当中的一个或者多个容器上的卷里面
2、把secret作为容器的环境变量
3、docker-registry可以作为集群拉取镜像时使用,使用secret可以实现免密登录
指定文件提取类型
data:image/s3,"s3://crabby-images/45589/45589c022af14eb5350e29ae3d91887e73a3d618" alt=""
data:image/s3,"s3://crabby-images/51f30/51f305d68f91824522f1897f552a6a0650650c6b" alt=""
--fro,-file=/opt/username.txt:从指定获取加密的信息
data:image/s3,"s3://crabby-images/22a0e/22a0e9c11cb27dc4217214299bf7d99dcd4ad107" alt=""
data:image/s3,"s3://crabby-images/b0150/b0150126fd6e6671b034853b2d93be2a086e2ed3" alt=""
#Data
====
password: 13 bytes
username: 13 bytes
data保存的是加密的内容,容器内部可以解密,可以直接引用
创建方式:
陈述式:
#base64就是加密的格式
data:image/s3,"s3://crabby-images/45589/45589c022af14eb5350e29ae3d91887e73a3d618" alt=""
data:image/s3,"s3://crabby-images/450b0/450b02145913fba1cb153cdbc621991c161b76d1" alt=""
data:image/s3,"s3://crabby-images/35f43/35f4344fd0fffd3645a208214f68b7c531824848" alt=""
声明式:
data:image/s3,"s3://crabby-images/11f76/11f76938d42eb1dc578ed8b9417b37f27fa0a7c5" alt=""
data:image/s3,"s3://crabby-images/a253f/a253ffb97c70040106c3a92ca2327ce0f9cd9293" alt=""
data:image/s3,"s3://crabby-images/ebcfd/ebcfd6e3deb30ed80c5c4906a58da6d51303c557" alt=""
挂载方式:
data:image/s3,"s3://crabby-images/a2da6/a2da6e68cf5d9252afab5ebd0bff02db0d788fdd" alt=""
把加密的文件传到容器内部并解密
data:image/s3,"s3://crabby-images/a1d78/a1d7885ab87fb33b73d07d4aa17556b5a033632c" alt=""
环境变量:
data:image/s3,"s3://crabby-images/f41b1/f41b1368d2d56340321b0e485ad979a569f5b731" alt=""
使用secret配置免密交互拉取habor私有仓库镜像
我们在搭建好docker的私有仓库后,在使用私有仓库时需要通过docker login指令来登录到私有仓库中。但同时在使用的过程中也会把habor仓库的用户名和密码暴露在命令行中,存在一定的安全隐患。k8s中的secret配置的运用能够实现并且规避这一问题的存在
data:image/s3,"s3://crabby-images/e161d/e161d921ab746818e47436a3e57a44b07554aa74" alt=""
data:image/s3,"s3://crabby-images/7f5dc/7f5dc3c04107dd2064f029fe956825aa86ee38a9" alt=""
data:image/s3,"s3://crabby-images/bc265/bc265139e87e9e6891cd7a7a8687a115855c8382" alt=""
data:image/s3,"s3://crabby-images/91c18/91c18c4823c347784c02162d744a5b47470c0bb9" alt=""
secret的三种方式:
陈述式创建
声明式创建
引用方式:
挂载使用
设定环境变量
docker-registry
ConfigMap资源配置:
保存的是不需要加密的信息。configmap是1.2引入的功能,应用程序会从配置文件,命令参数,以及环境变量中读取配置信息
configmap在创建容器中,给他注入我们需要的配置信息,既可以是单个的属性,也可以是整个容器的配置文件
1、陈述式
从指定文件创建,可以是一个,也可以是多个文件:(file通过文件上传变成键值对)
data:image/s3,"s3://crabby-images/4a67a/4a67a8c386d5b66c59e667e82805dde79cd85872" alt=""
data:image/s3,"s3://crabby-images/8ad78/8ad78fcc64471794752cca0af0dd03e948f8c830" alt=""
data:image/s3,"s3://crabby-images/e06ae/e06ae15435403588957b37c687c9ce3adcc02d32" alt=""
data:image/s3,"s3://crabby-images/b1a3b/b1a3b0cbfda121aaec633f58fec353eb4e216b66" alt=""
使用字面值创建:(literal通过命令行创建上传到键值对)
data:image/s3,"s3://crabby-images/68338/68338b4bc7e2c02f81a72f3ad0306759d51d046c" alt=""
2、声明式
data:image/s3,"s3://crabby-images/46033/46033cded9453fb057eb8abadfed52728c79d8fe" alt=""
data:image/s3,"s3://crabby-images/55e1d/55e1d8ece1963e6d35e1a7c35d2c4014e55eaed2" alt=""
comfigmap是键值对形式
data:image/s3,"s3://crabby-images/bacc2/bacc2b82d6e2b52269ff72bcf445379439014efc" alt=""
数据卷使用configmap
准备一个nginx.conf配置文件
data:image/s3,"s3://crabby-images/3d8aa/3d8aab4ed7f999e54f0951ac80f86e36446c51ad" alt=""
data:image/s3,"s3://crabby-images/da81d/da81d8eb49202b64f98f2a0ab6d56ceef5d25124" alt=""
写yaml文件
data:image/s3,"s3://crabby-images/7c321/7c321128cc2a368ab8628fe9888b36431dc1cd7e" alt=""
data:image/s3,"s3://crabby-images/65b86/65b8643f1cc1d5a8954fa2f58536b42358acb2b9" alt=""
1、我们通过数据卷的形式,把配置文件传给了pod内部容器
2、config的热更新,在pod运行的情况下,对config的配置信息进行修改。直接生效(反应到容器当中)
data:image/s3,"s3://crabby-images/fb6dd/fb6dd6a567b2107cb0e2821556d0ab4ccc13a0b6" alt=""
data:image/s3,"s3://crabby-images/570d8/570d83a8421334f037a16a709e5b4295168d882f" alt=""
3、configmap的热更新不会触发pod的滚动更新机制(deployment)
version/config来触发滚动更新
secret:主要作用是保存加密文件,主要的使用方式就是挂载方式
configMap:把配置信息传给容器,主要方式也是挂载
configMap的热更新:热更新可以直接反应到容器的内部,也不会触发pod的更新机制。如果不是需要重启的配置,都可以直接生效
version/config来触发滚动更新(直接删除容器重新拉取也可以)
kubectl patch deployments.apps nginx1 --patch '{"spec": {"template": {"metadata": {"annotations": {"version/conf ig ": "20240116"}}}}}'
需要重启的,可以重启pod
更新:就是把配置信息重新传到容器内,重启也是一样
configMap:就是把配置信息传给容器,键值对形式保存的,非加密的信息