minikube中下載鏡像錯誤Couldn't connect: SOCKS protocol error

問題描述

在啓動 minikube 的時候使用的代理環境變量創建的 minikube 虛擬機,但是在下載或者查詢鏡像的時候會出錯,比如下面兩個命令都會報相似錯誤 “Couldn’t connect: SOCKS protocol error”

# 在 minikube 虛擬機外執行
$ kubectl run hello-minikube --image=k8s.gcr.io/echoserver:1.4 --port=8080

$ minikube ssh 
# 在 minikube 虛擬機內執行
$ docker search echoserver
Error response from daemon: Get https://index.docker.io/v1/search?q=echoserver&n=25: Couldn't connect: SOCKS protocol error

問題原因

進入 在 minikube 虛擬機內,然後使用 docker info 查看一下 docker 的配置

$ minikube ssh 

$ docker info
Containers: 21
 Running: 21
 Paused: 0
 Stopped: 0
Images: 10
Server Version: 18.09.8
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 macvlan null overlay
 Log: awslogs fluentd gcplogs gelf journald json-file local logentries splunk syslog
Swarm: inactive
Runtimes: runc
Default Runtime: runc
Init Binary: docker-init
containerd version: 894b81a4b802e4eb2a91d1ce216b8817763c29fb
runc version: N/A
init version: N/A (expected: )
Security Options:
 seccomp
  Profile: default
Kernel Version: 4.15.0
Operating System: Buildroot 2018.05.3
OSType: linux
Architecture: x86_64
CPUs: 2
Total Memory: 1.897GiB
Name: minikube
ID: I7FY:LMTY:F4SU:NTMU:IJ7Q:FTIB:3UWP:TKLG:42XA:QQOX:JAFD:PV2B
Docker Root Dir: /var/lib/docker
Debug Mode (client): false
Debug Mode (server): false
HTTP Proxy: http://<host>:<port>
HTTPS Proxy: http://<host>:<port>
No Proxy: 127.0.0.1/24
Registry: https://index.docker.io/v1/
Labels:
 provider=virtualbox
Experimental: false
Insecure Registries:
 10.96.0.0/12
 127.0.0.0/8
Live Restore Enabled: false
Product License: Community Engine

其中包含了下面三行,正是自己當時啓動 minikube 的時候使用的代理,而這兩個代理被 minikube 寫入了 docker 的配置文件中。

HTTP Proxy: http://<host>:<port>
HTTPS Proxy: http://<host>:<port>
No Proxy: 127.0.0.1/24

解決辦法

使用 “minikube ssh” 命令登錄到虛擬機內,然後修改 Docker 配置文件 /usr/lib/systemd/system/docker.service,這是CentOS7.x上 Docker 配置文件的路徑,註釋掉上面三行。

#Environment=HTTP_PROXY=http://192.168.0.53:1080
#Environment=HTTPS_PROXY=http://192.168.0.53:1080
#Environment=NO_PROXY=127.0.0.1/24

重新啓動服務

$ sudo systemctl daemon-reload
$ sudo systemctl restart docker.service

然後重新查詢或拉取鏡像,問題解決。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章