关于Docker拉取镜像超时/无法访问镜像仓库解决方案

关于Docker拉取镜像超时/无法访问镜像仓库解决方案

我今天安装Docker后无论是配置阿里云镜像源或是按照网上以及ai说的配置dns、防火墙、关闭ipv6等方法都无法成功拉取镜像

进行docker login、通过curl命令访问docker镜像仓库也是一律超时或拒绝访问,在我捣鼓了一个下午后终于成功找到解决方法。下面我将针对使用代理的用户以及不使用代理的用户分别给出解决方案

卸载原先安装的Docker及相关配置

# 1. 停止所有Docker容器和守护进程
sudo systemctl stop docker.socket docker.service containerd
sudo pkill -f docker

# 2. 卸载Docker软件包
sudo apt purge -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin

# 3. 删除残留数据和配置
sudo rm -rf /var/lib/docker
sudo rm -rf /var/lib/containerd
sudo rm -rf /etc/docker
sudo rm -rf /etc/apt/sources.list.d/docker*.list

# 4. 删除代理配置文件(之前配置的)
sudo rm -rf /etc/systemd/system/docker.service.d/http-proxy.conf
sudo systemctl daemon-reload

# 5. 清理APT缓存
sudo apt autoremove -y
sudo apt clean

使用代理后无法拉取镜像解决方案

验证代理连通性

curl -I -x http://127.0.0.1:7890 https://hub.docker.com   # 通过代理测试能否访问 Docker Hub

如果能返回 HTTP 200/301 等响应,则表示代理连通正常。若以上命令失败,可尝试先导出环境变量后再测试:

export http_proxy="http://127.0.0.1:7890" # 使用环境变量中的代理访问,注意改成自己的!!!
curl -I https://hub.docker.com   

安装 Docker 最新版

sudo apt-get remove -y docker.io docker-compose docker-compose-v2 docker-doc podman-docker containerd runc  # 卸载旧版 Docker 及冲突软件
sudo apt-get update   # 更新软件包索引
sudo apt-get install -y ca-certificates curl gnupg lsb-release  # 安装必要工具

# 添加 Docker 官方 GPG 密钥并新建 Apt 仓库 keyrings 目录
sudo mkdir -p /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo tee /etc/apt/keyrings/docker.asc  # 获取 Docker GPG 密钥
sudo chmod a+r /etc/apt/keyrings/docker.asc

# 添加 Docker 官方 apt 软件源(Ubuntu 24.04 代号为 noble)
echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] \
https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" \
  | sudo tee /etc/apt/sources.list.d/docker.list  

sudo apt-get update  # 更新仓库索引
sudo apt-get install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin  # 安装 Docker 引擎及相关组件

配置 Docker Daemon HTTP 代理

注意下方将代理地址全都改为自己的,我这里使用的是http://127.0.0.1:7890

sudo mkdir -p /etc/systemd/system/docker.service.d   # 创建 docker.service 的 drop-in 目录
# 编辑 /etc/systemd/system/docker.service.d/http-proxy.conf,添加以下内容:
sudo tee /etc/systemd/system/docker.service.d/http-proxy.conf <<EOF
[Service]
Environment="HTTP_PROXY=http://127.0.0.1:7890"
Environment="HTTPS_PROXY=http://127.0.0.1:7890"
Environment="NO_PROXY=localhost,127.0.0.1"
EOF

上述配置将 Docker 守护进程的 HTTP/HTTPS 代理都指向 127.0.0.1:7890,并在 NO_PROXY 中排除本地地址​​
。保存后执行以下命令使配置生效

sudo systemctl daemon-reload   # 重新加载 systemd
sudo systemctl restart docker  # 重启 Docker 

重启后,可用下面命令查看代理环境变量是否已被加载:

sudo systemctl show --property=Environment docker  # 查看 Docker 服务的环境变量

若输出中包含类似 HTTP_PROXY=http://127.0.0.1:7890 字样,则表示代理配置已生效

重启验证与拉取镜像

sudo docker run hello-world  # 运行官方测试镜像确认安装成功


成功啦!!!

不使用代理解决方案

安装 Docker 最新版

sudo apt-get remove -y docker.io docker-compose docker-compose-v2 docker-doc podman-docker containerd runc  # 卸载旧版 Docker 及冲突软件
sudo apt-get update   # 更新软件包索引
sudo apt-get install -y ca-certificates curl gnupg lsb-release  # 安装必要工具

# 添加 Docker 官方 GPG 密钥并新建 Apt 仓库 keyrings 目录
sudo mkdir -p /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo tee /etc/apt/keyrings/docker.asc  # 获取 Docker GPG 密钥
sudo chmod a+r /etc/apt/keyrings/docker.asc

# 添加 Docker 官方 apt 软件源(Ubuntu 24.04 代号为 noble)
echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] \
https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" \
  | sudo tee /etc/apt/sources.list.d/docker.list  

sudo apt-get update  # 更新仓库索引
sudo apt-get install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin  # 安装 Docker 引擎及相关组件

配置阿里云容器镜像加速

阿里云容器镜像服务控制台获取专属加速地址

阿里云镜像连接:https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors

复制下方命令在命令行输入

ll /etc/docker


出现这行即配置完成

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值