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

文章目录

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

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

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

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

bash 复制代码
# 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

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

验证代理连通性

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

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

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

安装 Docker 最新版

bash 复制代码
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

bash 复制代码
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 中排除本地地址​​

。保存后执行以下命令使配置生效

bash 复制代码
sudo systemctl daemon-reload   # 重新加载 systemd
sudo systemctl restart docker  # 重启 Docker 

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

bash 复制代码
sudo systemctl show --property=Environment docker  # 查看 Docker 服务的环境变量

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

重启验证与拉取镜像

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

成功啦!!!

不使用代理解决方案

安装 Docker 最新版

bash 复制代码
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

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

bash 复制代码
ll /etc/docker

出现这行即配置完成

相关推荐
EAIReport11 小时前
企业级报表自动化:基于Docker的部署实践
运维·docker·自动化
努力进修11 小时前
跨设备文件共享零烦恼!PicoShare+cpolar让跨设备传输更简单
云原生·eureka·cpolar
tianyuanwo12 小时前
多平台容器化RPM构建流水线全指南:Fedora、CentOS与Anolis OS
linux·运维·容器·centos·rpm
敲上瘾15 小时前
【探索实战】:Kurator分布式统一应用分发平台的全面解析与实践指南
分布式·容器·kubernetes·serverless
cui_win15 小时前
Docker Compose 部署一个完整的Prometheus监控告警系统
docker·容器·prometheus
ALex_zry19 小时前
Docker Compose运维技术实战分享:从安装到架构解析
运维·docker·架构
2501_9411497921 小时前
Go语言高性能分布式缓存与Redis实战分享:微服务缓存优化与访问性能提升经验
eureka
roman_日积跬步-终至千里1 天前
【Docker】Docker Stop 后到底发生了什么?——从信号机制到优雅停机
运维·docker·容器
z***6261 天前
Docker:基于自制openjdk8镜像 or 官方openjdk8镜像,制作tomcat镜像
docker·容器·tomcat
Connie14511 天前
记一次K8s故障告警排查(Grafna告警排查)
云原生·容器·kubernetes·grafana