去评论
dz插件网

1panel超简单nginx反代各种docker registry

xiao9469
2024/06/13 12:46:36
完整见 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 新建站点 使用反代功能, 新建后删除反代.

然后编辑 站点配置, 添加 下面代码
  1. ... 原代码...        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;    }