当前位置: 代码网 > 服务器>服务器>Nginx > 利用Nginx反向代理功能自建CDN加速页面服务

利用Nginx反向代理功能自建CDN加速页面服务

2024年05月14日 Nginx 我要评论
一般我们选用cdn加速服务会用到第三方cdn服务,也有利用服务器自建cdn软件工具。当然,我们还可以用到nginx web反代的方式实现缓存加速页面,实现cdn加速的方式。具体的操作如下。第一、部署前

一般我们选用cdn加速服务会用到第三方cdn服务,也有利用服务器自建cdn软件工具。当然,我们还可以用到nginx web反代的方式实现缓存加速页面,实现cdn加速的方式。具体的操作如下。

第一、部署前的准备

这里,我们需要准备2台或者以上的服务器。而且可以分布不同的地区。比如a和b,a在美国,使用wordpress,ip地址:1.2.3.4,域名绑定:www.jb51.net。b在日本,空白网站,ip地址:2.3.4.5,域名绑定:static.jb51.net。

网站主站架设在a服务器上(即所有网站内容,包含动态文件、数据库等),我们将在b站上架设cdn服务。

第二、程序安装

由于a站上已经将服务环境架设好,网站也已经正常运行,同时也无需在a站上进行多余操作,故此,所有操作未进行说明均表示b站进行。

首先,自建cdn这里选择的是ngx_cache_purge这一模块,要运行这个模块,就需要服务器上安装有nginx,若之前安装过的,重新安装一次,加上参数即可。

下载相关软件:

wget http://nginx.org/download/nginx-1.10.3.tar.gz
wget http://labs.frickle.com/files/ngx_cache_purge-2.3.tar.gz
tar zxf nginx-1.10.3
tar zxf ngx_cache_purge-2.3.tar.gz

安装nginx:

cd nginx-1.10.3
./configure –prefix=/usr/local/nginx –user=www –group=www –add-module=../ngx_cache_purge-2.3

因为各人需求不同,所以这里只是写了ngx_cache_purge模块,若有其他需求请自行参考nginx编译参数

make && make install

验证ngx_cache_purge安装:

/usr/local/nginx/sbin/nginx -v

若出现了“–add-module=../ngx_cache_purge-2.3”字样表示已经安装完成

nginx配置:

打开nginx.conf文件,在http区域中添加如下内容

proxy_connect_timeout 5;
proxy_read_timeout 60;
proxy_send_timeout 5;
proxy_buffer_size 16k;
proxy_buffers 4 64k;
proxy_busy_buffers_size 128k;
proxy_temp_file_write_size 128k;
proxy_cache_path /data/wwwroot/static.jb51.net levels=1:2 keys_zone=cache_one:200m inactive=30d max_size=5g;
proxy_temp_path /data/wwwroot/static.jb51.net/tmp;

注意上面的“/data/wwwroot/static.jb51.net”,这是b站的网站路径

打开网站配置文件,在添加或修改如下内容,将静态文件进行缓存

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|flv|mp4|ico|js|css)$ {
proxy_pass https://www.jb51.net;
proxy_redirect off;
proxy_set_header host www.jb51.net;
proxy_cache cache_one;
proxy_cache_valid 200 302 304 365d;
proxy_cache_valid 301 1d;
proxy_cache_valid any 1m;
add_header images-cache “$upstream_cache_status from $host”;
add_header pragma public;
add_header cache-control “public, must-revalidate, proxy-revalidate”;
access_log off;
log_not_found off;
expires max;
}

最后重新载入下nginx,当以后访问static.jb51.net时,b站会先检查本地是否有缓存,若缓存存在则直接展示,若不存在则会访问www.jb51.net,将资源保存下来进行展示。

第三、网站程序配置

现在cdn架设好了,但是要怎样使用到网站上呢?

主站所有静态资源域名必须是static.jb51.net

static.jb51.net域名必须正确指向b站

wordpress替换法

如果网站使用的是wordpress程序,那可以很方便的对资源进行操作,其实也无需操作,就是把静态资源域名进行更改即可,反正cdn会自动拉取资源到本地!

打开本站模板函数文件“function.php”,在其中添加如下代码

if ( !is_admin() ) {
add_action(‘wp_loaded','lovekk_ob_start');
function lovekk_ob_start() {
ob_start(‘lovekk_cdn_replace');
}
function lovekk_cdn_replace($html) {
return str_replace(‘https://www.jb51.net/wp-content/uploads/', ‘http://static.jb51.net/wp-content/uploads/', $html);
}
}

若本站安装有缓存插件,将缓存先清空一次,然后尝试打开网站,若uploads目录下所有静态资源均指向static.jb51.net域名,且访问正常,说明已经安装正常。

以上就是利用nginx反向代理功能自建cdn加速页面服务的详细内容,更多关于利用nginx反向代理功能自建cdn加速页面服务的资料请关注代码网其它相关文章!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com