docker用不了了,但工作还要继续。以前从公共仓库(Docker Hub)下载的镜像,需要推送到自己的私有仓库,之后再从私有仓库中拉取。
私有仓库我们一般使用Harbor,github地址为Harbor (github.com)。具体的安装方式请访问Docker 安装 Harbor (踩坑完毕)_m1 使用docker 安装 harbor-CSDN博客。由于时间关系,上面安装harbor的方式我并没验证。大家也可以网上自己寻找其它安装方法。
下面我直接进入主题,讲解如何登陆自己的私有仓库。
首先,我在阿里云上的地址http://41.68.153.178:6114搭建了一个harbor私有仓库。请不要试图访问这个地址,这是我在原有的基础上,随便改了几个数字,防止被攻击。这里给出一个这样的地址,是为了帮助大家更好的理解,至少我认为比"IP地址:端口号"的方式好多了。
要访问私有仓库,需要使用docker login的方式访问,不通过login是无法访问私有仓库的。下面是我首次使用的命令
docker login --username=admin --password=41nccq827afbcb5i http://41.68.153.178:6114
回车后,服务器反馈给我一个错误。
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
Error response from daemon: Get "https://41.68.153.178:6114": http: server gave HTTP response to HTTPS client
意思是说,使用--password选项的方式不安全,建议使用--password-stdin,并且说明我应该访问https,而不是访问http的地址。
因为docker默认会以https的方式访问,想要访问http需要修改docker的配置文件。
windows下配置文件路径为:C:/Users/你的用户名/.docker/daemon.json
linux下配置文件路径为:/etc/docker/daemon.json
在其中需要加入以下内容:
"insecure-registries": ["41.68.153.178:6114"]
然后重启docker
systemctl restart docker
这个地址就被设置为受信任列表,之后就可以访问了。
于是我再次输入
docker login --username=admin --password-stdin http://41.68.153.178:6114
之后在光标处输入密码,不起作用。看了下官网,官网的解决思路是这样的:
cat ~/my_password.txt | docker login --username foo --password-stdin
也就是说,需要一个文件,将密码传给这个stdin。
所以我在一个文件夹下建立了这个文件,并将密码粘贴进入。再次输入,登陆成功。
cat ./my_password.txt | docker login --username admin --password-stdin http://41.68.153.178:6114
Login Succeeded