Я получаю сообщение об ошибке "Не удалось получить изображение" на моем deployment
в minikube
с локальным реестром, несмотря на то, что другие развертывания используют тот же реестр образов, работающий должным образом.
Мой рабочий процесс - создать образ из файла Docker с именем docker.collection
как показано ниже.
$ minikube start --insecure-registry localhost:5000 --memory 4096
$ docker build . -f docker.collection -t localhost:5000/collection:latest -t localhost:5000/collection:dev
$ docker push localhost:5000/collection
$ cat deployment.yaml | kubectl apply -f -
Развертывание создается по желанию, но модули не запускаются, а на панели управления minikube отображается:
Не удалось получить изображение «localhost: 5000 / collection: dev»: ошибка rpc: code = Unknown desc = Ошибка, ответ от демона: манифест для localhost: 5000 / collection: dev не найден
У меня нет причин полагать, что при создании или отправке образа возникла какая-либо проблема, и на хост-машине я могу успешно вытащить ...
$ docker pull localhost:5000/collection:dev
dev: Pulling from collection
Digest: sha256:8becfdd412f0b86ece8335aa5ee1aede75992d17f88739a28da5939eab28fde5
Status: Image is up to date for localhost:5000/collection:dev
Что еще я должен проверить? Как я могу получить более подробную информацию о сбое?
Я также проверил:
localhost:5000
: $ minikube ssh
$ ping localhost:5000
PING localhost:5000 (127.0.0.1): 56 data bytes
64 bytes from 127.0.0.1: seq=0 ttl=64 time=0.126 ms
64 bytes from 127.0.0.1: seq=1 ttl=64 time=0.041 ms
64 bytes from 127.0.0.1: seq=2 ttl=64 time=0.058 ms
^C
--- localhost:5000 ping statistics ---
3 packets transmitted, 3 packets received, 0% packet loss
round-trip min/avg/max = 0.041/0.075/0.126 ms
$
run
изображения не удается таким же образом: kubectl run coll-test --image=localhost:5000/collection:dev
дает те же события:Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal Scheduled 24s default-scheduler Successfully assigned dev/coll-test-cf4467b8d-8vpdk to minikube
Normal BackOff 23s kubelet, minikube Back-off pulling image "localhost:5000/collection:dev"
Warning Failed 23s kubelet, minikube Error: ImagePullBackOff
Normal Pulling 7s (x2 over 23s) kubelet, minikube Pulling image "localhost:5000/collection:dev"
Warning Failed 7s (x2 over 23s) kubelet, minikube Failed to pull image "localhost:5000/collection:dev": rpc error: code = Unknown desc = Error response from daemon: manifest for localhost:5000/collection:dev not found
Warning Failed 7s (x2 over 23s) kubelet, minikube Error: ErrImagePull
$ curl http://localhost:5000/v2/_catalog
{"repositories":["collection","foo","bar"]}
# deployment.yaml
apiVersion: apps/v1beta2
kind: Deployment
metadata:
namespace: dev
name: collection
labels:
app: collection
spec:
replicas: 1
selector:
matchLabels:
app: collection
template:
metadata:
labels:
app: collection
spec:
containers:
- name: collection
image: "localhost:5000/collection:dev"
command: ["bash", "./collection_entry.sh"]
imagePullPolicy: Always
# docker.collection
FROM python:3
WORKDIR /code
COPY . /code/
RUN adduser --system --group --no-create-home celery
RUN mkdir /var/run/celery
RUN mkdir /var/log/celery
RUN chown celery:celery /var/run/celery
RUN chown celery:celery /var/log/celery
RUN chmod 755 /var/run/celery
RUN chmod 755 /var/log/celery
RUN pip3 -q install -r requirements.txt
USER celery
ENTRYPOINT ./collection_entry.sh
1) Вы должны бежать eval $(minikube docker-env)
2) Соберите образ с помощью Docker-демона Minikube
docker build -t collection .
3) Установите изображение в спецификации модуля, как тег сборки - collection
4) Установите для imagePullPolicy значение Never, иначе Kubernetes попытается загрузить образ.
apiVersion: apps/v1beta2
kind: Deployment
metadata:
namespace: dev
name: collection
labels:
app: collection
spec:
replicas: 1
selector:
matchLabels:
app: collection
template:
metadata:
labels:
app: collection
spec:
containers:
- name: collection
image: "collection"
command: ["bash", "./collection_entry.sh"]
imagePullPolicy: Never