在解决问题前,要先树立两个思想:
- 无论是
docker login
命令还是docker pull
命令,无非就是发送请求去harbor
服务器获取数据。那么报错无非就是 网络问题 或者 接收的内容解析报错。docker harbor
的 ui 页面和docker login
、docker pull
中的地址最终映射的是同一台机器的同一个端口。
完整报错信息:
error during connect: This error may indicate that the docker daemon is not running.: Post "http://%2F%2F.%2Fpipe%2Fdocker_engine/v1.24/auth": open //./pipe/docker_engine: The system cannot find the file specified.
提示已经非常明显了,本地 docker
服务没有启动,或者启动失败。
启动本地 docker 服务。
这是因为无法解析 harbor 域名,或者解析后的 ip 和端口网络不通。可能是 harbor
地址写错了,需要重新核对一下域名和端口,比如我这里就是因为域名写错了,当前域名无法解析。
可以用 ping 域名
的方式判断是否可以解析域名,用 telnet ip 端口
判断网络是否开通。
将 harbor
地址修改为正确的域名和端口即可:
如果遇到了 500 Internal Server Error,参考下面的解决方案。
我这里导致这个问题是nginx代理配置的问题,在我本地机器之间还多了一层 Nginx 进行转发,将 harbor.xxx.cn 域名转发到了 192.168.1.134:8080 下。
具体为什么中间经过一层 Nginx 转发之后就会报 500 Internal Server Error
问题,我这边还没有定位到。
修改本地 hosts
,增加 192.168.1.134 harbor.xxx.cn
配置,直接解析到 Harbor 仓库所在服务器 ip。
出现这个问题有两种情况,一种是 docker login
的时候报这个错,一种是 docker login
不报错,但是 docker pull
报这个错。
我们先说第一种情况:
如果是 docker login 的时候就报错,是因为域名和端口错误导致的,比如我这里就是因为漏加了端口。那么细心的同学可能就会发现,为什么同样是域名和端口错误,为什么有的时候报 Get "https://harbor.xxx.cn/v2/": EOF
有的时候报 invalid character '<' looking for beginning of value
呢?
Get "https://harbor.xxx.cn/v2/": EOF
:出现这类问题,说明域名无法解析,或者域名解析后的 ip 和端口网络不通。invalid character '<' looking for beginning of value
:出现这类问题,说明当前机器和目标地址的网络是通的,但是目标域名解析后ip对应服务器的 8080 端口是一个 html 页面,所以报了一个 <
开头无效字符的错。将域名和端口修改正确后,如果继续报错 500 Internal Server Error
,可以参考上面第二章通过配置 hosts 的解决方案。我这里增加端口后就可以正常登录了:
如果将域名和端口修改正确后,可以正常登录了,但是拉取失败,可以参考下面的内容。
出现这类问题,如果确定地址没有写错的话,就是域名解析有问题了。虽然提示 Login Succeeded
,但是实际并没有登录成功,可以填一个错误的账号密码试下,还是会成功的。
报错 invalid character '<' looking for beginning of value
说明网络是通的,但是目标域名解析后ip对应服务器的 8080 端口是一个 html 页面,所以报了一个 <
开头无效字符的错。
在本地配置 hosts,将域名和实际 ip 重新配置后,就可以正常拉取了。
配置格式:ip 域名
。
docker -v
检查 docker 服务是否启动;
ping 域名
检查域名是否可以正常解析;
telnet ip 端口
检查网络是否通;
在 hosts 中追加配置 ip 域名
;(不管第2步域名是否可以成功解析到都要配置看看)
如果是 Linux 端,检查完以上 4 步基本就可以解决问题了。
如果使用的是 Windows 端的 Docker Desktop
,则需要检查下设置中的 Docker Engine
,需要给仓库地址设置 insecure-registries
白名单。
例如:仓库 ip 地址:192.168.1.66:8080,仓库域名地址:harbor.acgkaka.cn:8080,则 Docker Engine 配置如下:(registry-mirrors
为扩展镜像仓库,用于快速拉取镜像,选配)
{
"builder": {
"gc": {
"defaultKeepStorage": "20GB",
"enabled": true
}
},
"experimental": false,
"features": {
"buildkit": true
},
"insecure-registries": [
"192.168.1.66:8080",
"harbor.acgkaka.cn:8080"
],
"registry-mirrors": [
"https://docker.mirrors.ustc.edu.cn",
"https://hub-mirror.c.163.com",
"https://registry.docker-cn.com"
]
}
整理完毕,完结撒花~