Docer for Mac的ca.pem找不到的问题

2017-04-26 10:27:48来源:http://www.shuizhongyueming.com/2017/04/25/docer-for-mac的ca-作者:水中月明的Blog人点击

之前安装过Docker Toolbox来实现在Mac上面跑Docker,后来Docker又出了一个Docker for Mac,好奇心一起就卸了Docker Toolbox,装了它。



愿意尝试的原因是Docker Toolbox主要是用VirtualBox来放container,Mac环境里面相关的docker命令其实都是代理,最终的实现是在VirtualBox里面。而Docker for Mac用的是macOS的一个框架HyperKit
来实现的,不需要使用VirtualBox来做中间代理,性能上会有很大的提升。当然,前提是你的系统是升级到了macOS10.11。



顺利安装和启动Docker for Mac之后,在命令行运行docker info
命令,会出现如下错误。


could not read CA certificate "/Users/{{username}}/.docker/ca.pem": open /Users/{{username}}/.docker/ca.pem: no such file or directory

在网上找了不少解决方式,


bash_profile


尝试了下这个网址里面说的https://github.com/boot2docker/osx-installer/issues/126
_



我的用户目录下没有.bash_profile
的文件,我是用的zsh,所以在.zsh_rc
找了找(安装Docker Toolbox是很久之前的事情了,根本不记得当初怎么安装的),意外的也找到了当初配置的一些DOCKER_*的环境变量。注释,重启zsh,再次运行docker info
,还是不行。


docker machine

然后又继续尝试上面网址里面,后续给的方法:


docker-machine regenerate-certs default
egenerate TLS machine certs?Warning: this is irreversible. (y/n): y
Regenerating TLS certificates
Host does not exist: "default"

失败。



既然是说default
不存在,那我就来创建一个



查看了docker-machine
相关的命令,刚好有一个create
命令,执行了一下:


docker-machine create default
Creating CA: /Users/{{username}}/.docker/machine/certs/ca.pem
Creating client certificate: /Users/{{username}}/.docker/machine/certs/cert.pem
Running pre-create checks...
Error with pre-create check: "exit status 126"


搜了一下关于exit status 126
的相关错误,说的是没安装VirtualBox,这时候我觉得不对劲了,因为跑Docker for Mac是不需要VirtualBox的啊。



正式看了一下docker machine是什么东西,原来是一个用来方便的管理多种类型的docker主机的一个工具,可以是虚拟机,本地主机和云平台,具体可以看看这个链接:https://yeasy.gitbooks.io/docker_practice/content/machine/usage.html



顺便推荐一下这本电子书《Docker —— 从入门到实践》


看完docker machine的作用,可以看的出来,这和我现在想做的事情和遇到的问题,没有太大干系。我是安装完了Docker的环境,然后在执行docker命令的时候出现了问题,不是在已经有container的时候在维护上出了问题。


环境变量


这时候我开始回到官网来追根溯源了,很幸运的找到一篇深入比较Docker for Mac和Docker Toolbox的文章:Docker for Mac vs. Docker Toolbox



这个对于Docker for Mac和Docker Toolbox各自的实现机制说的十分透彻,同时还意外的有一个Setting up to run Docker for Mac
章节,说了如何配置Docker for Mac的环境,在你已经或者曾经安装过Docker Toolbox的情况下。


按照上面说的执行命令


env | grep DOCKER

顺利的找到了所有的DOCKER_*的环境变量


对对应的变量执行 unset


unset DOCKER_TLS_VERIFY
unset DOCKER_CERT_PATH
unset DOCKER_MACHINE_NAME
unset DOCKER_HOST

再次执行


env | grep DOCKER

保证环境变量已经清除。


然后执行


docker info

一个正常的信息列表出来了


Containers: 0
Running: 0
Paused: 0
Stopped: 0
Images: 0
Server Version: 17.03.1-ce
Storage Driver: overlay2
Backing Filesystem: extfs
Supports d_type: true
Native Overlay Diff: true
Logging Driver: json-file
Cgroup Driver: cgroupfs
Plugins:
Volume: local
Network: bridge host ipvlan macvlan null overlay
Swarm: inactive
Runtimes: runc
Default Runtime: runc
...

以上就是整个debug的过程。其实这么折腾,主要还是自己不是很了解docker,得抽空再好好看看上面说的那本电子书才行了。


最新文章

123

最新摄影

闪念基因

微信扫一扫

第七城市微信公众平台