首页>软件资讯>常见问题

常见问题

5种方法解决docker无法使用的问题,带着你的NAS终极突围

发布时间:2024-06-13 09:25:37人气:245

docker是NAS生态中必不可少的一个环节,作为一个NAS用户,一旦docker无法使用,那NAS的作用几乎可以失去80%。


近期,因docker被处理的问题,导致越来越多的NAS玩家开始寻找突围的办法。所以Cherry也花了好几天时间,收集并整理网上各种各样的方法,今天,将目前收集到的5种解决方案一一道出,并为每种解决方案提供1个例子供大家参考。


目录


方案一:修改hosts


方案二:公共镜像库


方案三:自建加速(镜像)库


方案四:docker proxy


方案五:离线安装


方案一:修改hosts


本次docker被处理,本质上是处理了cloudflare的连接,使用的是SNI阻拦+DNS污染。而SNI阻拦部分地区因为运营商的关系,省域强度会小一些,基本上修复DNS污染就可以正常访问(注意,是小部分地方,该方法不具有普适性)。


SNI阻拦涉及核心功能,基本上就是域前置、本地反代、http回流、HTTPSv2/v3等方法绕过,视服务商不同有所区别,这个不方便介绍,自行搜索。


而DNS污染就简单很多了,修改Hosts即可,我们可以通过CF优选等工具将docker相应的网站指定DNS解析后,我们就可以恢复下载。


production.cloudflare.docker.com

过SSH连接到NAS,然后在root权限修改NAS的hosts(路径/etc/hosts),最后增加一行【ip 域名】这样的格式,设置完成以后按下ESC退出编辑模式,然后输入【:wq!】保存

ip.png

方案二:公用镜像库


公共镜像库目前可能是唯一比较方便和实用的方法了,虽然主流的公共镜像库都因为ZC原因下架了,但是依旧会有一些小型乃至个人镜像库供大家实用,但是镜像库的缺点很明显,那就是库内的镜像不全,需要和管理者去申请补充。


这里介绍一些github上的镜像库项目,可以查看可用的镜像库,目前主流的基本上是daocluod这个镜像库了。


项目一(镜像):https://github.com/kubesre/docker-registry-mirrors


项目二(镜像):https://github.com/sky22333/Docker-Hub


项目三(代理):https://github.com/wzshiming/crproxy

制作.png

使用方法,也很简单


威联通——【Container Station】——【存储库】——【添加】,填写镜像URL地址。拉取镜像的时候选择设置好的镜像库即可。

图片

群晖——【Container Manager】——【注册表】——【设置】——【新增】,填写镜像URL地址后勾选使用。

图片

方案三:自建加速(镜像)库

刚才提到的公用镜像库之外,还有一种方式就是自建自己使用的个人加速(代理)库,好处就是不需要本地存储镜像,而是通过加速的方式实现镜像下载。


1、基于阿里云申请

这个方法@Stark—C大佬写的很清楚了,这里就不赘述了,直接给大家指路大佬文章。


且用且珍惜~,解决目前众所周知的Docker调皮的问题


2、基于VPS部署

需要海外VPS一台,而且方法多是多样,比如nexus3、harbor、nginx反代等等,这里就不赘述了,今天介绍一款支持一键部署的项目。


项目地址:https://github.com/dqzboy/Docker-Proxy


自建Docker镜像加速服务,基于官方registry一键部署Docker、K8s、Quay、Ghcr镜像加速、管理服务。


# 安装wget和cul,红帽系使用yum,debian系使用apt

apt(yum) -y install wget curl


# 一键安装

bash -c "$(curl -fsSL https://raw.githubusercontent.com/dqzboy/Docker-Proxy/main/install/DockerProxy_Install.sh)"


3、基于CF workers部署


秉持着能白嫖绝对不付钱的想法,我们可以采用cloudflare workers来作为加速源,配合CF优选实现快速链接。


PC端 :


windows下打开PowerShell,输入以下指令安装pnpm


iwr https://get.pnpm.io/install.ps1 -useb | iex


图片



从github下载代码包,解压到桌面即可


图片



Cloudfalre端 :


进入【Workers 和 Pages】,新创建一个workers应用程序


图片


点击【创建Workers】,下一步,随便取名,如docker为前缀


图片


选择【wrangler.toml】并确认


图片


回到【概述】,复制最右侧的“account_id”


图片


PC端 :


将wrangler.toml.sample修改为wrangler.toml,打开并更改文件中的name和account_id,name可以用刚才申请的docker,账号id就是刚才复制的,然后保存。

图片


重新打开PowerShell


# 来到压缩包目录,这个路径根据自己的调整

cd C:\Users\EQ59\Downloads\Compressed\hammal-main


# 安装依赖

pnpm install


# 登录cf

npx wrangler kv:namespace create hammal_cache

会自动转跳到浏览器进行cf认证


图片


复制返回的kv ID


图片


然后继续修改wrangler.toml文件,填入红框内


图片


然后继续在PowerShell里输入pnpm run deploy部署到cf端,完成后可以在CF workers里查看是否部署成功


图片


然后我们点击【设置】,选择【触发器】,选择【自定义域】,填入托管在CF的域名下任意二级域名确认即可。


图片


NAS端 :


以群晖为例,设置默认的【Docker Hub v1】,新增注册表镜像,选择我们刚才设置的自定义域名确认即可。


图片


已经可以正常拉取镜像了,但是速度稍微会慢一点,但是总比没有好,可以通过优选CF,参照方案一在NAS里修改hosts来提速。


图片


CF的流量也可以看得清清楚楚


图片


方案四:docker proxy



该方法使用docker自带的proxy工具,解决部分网友赛老师后依旧无法拉取镜像的问题。


使用ssh工具登录NAS,以此输入以下指令


# 首先请登录root,群晖使用sudo -i,其他NAS默认root

# 创建proxy配置文件

mkdir -p /etc/systemd/system/docker.service.d

touch /etc/systemd/system/docker.service.d/proxy.conf


# 修改proxy配置文件

vim /etc/systemd/system/docker.service.d/proxy.conf


# 将以下代码复制进去,然后根据自己的情况修改,192.168.0.100为NAS IP

[Service] 

Environment="HTTP_PROXY=http://192.168.0.100:7890/" Environment="HTTPS_PROXY=http://192.168.0.100:7891/" Environment="NO_PROXY=localhost,127.0.0.1,.example.com"


# 完成以后按ESC,输入:wq!保存并退出

# 重新读取daemon

systemctl daemon-reload


# 重启docker或重启NAS,比如群晖是无法使用以下指令的,直接重启NAS即可

systemctl restart docker

重启docker以后,在ssh页面输入docker info 查看是否有红框内代码,有的话说明成功了,可以自由拉去镜像了

图片


方案五:离线安装

如果以上方法你都没有办法,那我们还有最后一条路,离线安装docker,该方案让互联网共享精神再次伟大!


正如古希腊掌管光盘的神、21世纪SSD硬盘掌控者、神秘的地铁风衣男、走遍大街小巷的资源售卖大师所说:哪里有需要,哪里就有光盘。


我们可以寻找一些可以获取image资源的小伙伴,让他们通过ssh将资源导出给我们,然后我们再导入到本地使用。如果只是拷贝镜像的,只需要使用docker save 和docker load就可以了


【docker save 与 docker load】,基于已有的镜像导出


# 将名为【XXX/images:tag】的镜像,导出为到路径【/home】下的【image.tar】压缩包

docker save XXX/images:tag  -o /home/image.tar


# 将路径【/home】下名为【image.tar】的压缩包导入

docker load -i /home/image.tar


#### 查看docker 镜像,找到最近导入的镜像

# 该指令自行查找导入镜像

docker images 

# 该指令按导入时间排序

docker images --format "{{.ID}}\t{{.CreatedAt}}" | sort -k 2 -r


#  将导入的镜像ID为【abcd123456789】的镜像,重命名为【XXX/images:tag】

docker tag abcd123456789 XXX/images:tag



【docker export 与 docker import】,基于已有的容器导出


# 将名为【container】的容器,导出为到路径【/home】下的【image.tar】压缩包

docker export container -o /home/image.tar


# 将路径【/home】下名为【image.tar】的压缩包导入,并改名为【XXX/images:tag】

docker import /home/image.tar XXX/images:tag



上一条:docker的介绍和使用:进阶篇

下一条:国内无法访问下载Docker镜像的多种解决方案