nginx搭建jsdelivr镜像站过程详解
最近jsdelivr可谓国内站长圈的头条常客,这不,又双叒叕(yòu shuāng ruò zhuó)打不开了。
如何解决这个问题?最简单的方法当然是使用别人建立的jsd镜像站,但是稳定性和可靠性就只能看镜像站长的心情了吧。自己动手丰衣足食,还是自己搞个镜像吧。
创建 jsdelivr 镜像站
首先,你需要有一台安装了nginx的服务器。推荐使用腾讯云轻量服务器的Matomo镜像,其中集成了最新稳定版nginx、php、mariadb、Matomo等服务端软件。
把下面的nginx配置保存为jsdelivr.conf,然后上传到你的nginx站点配置目录中, 一般为/etc/nginx/include或者/etc/nginx/http.d。
使用上面提到的Matomo镜像,请上传到/usr/local/lighthouse/softwares/nginx/conf/include目录
- 使用宝塔镜像,可以替换下其生成的站点配置
server { listen 80; listen 443 ssl http2; # 请更改为你的证书路径 ssl_certificate certs/default.cer; ssl_certificate_key certs/default.key; # 请更改为你的镜像域名 server_name jsd.rehiy.com; location / { proxy_pass https://cdn.jsdelivr.net; proxy_set_header Host $proxy_host; proxy_set_header Accept-Encoding ''; proxy_ssl_server_name on; proxy_ssl_name $proxy_host; proxy_redirect / /; # Proxy Cache proxy_cache jsdelivr; proxy_cache_lock on; proxy_cache_lock_timeout 15s; proxy_cache_use_stale updating; proxy_cache_background_update on; proxy_cache_key $host$request_uri; proxy_cache_valid 200 301 302 30d; proxy_cache_valid 500 501 502 503 15s; proxy_cache_valid any 5m; # Replace Domain sub_filter_once off; sub_filter_types application/javascript application/json text/xml text/css; sub_filter '$proxy_host' '$host'; } } # 缓存路径请根据需要更改 proxy_cache_path /var/tmp/nginx/jsdelivr levels=1:2 use_temp_path=off keys_zone=jsdelivr:300m inactive=30d max_size=30g;
使用 jsdelivr 镜像站
在你的站点源码中批量替换cdn.jsdelivr.net为jsd.rehiy.com即可使用自己的jsd镜像了。
当然,也可以把下面的代码插入到你的站点nginx配置中,不修改站点源码替换为自己的镜像站。
sub_filter_once off; sub_filter_types application/javascript application/json text/xml text/css; sub_filter 'cdn.jsdelivr.net' 'jsd.rehiy.com';
以上就是nginx搭建jsdelivr镜像站过程详解的详细内容,更多关于nginx搭建jsdelivr镜像站的资料请关注本站其它相关文章!
版权声明:本站文章来源标注为YINGSOO的内容版权均为本站所有,欢迎引用、转载,请保持原文完整并注明来源及原文链接。禁止复制或仿造本网站,禁止在非www.yingsoo.com所属的服务器上建立镜像,否则将依法追究法律责任。本站部分内容来源于网友推荐、互联网收集整理而来,仅供学习参考,不代表本站立场,如有内容涉嫌侵权,请联系alex-e#qq.com处理。