网站首页 > 技术文章 正文
系统环境:
- 群晖 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-09-12 天翼云主机初始化Linux数据盘,解决新装宝塔不显示挂载磁盘。
- 2025-09-12 Linux服务器SSH登录慢?3个实用技巧让连接速度提升10倍!
- 2025-09-12 Linux系统保存文件命令的详细介绍
- 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的安装与使用
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)