|NO.Z.00181|——————————|CloudNative|——|KuberNetes&配置管理.V12|——|secret.v04|ImagePullSecret|
一、ImagePullSecret:
### --- ImagePullSecret:
~~~ Pod拉取私有镜像仓库时使用的账号密码,里面的账号信息会传递给kubelet,
~~~ 然后kubelet就可以拉取有密码的仓库里面的镜像。
### --- 创建一个docker registry的secrets
~~~ 手动创建docker registry的secrets
[root@k8s-master01 secrets]# kubectl create secret docker-registry docker-secret --docker-server=hub.docker.com --docker-username=admin --docker-password=password --docker-email=xxx@xxx.com
secret/docker-secret created
docker-registry docker-secret // secrets名称
--docker-server=hub.docker.com // 公司内部镜像仓库地址
--docker-username=admin // 账户名
--docker-password=password // 密码
--docker-email=xxx@xxx.com // 邮箱
secret/docker-secret created
### --- 查看它的类型
~~~ 类型是dockerconfigjson类型
[root@k8s-master01 secrets]# kubectl get secret
NAME TYPE DATA AGE
docker-secret kubernetes.io/dockerconfigjson 1 2m24s
二、查看创建的docker-secret.yaml配置文件
[root@k8s-master01 secrets]# kubectl get secret docker-secret -oyaml
apiVersion: v1
data:
.dockerconfigjson: eyJhdXRocyI6eyJodWIuZG9ja2VyLmNvbSI6eyJ1c2VybmFtZSI6ImFkbWluIiwicGFzc3dvcmQiOiJwYXNzd29yZCIsImVtYWlsIjoieHh4QHh4eC5jb20iLCJhdXRoIjoiWVdSdGFXNDZjR0Z6YzNkdmNtUT0ifX19
kind: Secret
metadata:
creationTimestamp: "2021-04-25T11:20:34Z"
manager: kubectl-create
operation: Update
time: "2021-04-25T11:20:34Z"
name: docker-secret
namespace: default
resourceVersion: "757264"
uid: 61c68e06-d490-41cc-9385-e10e0c6b97c5
type: kubernetes.io/dockerconfigjson
三、解密加密的参数
### --- 解密查看它的输出值
[root@k8s-master01 secrets]# echo "eyJhdXRocyI6eyJodWIuZG9ja2VyLmNvbSI6eyJ1c2VybmFtZSI6ImFkbWluIiwicGFzc3dvcmQiOiJwYXNzd29yZCIsImVtYWlsIjoieHh4QHh4eC5jb20iLCJhdXRoIjoiWVdSdGFXNDZjR0Z6YzNkdmNtUT0ifX19" | base64 --decode
{"auths":{"hub.docker.com":{"username":"admin","password":"password","email":"xxx@xxx.com","auth":"YWRtaW46cGFzc3dvcmQ="}}}
四、将镜像挂载到容器中
### --- 挂载镜像使用
[root@k8s-master01 configmap]# vim pod-single-configmap-env-variable.yaml
apiVersion: v1
kind: Pod
metadata:
name: dapi-test-pod-secret
spec:
nodeName: k8s-master02
imagePullSecrets: // 它和containers是同一级别的
- name: docker-secret
containers:
- name: test-container
### --- 查看容器创建过程中镜像挂载参数
[root@k8s-master01 secrets]# kubectl describe pod dapi-test-pod-secret
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal Pulled 66s kubelet Container image "busybox:1.28" already present on machine
Normal Created 65s kubelet Created container test-container
Normal Started 65s kubelet Started container test-container
Walter Savage Landor:strove with none,for none was worth my strife.Nature I loved and, next to Nature, Art:I warm'd both hands before the fire of life.It sinks, and I am ready to depart
——W.S.Landor
浙公网安备 33010602011771号