【环境】
MacOS
minikube version: v1.25.2
minikube vm-driver: hyperkit
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
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 .
这里还是需要设置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
查看,可以看到Pod已经运行: