|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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了