一、配置管理分为两种:
- 加密配置:用来保存密码和token密钥对以及其它敏感的k8s资源。
2.应用配置:我们需要定制化的给应用进行配置,我们需要把定制好的配置文件同步到pod当中的容器。
二、加密配置
1.secret三种类型:1和2分为一类
查看加密的配置
data:image/s3,"s3://crabby-images/a24f8/a24f872b57a584f3cba7cb5a5c89064156458ec0" alt=""
1》service-account-token:k8s集群自建的,用来访问APIserver的secret,pod默认使用这种secret和APIserver进行通信,默认自动挂载到pod/run/secrets/kubenets.io/serviceaccount这个目录下
2》Opaque:用户自定义密码、密钥等等,默认类型就是opaque,语法为generic
3》kubenets.io/dockerconfigjson:配置docker私有仓库的验证信息
4》TLS:用来存储TLS或者SSL证书的私钥
三.Opaque实验
1.创建secret,先创建目录
data:image/s3,"s3://crabby-images/71758/71758d0160d77c1b043a2b19826f955009ae347d" alt=""
指定文件创建:
data:image/s3,"s3://crabby-images/20c87/20c87c6aef27220a3d9d8c6f24189b8fb2d51c4e" alt=""
创建secret类型为Opaque(第一种方式),生产中都用命令行指定文件的方式创建很少使用yml文件的方式实现
data:image/s3,"s3://crabby-images/d4c58/d4c589364aeb42122d6dde72b8409d2bfab79da8" alt=""
data:image/s3,"s3://crabby-images/c55a9/c55a9fa8af23e8b3c12b9691b4a3a06b70303b4c" alt=""
2.创建secret类型为Opaque(第二种方式):使用yaml文件实现
获取加密的方式
data:image/s3,"s3://crabby-images/a17ef/a17ef1c674435e9a6068d2da3264696138e7b018" alt=""
data:image/s3,"s3://crabby-images/abd64/abd640a9dcb3c6952437ce2dbf962b8f41d688a8" alt=""
- 如何将secret挂载到pod当中
将secret2里面的加密文件传到pod/etc/secrets目录下
data:image/s3,"s3://crabby-images/f0785/f0785d286aaad226eeb46144851e6916c3a1af15" alt=""
data:image/s3,"s3://crabby-images/443c9/443c976317233868af0aaa2d7c30a5bb023fb65a" alt=""
data:image/s3,"s3://crabby-images/c6904/c6904114b0d5b869f04302a460a682307f922f9e" alt=""
4.将secret作为环境变量传到pod当中:env给容器定义环境变量的语段,也就是给pod当中的容器定义环境变量
定义两个环境变量,名称分别叫user1、password1,user1及password1的值由secret2中的username和password文件给的,所以user=username,password1=password
data:image/s3,"s3://crabby-images/5deb4/5deb4bb646f60d91ce0204dd237aa57531b59edf" alt=""
data:image/s3,"s3://crabby-images/dd95b/dd95b34e17c0be174cb942d9319193d29756fdca" alt=""
查看的两种方式
data:image/s3,"s3://crabby-images/9c441/9c441d30b1876d7f260656a4da61a8b8f4375712" alt=""
data:image/s3,"s3://crabby-images/23501/23501fed8459df3002319e577b5ebb57aaebf42a" alt=""
5..kubenets.io/dockerconfigjson:配置docker私有仓库的验证信息实验
首先创建私有仓库加密的secret
data:image/s3,"s3://crabby-images/f1e10/f1e106e78a8f9a501cc6d67b5e2af82a70d0efaa" alt=""
指定私有仓库的IP 三台同步vim /lib/systemd/system/docker.service
data:image/s3,"s3://crabby-images/6e467/6e467f17e25c93ce9594bedb3b130e2e93fe883b" alt=""
vim secret.yml
imagePullsecrets:指定docker私有仓库的加密的secret配置
四、configmap:语法和secret一样,但是configmap保存的不是加密信息,主要就是用于保存应用的配置信息;configmap的挂载目录,权限只是只读权限。
1.创建方式:命令行及yml文件两种
命令行方式:指定文件即可
data:image/s3,"s3://crabby-images/654d0/654d08508226c86e4f667252b8c509b22714e7a4" alt=""
yml文件方式创建:当出现数字时要引号引起来
vim cm.yml
data:image/s3,"s3://crabby-images/2c65e/2c65e15790d58d48baa52755814fe8051d15ca47" alt=""
查看当前所有的configmap配置
- 在pod类里面用configmap做pod的环境变量
vim con1-test.yml
data:image/s3,"s3://crabby-images/2d8d4/2d8d4f93687ee5b1010ae6c80c79ca361148e34c" alt=""
data:image/s3,"s3://crabby-images/3e82c/3e82c64535aad2bb4bb5b9e1d99ef46a5a43bf0c" alt=""
3. 通过configmap的方式将nginx.conf内容传到应用容器当中
1》首先创建nginx.conf
data:image/s3,"s3://crabby-images/9a0c0/9a0c00fa8e48573f826ba5d0c38d928184df922d" alt=""
2》创建configmap,名称叫nginx-con --from-file指定文件就是/opt/configmap/nginx.conf
3》vim con1.yaml
data:image/s3,"s3://crabby-images/83686/8368622b9aa6d7b248fb099787ad4604c529f909" alt=""
data:image/s3,"s3://crabby-images/19d18/19d18f51eedd1e59a4f9f63e5ab99a2ed1ccdd74" alt=""
node1节点查看
进入pod
data:image/s3,"s3://crabby-images/d128d/d128d91b65cd815439f9b3f74fd1c88172d6ebe8" alt=""
configmap的热更新
data:image/s3,"s3://crabby-images/cd8bd/cd8bd99a9e3928f4ef919a3ad248f07aeeb8bc5b" alt=""
更改端口及路径
data:image/s3,"s3://crabby-images/32cd0/32cd06e462af90180c384e4e58c1622f81ed93a3" alt=""
再次进入pod查看
进行滚动更新
data:image/s3,"s3://crabby-images/4d5a9/4d5a922d8252f377881a86f57058871e3db47aa1" alt=""
查看node2节点并且进入html11内往index.html内插入文件666
data:image/s3,"s3://crabby-images/2319b/2319b78553e9ff2b836a8ba332c67cbbffdaebc9" alt=""
在主节点访问pod查看插入内容
data:image/s3,"s3://crabby-images/b4a82/b4a82916c8490df4d6b82cccd78352e0c80f6f1e" alt=""
4》configmap的挂载点目录,权限只是只读模式