利用Nginx的proxy_cache搭建缓存服务器一:编译ngx_cache_purge
一、Nginx的Proxy_cache是根据Key值md5哈希存储缓存,支持任意的Key,例如你能够根据”域名、URI、参数”组合成key,也支持非200状态码,如404/302等。
二、要利用Nginx的Proxy_cache,你须要在Nginx编译进ngx_cache_purge 模块,执行:nginx -V,查看有没有ngx_cache_purge 字样,没有的话须要本身手动编译。
Nginx搭建CDN手动编译css
三、这里以Oneinstack编译ngx_cache_purge 模块做为操做演示,若是你用的是其它的LNMP包能够参考,基本过程是差很少的。命令以下:html
cd /root/oneinstack/src #进入安装包目录 nginx -V tar xzf nginx-1.10.3.tar.gz #根据上面查看到的nginx版本选择解压包 wget http://labs.frickle.com/files/ngx_cache_purge-2.3.tar.gz tar zxvf ngx_cache_purge-2.3.tar.gz cd /root/oneinstack/src/nginx-1.10.3 # 下面的./configure 后加的参数,你能够直接复制刚刚用nginx -V获得的参数,而后在最后加上–add-module=../ngx_cache_purge-2.3便可,参考: ./configure –prefix=/usr/local/nginx –user=www –group=www –with-http_stub_status_module –with-http_v2_module –with-http_ssl_module –with-http_gzip_static_module –with-http_realip_module –with-http_flv_module –with-http_mp4_module –with-openssl=../openssl-1.0.2k –with-pcre=../pcre-8.39 –with-pcre-jit –with-ld-opt=-ljemalloc –add-module=../ngx_cache_purge-2.3 make mv /usr/local/nginx/sbin/nginx{,$(date +%m%d)} cp objs/nginx /usr/local/nginx/sbin #oneinstack,其它的能够不用这个操做 nginx -t service nginx restart
四、安装完成后,再次nginx -V你就能够看到Nginx已经成功编译进了ngx_cache_purge 了。nginx
2、利用Nginx的proxy_cache搭建缓存服务器二:修改Nginx配置文件
一、先找到你的Nginx配置文件:nginx.conf(路径通常是在/usr/local/nginx/conf/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/pic.freehao123.com levels=1:2 keys_zone=cache_one:200m inactive=30d max_size=5g; proxy_temp_path /data/wwwroot/pic.freehao123.com/temp;
二、操做以下图:服务器
三、而后在你的虚拟主机的nginx.conf(路径通常是/usr/local/nginx/conf/vhost/pic.freehao123.com.conf),在server listen 80 和 listen 443 ssl http2 都加入下面命令:负载均衡
location /{ proxy_pass https://www.freehao123.com; proxy_redirect off; proxy_set_header Host www.freehao123.com; 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; }
四、将配置文件保存从新上传,而后执行:ide
nginx -t
service nginx restart
五、先执行检查Nginx配置是否正确,确认没有问题的就是重启Nginx了。tornado
六、若是你想缓存gravatar头像,那么代码就是:网站
location /avatar{ proxy_pass http://cn.gravatar.com; proxy_redirect off; proxy_set_header Host cn.gravatar.com; 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; }
七、如今打开你的二级域名:pic.freehao123.com,你就能够看到已经正确缓存了图片了。搜索引擎
八、这里再给出另外一个Nginx缓存代码,实现效果和上面是同样的。
#先在Nginx配置中写入如下命令: proxy_temp_file_write_size 128k; proxy_temp_path /data/wwwroot/pic.ucblog.net/temp; proxy_cache_path /data/wwwroot/pic.ucblog.net levels=1:2 keys_zone=cache_one:500m inactive=7d max_size=5g; #再在虚拟主机的Nginx配置中写入如下命令: 先在server listen 80 和listen 443代码前面加入: upstream gravatar { server secure.gravatar.com:443; } #再在server listen 80 和listen 443 里面加入: location / { proxy_pass_header Server; proxy_set_header Host cn.gravatar.com; proxy_set_header Accept-Encoding ”; proxy_redirect off; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Scheme $scheme; proxy_pass https://gravatar; proxy_cache cache_one; proxy_cache_valid 200 304 365d; proxy_cache_key $host$uri$is_args$args; expires max; }
九、在VPS主机上,你能够看到proxy_cache生成的哈希文件,就表示缓存已经成功了。
3、利用Nginx的proxy_store搭建镜像服务器:修改Nginx配置方法
一、Nginx的proxy_store做用是直接把静态文件在本地硬盘建立并读取,相似于七牛或者又拍这样的镜像CDN功能,首次访问会自动获取源站的静态图片等文件,以后的访问就是直接从CDN服务器读取,加快了速度。
二、直接修改Nginx的虚拟主机配置文件(这里以img.freehao123.com.conf为演示),加入如下代码:
location / { expires 3d; proxy_set_header Accept-Encoding ”; root /data/wwwroot/img.freehao123.com; proxy_store on; proxy_store_access user:rw group:rw all:rw; proxy_temp_path /data/wwwroot/img.freehao123.com/temp; if ( !-e $request_filename) { proxy_pass https://www.freehao123.com; } }
三、再次保存配置上传,而后重启Nginx。你能够看到img.freehao123.com请求的图片等静态文件已经成功从源站中得到到了。
四、在VPS主机上的存目录中也能够看到proxy_store已经完整地将图片等静态文件的目录都保存下来了,至关于一个网站的镜像存储CDN了。
五、这里还有一个使用,效果和上面是同样的,记得替换好路径,代码以下:
upstream http_tornado { server www.freehao123.com:443; } server { # 省略其余配置 location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|js|html|htm|css)$ { root /opt/data/product/blog/cache; proxy_store on; proxy_store_access user:rw group:rw all:rw; proxy_temp_path /opt/data/product/blog/cache; if ( !-e $request_filename) { proxy_pass http://http_tornado; } } }
4、Nginx的proxy_store和proxy_cache有什么区别?
一、镜像与缓存的区别。从上面的介绍咱们也能够看出来,proxy_store至关于镜像一个网站了,第二次访问图片等静态文件是直接读取CDN服务器上的,大大减轻了源站的负担。proxy_cache至关于缓存,即把请求生成Key,第二次访问就能够加快速度了。
二、proxy_store适合静态,proxy_cache适合动态。proxy_store是将图片完整保存在CDN服务器上,因此它更适合于图片CDN加速,而proxy_cache是缓存生成Key,更加适合动态网站加速,可用于负载均衡,减轻服务器负担。
5、搭建镜像CDN服务器后要作的事情?
一、第一,由于搭建镜像CDN服务器是完整地复制了源站的文件和URL,因此为了不被搜索引擎误认为抄袭重复站,咱们能够给CDN站加上Robots.txt,阻止搜索引擎收录。命令以下(容许收录图片,其它不容许爬取):
User-agent: Baiduspider Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: 360Spider Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: Baiduspider-image Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: 360Spider-Image Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: Sosospider Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: sogou spider Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: YodaoBot Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: Googlebot Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: Bingbot Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: Slurp Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: MSNBot Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: googlebot-image Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: googlebot-mobile Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: yahoo-blogs/v3.9 Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: psbot Allow: /wp-content/uploads/*.jpg$ Allow: /wp-content/uploads/*.png$ Allow: /wp-content/uploads/*.gif$ Disallow: / User-agent: * Disallow: /
二、第二,作好Nginx防盗链。若是你的CDN服务器流量不怎么够的话,建议仍是作好防盗链措施,同时还能够帮你减轻服务器负担。在你的虚拟主机配置文件中加入如下代码:
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ { valid_referers none blocked freehao123.com *.freehao123.com *.google.cn *.google.com *.google.com.hk image.baidu.com *.baidu.com; if ($invalid_referer) { rewrite ^/ https://www.freehao123.com; #return 403; } }
三、第三,设置好Nginx默认图片。这个主要是针对缓存Gravatar头像的,当源站服务器不存在某一个图片或者文件时,咱们能够给Nginx设置一个默认的图片或者连接,这样缓存看起来就完美了。
location /avatar { try_files $uri /avatar/set-avatar.png; } #或者使用: location /{ try_files $uri /set-avatar.png; }
四、效果见下图:
文章出自:freehao123.com