Has anyone been able to get minikube to work with --driver=podman?
I have tried Fedora 30,31, CentOS7,8, RHEL7,8 all with the same results.
# # minikube start --driver=podman --container-runtime=cri-o --cri-socket=/var/run/crio/crio.sock
minikube v1.9.2 on Fedora 30 (vbox/amd64)
✨ Using the podman (experimental) driver based on user configuration
Starting control plane node m01 in cluster minikube
Pulling base image ...
E0409 16:50:17.654306 30363 cache.go:114] Error downloading kic artifacts: error loading image: Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?
StartHost failed, but will try again: creating host: create host timed out in 120.000000 seconds
Restarting existing podman container for "minikube" ...
Failed to start podman container. "minikube start" may fix it.: driver start: get kic state: "podman inspect -f {{.State.Status}} minikube" failed: exit status 125: Error: error getting image "minikube": unable to find a name and tag match for minikube in repotags: no such image
minikube is exiting due to an error. If the above message is not useful, open an issue:
https://github.com/kubernetes/minikube/issues/new/choose
It feels like cri-o needs to be installed and running. I have done that but still get the same results.
Update 1:
# minikube start --driver=podman --container-runtime=cri-o --cri-socket=/var/run/crio/crio.sock --network-plugin=cni --enable-default-cni --v=1
minikube v1.9.2 on Fedora 30
✨ Using the podman (experimental) driver based on user configuration
Starting control plane node m01 in cluster minikube
Pulling base image ...
E0415 12:38:49.764297 24903 cache.go:114] Error downloading kic artifacts: error loading image: Error response from daemon: 404 page not found
StartHost failed, but will try again: creating host: create: creating: create kic node: create container: failed args: [run --cgroup-manager cgroupfs -d -t --privileged --security-opt seccomp=unconfined --tmpfs /tmp --tmpfs /run -v /lib/modules:/lib/modules:ro --hostname minikube --name minikube --label created_by.minikube.sigs.k8s.io=true --label name.minikube.sigs.k8s.io=minikube --label role.minikube.sigs.k8s.io= --label mode.minikube.sigs.k8s.io=minikube --volume /root/.minikube/machines/minikube/var:/var:exec --expose 8443 --publish=127.0.0.1::8443 --publish=127.0.0.1::22 --publish=127.0.0.1::2376 gcr.io/k8s-minikube/kicbase:v0.0.8] output: Error: invalid option type "exec"
: exit status 125
Restarting existing podman container for "minikube" ...
Failed to start podman container. "minikube start" may fix it.: driver start: get kic state: "podman inspect -f {{.State.Status}} minikube" failed: exit status 125: Error: error getting image "minikube": unable to find a name and tag match for minikube in repotags: no such image
minikube is exiting due to an error. If the above message is not useful, open an issue:
https://github.com/kubernetes/minikube/issues/new/choose
I'm happy to flip over to Fedora 31 or CentOS if needed.
Update 2: Set selinux to permissive with same failure.
Update 3: Per suggestion from @vbatts the minikube start cmd is pretty close to working. It seems crio sock lives in /var/run/crio/ so I updated that path. Now I'm getting the following...
[root@test ~]# minikube start --network-plugin=cni --enable-default-cni --extra-config=kubelet.container-runtime=remote --extra-config=kubelet.container-runtime-endpoint=/var/run/crio/crio.sock --extra-config=kubelet.image-service-endpoint=/var/run/crio/crio.sock --driver=podman
minikube v1.9.2 on Fedora 30
✨ Using the podman (experimental) driver based on user configuration
Starting control plane node m01 in cluster minikube
Pulling base image ...
Downloading Kubernetes v1.18.0 preload ...
> preloaded-images-k8s-v2-v1.18.0-docker-overlay2-amd64.tar.lz4: 542.91 MiB
E0416 09:25:47.539842 1632 cache.go:114] Error downloading kic artifacts: error loading image: Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?
Preparing Kubernetes v1.18.0 on Docker 19.03.2 ...
▪ kubelet.container-runtime=remote
▪ kubelet.container-runtime-endpoint=/var/run/crio/crio.sock
▪ kubelet.image-service-endpoint=/var/run/crio/crio.sock
Enabling addons: default-storageclass, storage-provisioner
Done! kubectl is now configured to use "minikube"
And now these cmds hang ....
[root@test ~]# kubectl get nodes
^C
[root@test ~]# minikube status
E0416 09:30:30.741722 10795 api_server.go:169] unable to get freezer state: cat: /sys/fs/cgroup/freezer/libpod_parent/libpod-16c8b830eb8e4cb0baa576e98d8343fdab1dacea8db4a6a6d84bbb8fbc7c0f92/kubepods/burstable/pod7dd7509c8b924aaaebd697cbbc2aff89/aa2abeea32b056907d33590baf5fc0c213b718cc8b16b548f251326675f32337/freezer.state: No such file or directory
Error: non zero exit code: 1: OCI runtime error
^C
Firstly make sure that you configured Minikube properly: minikube-configuration.
You have to specify network plugin and enable it, also it is important to add image-service endpoint for runtime: /var/run/crio/crio.sock
:
$ sudo minikube start \
--network-plugin=cni \
--enable-default-cni \
--extra-config=kubelet.container-runtime=remote \
--extra-config=kubelet.container-runtime-endpoint=/var/run/crio.sock \
--extra-config=kubelet.image-service-endpoint=/var/run/crio.sock \
--driver=podman
Please take a look: minikube-crio-podman, crio-minikube.