当前位置: 首页 > ops >正文

WSL Ubuntu Docker 代理自动配置教程

WSL Ubuntu Docker 代理自动配置教程

WSL Ubuntu Docker 代理自动配置教程

背景说明

在 WSL2 环境下使用 Docker 时,由于网络环境限制,经常需要通过 Windows 主机上的代理来访问 Docker Hub。但每次 Windows 重启后,WSL 获取到的主机 IP 地址可能会发生变化,导致 Docker 代理配置失效。

本教程将帮你配置一个自动化方案,让 Docker 在每次 WSL 启动时都能自动获取最新的 Windows 主机 IP 并配置代理。

解决的问题

  1. IP 地址动态变化:自动获取最新的 Windows 主机 IP
  2. 开机自动配置:WSL 启动时自动设置 Docker 代理
  3. 避免重复执行:只在系统层面执行一次,不会每次打开终端都重复设置
  4. 时序问题:确保在 Docker 启动前就配置好代理

前提条件

  • WSL2 Ubuntu 系统
  • Docker 已安装并可正常运行
  • Windows 上运行着代理服务(本教程以 7890 端口为例)

配置步骤

步骤 1:创建代理配置脚本

创建专门用于 systemd 服务的 Docker 代理配置脚本:

# 创建脚本文件
nano ~/setup_docker_proxy_systemd.sh

脚本内容:

#!/bin/bash# 专门给 systemd 服务使用的 Docker 代理配置脚本
# 此脚本以 root 身份运行,不需要使用 sudo# 获取 Windows 宿主机 IP
HOST_IP=$(cat /etc/resolv.conf | grep nameserver | awk '{print $2}')
PROXY_PORT=7890echo "Setting up Docker proxy with Windows host IP: $HOST_IP:$PROXY_PORT"# 检查代理是否可用(可选,失败不会阻止执行)
if ! timeout 2 nc -z $HOST_IP $PROXY_PORT 2>/dev/null; thenecho "Warning: Proxy server not reachable at $HOST_IP:$PROXY_PORT"
fi# 创建 Docker systemd 代理配置文件
mkdir -p /etc/systemd/system/docker.service.d# 动态生成代理配置文件
cat > /etc/systemd/system/docker.service.d/http-proxy.conf << EOF
[Service]
Environment="HTTP_PROXY=http://${HOST_IP}:${PROXY_PORT}"
Environment="HTTPS_PROXY=http://${HOST_IP}:${PROXY_PORT}"
Environment="NO_PROXY=localhost,127.0.0.1,::1,10.0.0.0/8,192.168.0.0/16,172.16.0.0/12"
EOF# 重新加载 systemd 配置
systemctl daemon-reloadecho "Docker proxy configuration updated for host IP: $HOST_IP:$PROXY_PORT"

给脚本添加执行权限:

chmod +x ~/setup_docker_proxy_systemd.sh

步骤 2:创建 systemd 服务

创建 systemd 服务配置文件:

# 创建服务文件
nano ~/docker-proxy-update.service

服务文件内容:

[Unit]
Description=Update Docker proxy with current Windows host IP
After=network.target
Before=docker.service[Service]
Type=oneshot
ExecStart=/home/user/setup_docker_proxy_systemd.sh
RemainAfterExit=yes
User=root[Install]
WantedBy=multi-user.target

注意:请将 /home/user/ 替换为你的实际用户主目录路径。

步骤 3:安装并启用服务

# 复制服务文件到系统目录
sudo cp docker-proxy-update.service /etc/systemd/system/# 重新加载 systemd 配置
sudo systemctl daemon-reload# 启用服务(开机自启)
sudo systemctl enable docker-proxy-update.service# 启动服务进行测试
sudo systemctl start docker-proxy-update.service

步骤 4:验证配置

检查服务状态:

# 查看服务状态
sudo systemctl status docker-proxy-update.service# 查看生成的配置文件
cat /etc/systemd/system/docker.service.d/http-proxy.conf# 验证 Docker 环境变量
sudo systemctl show docker --property=Environment

重启 Docker 服务以应用配置:

sudo systemctl restart docker

步骤 5:测试 Docker 代理

测试是否能正常拉取镜像:

# 测试拉取小镜像
sudo docker pull hello-world# 测试拉取稍大的镜像
sudo docker pull nginx:alpine

如果能成功拉取,说明代理配置成功!

清理旧配置(可选)

如果之前在 .bashrc 中配置过 Docker 代理,建议清理掉避免冲突:

# 编辑 .bashrc
nano ~/.bashrc# 删除或注释掉类似以下的行:
# ~/setup_docker_proxy.sh
# (~/setup_docker_proxy.sh > /dev/null 2>&1 &)

工作原理

  1. 启动时机:WSL 启动 → systemd 启动 → docker-proxy-update.service 运行
  2. IP 获取:服务从 /etc/resolv.conf 动态获取最新的 Windows 主机 IP
  3. 配置生成:自动生成 /etc/systemd/system/docker.service.d/http-proxy.conf 文件
  4. Docker 应用:Docker 服务启动时自动读取代理配置

文件结构

配置完成后,相关文件分布如下:

/home/user/
├── setup_docker_proxy_systemd.sh          # 代理配置脚本
└── docker-proxy-update.service            # 服务配置文件(备份)/etc/systemd/system/
├── docker-proxy-update.service            # systemd 服务文件
└── docker.service.d/└── http-proxy.conf                     # Docker 代理配置文件

故障排除

问题 1:服务启动失败

# 查看详细错误信息
sudo journalctl -u docker-proxy-update.service -f

问题 2:代理不生效

# 检查代理服务器是否可达
nc -z $(cat /etc/resolv.conf | grep nameserver | awk '{print $2}') 7890# 手动重新运行配置脚本
sudo ~/setup_docker_proxy_systemd.sh# 重启 Docker
sudo systemctl restart docker

问题 3:IP 地址变化后代理失效

由于服务只在启动时运行一次,如果 Windows 重启后 IP 变化,需要:

# 重新运行服务
sudo systemctl start docker-proxy-update.service# 或者重启 WSL(推荐)

自定义配置

修改代理端口

如果你的代理端口不是 7890,修改脚本中的 PROXY_PORT 变量:

# 编辑脚本
nano ~/setup_docker_proxy_systemd.sh# 修改这一行
PROXY_PORT=你的端口号

添加更多 NO_PROXY 地址

如果需要排除更多地址不走代理,修改脚本中的 NO_PROXY 环境变量。

验证清单

  • 脚本文件已创建并有执行权限
  • systemd 服务已安装并启用
  • 服务运行状态正常
  • Docker 配置文件已生成
  • Docker 能成功拉取镜像
  • 重启 WSL 后代理仍然生效

总结

通过这个配置方案,你的 WSL Ubuntu Docker 将能够:

  1. 自动适应 IP 变化:每次启动都获取最新的 Windows 主机 IP
  2. 开机即可用:无需手动配置,WSL 启动后 Docker 代理自动生效
  3. 一次配置,长期使用:无需重复操作,稳定可靠

现在你可以愉快地使用 docker pull 命令,无论何时重启都不用担心代理配置问题了!

http://www.xdnf.cn/news/20235.html

相关文章:

  • LeetCode 139. 单词拆分 - 动态规划解法详解
  • 【软考架构】第二章 计算机系统基础知识:计算机网络
  • 主数据系统是否对于企业是必需的?
  • 最大似然估计:损失函数的底层数学原理
  • 基本数据类型和包装类的区别?
  • 2025年大数据专业人士认证发展路径分析
  • MySQL运维补充
  • 【目录-判断】鸿蒙HarmonyOS开发者基础
  • 敏捷scrum管理实战经验总结
  • 贪心算法应用:化工反应器调度问题详解
  • 【LLIE专题】SIED:看穿0.0001lux的极致黑暗
  • NPU边缘推理识物系统
  • 懒加载的概念
  • 新能源风口正劲,“充电第一股”能链智电为何掉队?
  • 操作系统启动过程详解
  • Coze源码分析-资源库-删除插件-前端源码-核心组件实现
  • 03-生产问题-慢SQL-20250926
  • 机器人控制器开发(导航算法——导航栈关联坐标系)
  • 创客匠人:什么是“好的创始人IP”
  • 2025年本体论:公理与规则的挑战与趋势
  • CentOS系统停服,系统迁移Ubuntu LTS
  • 【CSS,DaisyUI】自定义选取内容的颜色主题
  • Android开发——初步了解AndroidManifest.xml
  • 零基础入门深度学习:从理论到实战,GitHub+开源资源全指南(2025最新版)
  • C++ 条件变量 通知 cv.notify_all() 先释放锁再通知
  • [光学原理与应用-428]:非线性光学 - 为什么要改变光的波长/频率,获得特点波长/频率的光?
  • RocketMQ如何处理消息堆积
  • 云某惠旧案再审可能性与商业创新实践:积分运营的边界与实体商家机遇
  • 【设计模式】 工厂方法模式
  • 【YOLOv11】2.安装Anaconda3