linux 从仓库拉取镜像,K8s集群从私有镜像仓库中拉取镜像

Node节点已经配置了docker私有库,docker pull镜像可以正常拉取,但是在k8s master节点创建deployment时,pod一直处于ImagePullBackOff,ErrImagePull状态来回切换。

kubectl describe pod 查看pod错误提示,看到Failed to pull image “xxx.xxx.xxx/job:latest”: rpc error: code = Unknown desc = Error response from daemon:pull access denied for xxx.xxx.xxx/job, repository does not exist or may require ‘docker login’: denied: requested access to the resource is denied

查了一会文档,为了方便以后操作,创建一个Secret,在deployment里指定imagePullSecrets,就可以正常拉取。

1.创建Secret

kubectl create secret docker-registry myregcred -n ceres\

--docker-server= \

--docker-username= \

--docker-password= \

--docker-email=

可以通过下面这个命令查看,docker私有仓库的详细信息

kubectl get secret myregcred -n ceres --output="jsonpath={.data.\.dockerconfigjson}" | base64 --decode

2.在deployment指定imagePullSecrets

---

apiVersion: apps/v1

kind: Deployment

metadata:

name: ceres-job

namespace: ceres

spec:

selector:

matchLabels:

app: job

replicas: 2

template:

metadata:

labels:

app: job

spec:

containers:

- name: ceres-job

image: xxx.xxx.xxx/ceres_k8s/job:latest

ports:

- containerPort: 8080

imagePullSecrets:

- name: myregcred

3.重新创建deployment,查看pod状态。

[root@m0001 ceres]# kubectl get pod -n ceres

NAME READY STATUS RESTARTS AGE

ceres-job-77586dc854-9tmdt 1/1 Running 0 43m

ceres-job-77586dc854-jqhvb 1/1 Running 0 43m

[root@m0001 ceres]#

已经看到pod已经启动。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值