网站首页 > 技术文章 正文
系统环境:
- 群晖 DSM 7.2.2-72806 Update 3
- Container Manager 版本:24.0.2-1535
- 使用 macOS 上的 小火箭(Shadowrocket) 提供局域网 HTTP 代理
- 群晖机器作为客户端代理上网
一、问题现象
- Container Manager 可登录镜像仓库(如 Docker Hub)
- 浏览器也可访问 docker.io 网站
- 无法拉取镜像,提示 timeout、context deadline exceeded、权限 denied 等错误
二、问题原因总结
- 群晖默认 Docker 不使用系统代理
- 守护进程未读取代理设置
- SSH 用户没有 Docker 权限
- 群晖不支持用 systemd 或 synoservice 重启 Docker,需要重启整个系统
三、解决步骤(推荐流程)
第 1 步:确认代理服务开启并允许 LAN 访问
在 Mac 上的小火箭(Shadowrocket)中设置:
- 开启 HTTP 代理
- 勾选 「Allow LAN Access(允许局域网设备使用代理)」
- 查看 Mac 的本地 IP 地址,例如:192.168.0.42
- 默认端口一般为 1080(Socks)或 1082(HTTP)
第 2 步:SSH 登录群晖并配置 Docker 代理
- 登录 SSH:
ssh admin@群晖IP地址
- 创建配置目录:
sudo mkdir -p /etc/docker
- 编辑代理配置文件:
sudo vi /etc/docker/daemon.json
填入如下内容(根据你的代理 IP 和端口调整):
{
"proxies": {
"default": {
"httpProxy": "http://192.168.0.42:1082",
"httpsProxy": "http://192.168.0.42:1082",
"noProxy": "127.0.0.1,localhost"
}
}
}
- 保存并退出 vi(按下 Esc,输入 :wq,回车)
第 3 步:将当前用户加入 Docker 用户组(避免权限 denied)
sudo synogroup --add docker 你的用户名
建议重启或重新 SSH 登录以使权限变更生效。
第 4 步:重启 DSM 系统以使 Docker 加载代理配置
DSM 不支持直接重启 Docker 守护进程,推荐整机重启:
sudo reboot
或在 DSM 控制面板中手动重启系统。
第 5 步:重启后验证代理是否生效
登录 SSH,运行:
sudo docker info | grep -i proxy
正常输出应类似:
HTTP Proxy: http://192.168.0.42:1082
HTTPS Proxy: http://192.168.0.42:1082
第 6 步:测试拉取镜像
sudo docker pull busybox
若成功拉取,说明配置完全生效 。
附加测试命令(排查代理是否通)
如镜像拉取失败,可运行以下命令:
curl -x http://192.168.0.42:1082 https://www.google.com -v
若能获取页面内容或 HTTP/200 状态,说明代理本身正常。
文件结构检查(最终验证)
最终你的配置文件应是:
/etc/docker/daemon.json
{
"proxies": {
"default": {
"httpProxy": "http://192.168.0.42:1082",
"httpsProxy": "http://192.168.0.42:1082",
"noProxy": "127.0.0.1,localhost"
}
}
}
以上
猜你喜欢
- 2025-07-06 这个办法能够让家里的旧手机安装docker并成功运行!免root安装!
- 2025-07-06 2022年即将生效的防止空气污染规定,请查收
- 2025-07-06 纯干货 | 四六级核心词500词第七组50词
- 2025-07-06 Centos7修改网卡固定IP地址(centos7修改网卡配置文件)
- 2025-07-06 # linux 中使用 visudo 命令,怎么保存退出?
- 2025-07-06 驰为Vi8 双12全球首发(驰为vi8 hi8)
- 2025-07-06 Hadoop集群搭建及Hive的安装与使用
- 2025-07-06 学习数据结构--第五章:图(图的存储方法)
- 2025-07-06 成功安装 Magento2.4.3最新版教程「技术干货」
- 2025-07-06 虚拟机中的Linux怎么配置上网(虚拟机linux系统怎么联网)
- 1509℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 526℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 492℃MySQL service启动脚本浅析(r12笔记第59天)
- 472℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 469℃启用MySQL查询缓存(mysql8.0查询缓存)
- 449℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 429℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 426℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)