完整见 https://t.me/mjjgarden/8
参考了 https://blog.lty520.faith/博文/自建docker-hub加速镜像/ 的代码
支持
registry-1.docker.io
gcr.io
ghcr.io
registry.gitlab.com
nvcr.io
quay.io
代码已经简化了, 直接注释代码 就能反代 目标 regisry了.
先1panel 新建站点 使用反代功能, 新建后删除反代.
然后编辑 站点配置, 添加 下面代码
[ol]... 原代码...
location / {
resolver 1.1.1.1;
# 这个docker hub 官方registry,大部份人用这个就够了,
set $target_host registry-1.docker.io;
# 根据情况自己选择使用, 一个站点(host)只能用一个 目标registry, 需要多个反代多个目标就建立多个不同站点.
# set $target_host ghcr.io; # github 使用的人也不少.
# set $target_host gcr.io; # Google
# set $target_host nvcr.io; # nvdia
# set $target_host registry.gitlab.com; # gitlab
# set $target_host quay.io; # quay
proxy_pass https://$backend_host;
proxy_set_header Host $backend_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# 关闭缓存
proxy_buffering off;
# 转发认证相关的头部
proxy_set_header Authorization $http_authorization;
proxy_pass_header Authorization;
# 对 upstream 状态码检查,实现 error_page 错误重定向
proxy_intercept_errors on;
# error_page 指令默认只检查了第一次后端返回的状态码,开启后可以跟随多次重定向。
recursive_error_pages on;
# 根据状态码执行对应操作,以下为301、302、307状态码都会触发
#error_page 301 302 307 = @handle_redirect;
error_page 429 = @handle_too_many_requests;
}
#处理重定向
location @handle_redirect {
resolver 1.1.1.1;
set $saved_redirect_location '$upstream_http_location';
proxy_pass $saved_redirect_location;
}
# 处理429错误, 如registry-1.docker.io 短时间请求太多会触发, 此时可以cf work方案接力, 或者 使用 warp
location @handle_too_many_requests {
#proxy_set_header Host cfcr.j8.work; # 对应 Worker设置的域名
#proxy_pass http://cfcr.j8.work; # 对应 Worker设置的域名
#proxy_set_header Host $http_host;
}[/ol]复制代码