【环境】
MacOS
minikube version: v1.25.2
minikube vm-driver: hyperkit
【参考】
https://minikube.sigs.k8s.io/docs/handbook/pushing/
1. Pushing directly to the in-cluster Docker daemon (docker-env)
1.1 Linux或MacOS可以使用命令:
eval $(minikube docker-env)
这个适用于用vm-driver启动的minikube(比如minikube start --vm-driver=hyperkit,或是其它虚拟driver,默认minikube start使用的是docker的虚拟driver),这个命令不适用vm-driver=none的情况。
我们可以在minikube集群中用daemon的方式重用现有的docker。
意味着我们不需要再将docker image push到远程的docker hub后,再在deployment.yaml中pull了,而是可以在minikube中直接使用docker build后使用这个镜像了!!!
1.2 测试
我们先打包一个本地镜像:
准备一个Spring Boot项目,端口为8090,可以参考我之前的文章:【k8s学习】在Kubernetes上部署Hazelcast集群(embedded模式)
build镜像:
docker build -f DockerFile -t localhost/hazelcast-k8s-single .
通过docker images
查看镜像:
以往接下来的步骤是docker push
命令将镜像推送至docker hub,而现在因为docker以daemon的方式include到minikube集群中了,所以在minikube中可以直接使用打包的docker image。
创建deployment.yaml文件,重点是需要先把属性imagePullPolicy:Always
关掉,改用imagePullPolicy:IfNotPresent
或imagePullPolicy:Never
:
apiVersion: apps/v1
kind: Deployment
metadata:
name: hazelcast-k8s
labels:
app: hazelcast
spec:
replicas: 1
selector:
matchLabels:
app: hazelcast
template:
metadata:
labels:
app: hazelcast
spec:
containers:
- name: hazelcast-k8s
image: localhost/hazelcast-k8s-single
imagePullPolicy: IfNotPresent
ports:
- containerPort: 8090
部署deployment.yaml
kubectl apply -f deployment.yaml
查看Pod log,可以看到已经运行了:
kubectl logs hazelcast-k8s-6dfb49ccb8-dlxkj
1.3 想要取消上述的命令:
参考:https://stackoverflow.com/questions/30550742/how-do-i-undo-the-command-eval-docker-machine-env-blog
官网:https://minikube.sigs.k8s.io/docs/commands/docker-env/
官网上有说minikube docker-env [flags]
,这个命令,可以加上参数-u, --unset:Unset variables instead of setting them
,即为取消上述的docker daemon操作,试一下:
docker-machine env -u
2. Push images using ‘cache’ command
2.1 首先调用minikube cache list
查看有没有cache,确保下面的测试准确性。
2.2 minikube image load介绍
我们可以把docker image直接push到minikube中,这个image会自动被minikube缓存起来。
首先还是先打包一个本地docker镜像:
build镜像:
docker build -f DockerFile -t cached/hazelcast-k8s-single .
添加到minikube cache中:
minikube cache add cached/hazelcast-k8s-single
查看cache list:
minikube cache list
另,如果cache里已经有了image,想要更新,可以用:
minikube cache reload
2.3 测试
修改#1.2中的deployment image,从localhost/hazelcast-k8s-single
改成cached/hazelcast-k8s-single
,然后部署之。
这里还是需要设置imagePullPolicy为IfNotPresent或Never,如果不设置,pod在pull image的时候会报错,因为它还是会试图从docker hub中pull image:Failed to pull image "cached/hazelcast-k8s-single": rpc error: code = Unknown desc = Error response from daemon: pull access denied for cached/hazelcast-k8s-single, repository does not exist or may require 'docker login': denied: requested access to the resource is denied
通过kubectl describe
可以看到pull image直接在machine中存在了,所以不会从docker hub中拉取了:
kubectl describe pod hazelcast-k8s-699ffb895c-jfk42
2.4 删除minikube cache 列表
minikube cache delete cached/hazelcast-k8s-single
文章开头的文章中还介绍了别的一些方式,可以点进去详细了解下其它方式,比如:
- Pushing directly to in-cluster CRI-O. (podman-env)
- Pushing to an in-cluster using Registry addon
- Building images inside of minikube using SSH
- 等等