我有一个Dockerfile创建的以下图像:
REPOSITORY TAG IMAGE ID CREATED SIZE
ruby/lab latest f1903b1508cb 2 hours ago 729.6 MB
我有以下YAML文件:
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: ruby-deployment
spec:
replicas: 2
template:
metadata:
labels:
app: ruby
spec:
containers:
- name: ruby-app
image: ruby/lab
imagePullPolicy: IfNotPresent
ports:
- containerPort: 4567
当我创建部署时,我在pod中获得了以下信息:
ruby-deployment-3830038651-sa4ii 0/1 ImagePullBackOff 0 7m
ruby-deployment-3830038651-u1tvc 0/1 ImagePullBackOff 0 7m
并从下面的错误Failed to pull image "ruby/lab:latest": Error: image ruby/lab not found
:
8m 2m 6 {kubelet minikube} spec.containers{ruby} Normal Pulling pulling image "ruby/lab:latest"
8m 2m 6 {kubelet minikube} spec.containers{ruby} Warning Failed Failed to pull image "ruby/lab:latest": Error: image ruby/lab not found
8m 2m 6 {kubelet minikube} Warning FailedSync Error syncing pod, skipping: failed to "StartContainer" for "ruby" with ErrImagePull: "Error: image ruby/lab not found"
是否真的有必要在docker中使用注册表?我只是想在本地进行测试并将我的代码/ repo传递给朋友进行测试
谢谢
您可以通过运行将docker客户端指向VM的docker守护程序
eval $(minikube docker-env)
然后,您可以正常构建图像并使用kubectl创建kubernetes资源。确保你有
imagePullPolicy: IfNotPresent
在您的YAML或JSON规范中。
此外,还有一个标志可以将不安全的注册表传递给minikube VM。但是,必须在第一次创建机器时指定。
minikube start --insecure-registry
您可能还想在使用私有注册表http://kubernetes.io/docs/user-guide/images/时阅读此内容
AFAIR minikube在VM中运行,因此它不会在主机上看到您在本地构建的图像,但是......如https://github.com/kubernetes/minikube/blob/master/docs/reusing_the_docker_daemon.md中所述,您可以使用eval $(minikube docker-env)
实际使用在minikube上运行的docker守护程序,从此构建您的图像minikubes docker因此期望它可用于minikubes k8s引擎而无需从外部注册表中提取
docker pull,在每个节点中手动拉取所有图像或运行DaemonSet以拉取所有图像