如何不改变Docker daemon 的配置文件的解决Error response from daemon: Get "https://150.158.147.155:5000/v2/": http: server gave HTTP response to HTTPS client
时间: 2024-01-21 07:18:04 浏览: 134
这个错误通常是因为Docker daemon配置文件中的"insecure-registries"参数不包含你尝试访问的仓库地址。但是,如果你不想改变Docker daemon的配置文件,可以尝试以下方法:
1. 在Docker命令中使用"--insecure-registry"参数,例如:
```
docker pull --insecure-registry 150.158.147.155:5000/image_name
```
2. 在Docker客户端的环境变量中设置"Docker daemon"的配置,例如:
```
export DOCKER_TLS_VERIFY=0
export DOCKER_HOST=tcp://your-docker-host:2376
export DOCKER_CERT_PATH=/path/to/your/certs
export DOCKER_API_VERSION=1.23
```
请注意,这些方法都涉及到安全问题,因此仅在测试或开发环境中使用。如果你需要在生产环境中使用,请确保正确地配置Docker daemon的安全设置。
相关问题
Error response from daemon: Get "https://150.158.147.155:5000/v2/": http: server gave HTTP response to HTTPS client
这个错误提示表明你的 Docker 客户端尝试使用 HTTPS 协议访问 Docker Registry,但是该 Registry 只支持 HTTP 协议。你需要将 Docker 客户端配置为使用 HTTP 协议访问该 Registry,可以尝试以下方法:
1. 在 Docker 客户端的配置文件 `/etc/docker/daemon.json` 中添加以下内容:
```
{
"insecure-registries": ["150.158.147.155:5000"]
}
```
然后重启 Docker 服务。
2. 在启动 Docker 客户端时使用 `--insecure-registry` 参数指定该 Registry 的地址和端口:
```
docker run --insecure-registry 150.158.147.155:5000 image:tag
```
注意,使用这种方法可能存在安全风险,因为 Docker 客户端会完全信任该 Registry,而不会验证其证书。建议在使用时谨慎考虑。
error execution phase preflight: [preflight] Some fatal errors occurred: [ERROR ImagePull]: failed to pull image k8s.gcr.io/kube-apiserver:v1.22.17: output: Error response from daemon: Ge t "https://k8s.gcr.io/v2/": net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers), error: exit status 1 [ERROR ImagePull]: failed to pull image k8s.gcr.io/kube-controller-manager:v1.22.17: output: Error response from d aemon: Get "https://k8s.gcr.io/v2/": net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers), error: exit status 1 [ERROR ImagePull]: failed to pull image k8s.gcr.io/kube-scheduler:v1.22.17: output: Error response from daemon: Ge t "https://k8s.gcr.io/v2/": net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers), error: exit status 1 [ERROR ImagePull]: failed to pull image k8s.gcr.io/kube-proxy:v1.22.17: output: Error response from daemon: Get "h ttps://k8s.gcr.io/v2/": net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers), error: exit status 1 [ERROR ImagePull]: failed to pull image k8s.gcr.io/pause:3.5: output: Error response from daemon: Get "https://k8s .gcr.io/v2/": context deadline exceeded, error: exit status 1 [ERROR ImagePull]: failed to pull image k8s.gcr.io/etcd:3.5.0-0: output: Error response from daemon: Get "https:// k8s.gcr.io/v2/": net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers), error: exit status 1 [ERROR ImagePull]: failed to pull image k8s.gcr.io/coredns/coredns:v1.8.4: output: Error response from daemon: Get "https://k8s.gcr.io/v2/": context deadline exceeded, error: exit status 1 [preflight] If you know what you are doing, you can make a check non-fatal with `--ignore-preflight-errors=...` To see the stack trace of this error execute with --v=5 or higher
这个错误是由于在安装 Kubernetes 期间无法拉取所需的镜像引起的。它表明在尝试从 k8s.gcr.io 拉取镜像时出现了连接超时的问题。
这个问题可能是由于网络连接问题、防火墙设置或者代理配置引起的。以下是一些解决该问题的常见步骤:
1. 确保您的网络连接正常,尝试通过浏览器访问 `https://k8s.gcr.io/v2/` 确认是否可以访问。
2. 如果您使用了代理,请确保已正确配置 Docker 的代理设置。您可以通过编辑 `/etc/systemd/system/docker.service.d/http-proxy.conf`(如果不存在则创建它)文件来设置代理。例如,如果您使用 HTTP 代理,可以添加以下内容:
```
[Service]
Environment="HTTP_PROXY=http://proxy.example.com:8080/"
Environment="HTTPS_PROXY=http://proxy.example.com:8080/"
```
3. 如果您在防火墙后面,确保防火墙允许 Docker 访问所需的资源。您可以尝试临时禁用防火墙并重新运行安装命令,以验证是否与防火墙有关。
4. 如果您使用的是私有网络或内部网络,请确保您的网络环境正确配置,以允许 Docker 访问所需的资源。
5. 您还可以尝试使用其他镜像源或加速器来拉取所需的镜像。例如,您可以使用阿里云容器镜像服务(https://cr.console.aliyun.com/)或其他可靠的镜像源。
尝试上述步骤后,如果问题仍然存在,请确保您的环境满足 Kubernetes 的最低要求,并尝试在不同的网络环境下重新运行安装命令。
阅读全文