I am attempting to migrate from boot2docker to docker-machine.
I followed the directions here to install docker but I keep getting the following message:
Usually most people have install boot2docker and old version of virtualbox. As said in installation guide, before installing Docker for Mac, we have to uninstall boot2docker and reinstall virtualbox to high version. https://docs.docker.com/engine/installation/mac/#/docker-for-mac
Even though we have installed Docker for Mac, we still encountered error "Could not read CA certificate".
My solution is to remove the docker related environment variables (DOCKER*) from .bash_profile
. It seems a long term solution.
vim ~/.bash_profile
Comment something like DOCKER_*
source ~/.bash_profile
docker info
or docker ps
Hope it helps.
I encountered the same error due to the reason that I had setup the environment to a particular docker machine which I later deleted but my environment was still set to the deleted machine. So docker calls were being redirected the a non-existant machine causing the error.
I unset the environment variables and the issue was fixed:
eval $(docker-machine env -u)
To see which environment variable would be unset run:
docker-machine env -u
If it still doesn't work, run:
find . -name ca.pem
To find out where it is, and then modify DOCKER_CERT_PATH=<the path you find out>
, and on a Mac, it must be .bash_profile
. If you input this in yo .oh-my-zsh
it won't work.
If the file is present in DOCKER_CERT_PATH
env variable, the error could also be caused due to file permissions issue. Please check this use-case as well.
Docker from the launchpad on my Mac quit working as well as commands from terminal. I'm just going to say what I did to fix it for me regardless of whether it makes sense in case it helps someone else out.
unset ${!DOCKER*}
I then ran:
export DOCKER_HOST=tcp://192.168.99.100:2376
export DOCKER_MACHINE_NAME=default
export DOCKER_TLS_VERIFY=1
export DOCKER_CERT_PATH=~/.docker/machine/certs/
I then ran: docker
(which only partially worked)
unset ${!DOCKER*}
againI found my solution here
I needed to update my .bash_profile to look like:
export DOCKER_HOST=tcp://192.168.99.100:2376
export DOCKER_MACHINE_NAME=default
export DOCKER_TLS_VERIFY=1
export DOCKER_CERT_PATH=~/.docker/machine/machines/default
and then run the following to generate the missing ca.pem:
docker-machine regenerate-certs default
I posted this in case this could help anyone else. Thanks/props go to everyone in that thread on github which was found after an hour of pain.