使用Nginx加速访问docker hub

发布于:2024-10-09 ⋅ 阅读:(124) ⋅ 点赞:(0)

背景

之前通过nginx加速访问docker hub,在拉取镜像的时候出现 GET /v2/ HTTP/1.1" 401 87 是由于auth.docker.io 也被限制访问了,所以需要对其反代。

配置

最新配置如下:

#反代docker hub镜像源
server {
	 listen 443 ssl;
	 server_name 域名;

	 ssl_certificate 证书地址;
	 ssl_certificate_key 密钥地址;

	 ssl_session_timeout 24h;
	 ssl_ciphers 'ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256';
	 ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3;

	 location /v2/ {
			 proxy_pass https://registry-1.docker.io;  # Docker Hub 的官方镜像仓库
			 proxy_set_header Host registry-1.docker.io;
			 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;

			 # 重写 www-authenticate 头为你的反代地址
			 proxy_hide_header www-authenticate;
			 add_header www-authenticate 'Bearer realm="https://域名/token",service="registry.docker.io"' always;
			 # always 参数确保该头部在返回 401 错误时无论什么情况下都会被添加。

			 # 对 upstream 状态码检查,实现 error_page 错误重定向
			 proxy_intercept_errors on;
			 # error_page 指令默认只检查了第一次后端返回的状态码,开启后可以跟随多次重定向。
			 recursive_error_pages on;
			 # 根据状态码执行对应操作,以下为301、302、307状态码都会触发
			 error_page 301 302 307 = @handle_redirect;

	 }
	 
	 # 处理 Docker OAuth2 Token 认证请求
	 location /token {
		 resolver 1.1.1.1 valid=600s;
		 proxy_pass https://auth.docker.io;  # Docker 认证服务器

		 # 设置请求头,确保转发正确
		 proxy_set_header Host auth.docker.io;
		 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;

		 # 传递 Authorization 头信息,获取 Token
		 proxy_set_header Authorization $http_authorization;
		 proxy_pass_header Authorization;

		 # 禁用缓存
		 proxy_buffering off;
	 }
	 
	 location @handle_redirect {
			 resolver 1.1.1.1;
			 set $saved_redirect_location '$upstream_http_location';
			 proxy_pass $saved_redirect_location;
	 }
}

参考文章


网站公告

今日签到

点亮在社区的每一天
去签到