nginx图片缓存服务器配置实战
1、图片目录设置:
假定服务器主目录为nginx的默认目录:/usr/local/nginx-0.8.32/html/
图片存放目录为:/usr/local/nginx-0.8.32/html/SD/images
图片缓存目录为:/usr/local/nginx-0.8.32/html/SD/images_cache
图片临时目录为:/usr/local/nginx-0.8.32/html/SD/images_temp
SD意义为项目中使用的代称,可以忽略其意义
在nginx缓存配置成功之后,如果用户成功获取了一次图片文件,就会缓存到images_cache目录下
2、nginx服务器配置:
所需软件包如下:
- tar zxvf pcre-8.20.tar.gz cd pcre-8.20/
- ./configure
- make && make install
- cd ../
- tar zxvf ngx_cache_purge-1.0.tar.gz
- tar zxvf nginx-0.8.32.tar.gz
- cd nginx-0.8.32/
- ./configure --user=www --group=www \
- --add-module=../ngx_cache_purge-1.0 \
- --prefix=/usr/local/webserver/nginx \
- --with-http_stub_status_module \
- --with-http_ssl_module \
- --with-openssl=/usr/local/openssl-1.0.1
- make && make install
如果在nginx执行make的过程中出现如下错误:
- make[1]: *** [objs/addon/ngx_cache_purge-1.2/ngx_cache_purge_module.o] Error 1
- make[1]: Leaving directory `/root/nginx-1.0.5'
- make: *** [build] Error 2
则是由于nginx版本的问题。我之前用的是比较新的nginx1.2版本, 结果总是出现上述Error信息,于是更换回旧版本之后Error消失。至于具体原因,暂未深入研究。
3、对nginx进行配置
- #需要建立www用户和www用户组
- user www www;
- worker_processes 8;
- error_log /usr/local/nginx-0.8.32/logs/error.log crit;
- pid /usr/local/nginx-0.8.32/nginx.pid;
- events {
- use epoll;
- worker_connections 65535;
- }
- http {
- include mime.types;
- default_type application/octet-stream;
- charset utf-8;
- server_names_hash_bucket_size 128;
- client_header_buffer_size 32k;
- large_client_header_buffers 4 32k;
- client_max_body_size 300m;
- sendfile on;
- tcp_nopush on;
- keepalive_timeout 60;
- tcp_nodelay on;
- client_body_buffer_size 512k;
- 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;
- gzip on;
- gzip_min_length 1k;
- gzip_buffers 4 16k;
- gzip_http_version 1.1;
- gzip_comp_level 2;
- gzip_types text/plain application/x-javascript text/css application/xml;
- gzip_vary on;
- #注:images_temp和images_cache指定的路径必须在同一分区
- proxy_temp_path /usr/local/nginx-0.8.32/html/SD/images_temp;
- #设置Web缓存区名称为cache_one,内存缓存空间大小为200MB,1天没有被访问的内容自动清除,硬盘缓存空间大小为30GB。
- proxy_cache_path /usr/local/nginx-0.8.32/html/SD/images_cache levels=1:2 keys_zone=cache_one:200m inactive=1d max_size=30g;
- server {
- listen 80;
- server_name 192.168.0.146;
- location / {
- proxy_cache cache_one;
- #对不同的HTTP状态码设置不同的缓存时间
- proxy_cache_valid 200 304 12h;
- #以域名、URI、参数组合成Web缓存的Key值,Nginx根据Key值哈希,存储缓存内容到二级缓存目录内
- proxy_cache_key $host$uri$is_args$args;
- proxy_set_header Host $host;
- proxy_set_header X-Forwarded-For $remote_addr;
- proxy_pass http://192.168.0.146:8080;
- log_format cache '***$time_local ' '***$upstream_cache_status ' '***Cache-Control: $upstream_http_cache_control ' '***Expires: $upstream_http_expires ' '***"$request" ($status) ' '***"$http_user_agent" ';
- access_log /usr/local/nginx-0.8.32/logs/cache.log cache;
- expires 1d;
- }
- #用于清除缓存,假设一个URL为http://192.168.8.42/test.txt,通过访问http://192.168.8.42/purge/test.txt就可以清除该URL的缓存。
- location ~ /purge(/.*) {
- #设置只允许指定的IP或IP段才可以清除URL缓存。
- allow 127.0.0.1;
- allow 192.168.0.0/16;
- deny all;
- proxy_cache_purge cache_one $host$1$is_args$args;
- }
- #扩展名以.php、.jsp、.cgi结尾的动态应用程序不缓存。
- location ~ .*\.(php|jsp|cgi)?$ {
- proxy_set_header Host $host;
- proxy_set_header X-Forwarded-For $remote_addr;
- proxy_pass http://192.168.0.146:8080;
- }
- access_log off;
- }
- server{
- listen 8080;
- server_name 192.168.33.243;
- location / {
- root /usr/local/webapp;
- }
- access_log off;
- }
- }
修改完成之后,可以在nginx/sbin目录下执行./nginx -t命令来检查配置文件是否正确,当现实如下信息时即表示配置成功。
configuration file /usr/local/nginx-0.8.32/conf/nginx.conf test is successful
4、测试及验证
在nginx/sbin目录下执行./nginx即可启动nginx
在浏览器里直接输入ip地址之后显示如下界面即表示成功启动:
在图片存放目录images下面存放了如下图片:
在浏览器里输入请求图片的地址:http://192.168.0.146/webapp/images/03.jpg即可成功显示图片:
此时我们可以看到在images_cache下面生成了缓存文件:
文件存放路径是根据我们前面配置的key的映射方式生成的:proxy_cache_key $host$uri$is_args$args;
经过对存放的多张图片的多次请求之后,我们就会发现因映射key而产生的多个文件夹目录:
另外,我们还可以根据nginx.conf文件中配置的日志来确定我们的请求是否命中缓存:
第一次请求的时候,我们可以看到miss
第二次请求的时候,我们就可以看到hit命中了
****************************************************************************************************************
server {
listen 80;
server_name douco.com;
#access_log logs/host.access.log main;
location / {
index index.php index.html index.htm;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_pass http://192.168.253.137:80;
}
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|js|css)$ {
index index.php index.html index.htm;
proxy_cache cache_one;
proxy_cache_valid 200 304 12h;
proxy_cache_key $host$uri$is_args$args;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_pass http://192.168.253.137:80;
access_log /var/www/logs/cache.log cache;
expires 1d;
}
location ~ /purge(/.*) {
allow 127.0.0.1;
#allow 192.168.253.136;
deny all;
proxy_cache_purge cache_one $host$1$is_args$args;
}
}
nginx图片缓存服务器配置实战的更多相关文章
- 用nginx图片缓存服务器
图片的存储硬件 把图片存储到什么介质上? 如果有足够的资金购买专用的图片服务器硬件或者 NAS 设备,那么简单的很: 如果上述条件不具备,只想在普通的硬盘上存储,首先还是要考虑一下物理硬盘的实际处理能 ...
- 【T电商 3】Nginx的Http(图片)服务器配置+ftp上传使用说明
在前两篇博客中提到了搭建Nginx和Ftp服务器,在本篇博客,主要是介绍Nginx的配置文件的使用,怎样修改配置文件使其成为一个图片服务器. 一.Nginx图片服务器配置 <span style ...
- 【Ts 3】Nginx的Http(图片)服务器配置+ftp上传使用说明
在前两篇博客中提到了搭建Nginx和Ftp服务器,在本篇博客,主要是介绍Nginx的配置文件的使用,怎样修改配置文件使其成为一个图片服务器. 一.Nginx图片服务器配置 <span style ...
- Nginx 1.4.7图片缓存服务器
软件包版本: Nginx 1.4.7 Ngx_cache_purge-2.0 Openssl-1.0.1 Pcre-8.32 二.安装编译: a) 下载pcre-8.32.tar.gz ...
- Nginx图片防盗链【实战】
访问我的博客 前言 博主目前在一家原创小说网站公司工作,由于站内的作品全部是原创,于是乎不可避免地会被一些盗版网站爬取盗版,对于防盗版一直没有很好的对策,让公司很是苦恼. 最近去一些盗版网站上搜索我们 ...
- Nginx+proxy_cache图片缓存
搭建图片缓存机制的原理在于减少数据库的负担并加快静态资源的响应. 步骤: 1. vim /usr/local/nginx/conf/nginx.conf 2. http{ ... .. ...
- nginx实现负载均衡、缓存功能实战
nginx实现负载均衡.缓存功能实战 什么是正向代理?应用场景:翻墙 什么是反向代理?例如:haproxy和nginx Nginx实现反向代理 nginx代理基于是ngx_http_proxy_m ...
- Linux实战教学笔记38:企业级Nginx Web服务优化实战(下)
四,Nginx站点目录及文件URL访问控制 4.1 根据扩展名限制程序和文件访问 Web2.0时代,绝大多数网站都是以用户为中心多的,例如:bbs,blog,sns产品,这几个产品都有一个共同特点,就 ...
- nginx图片处理
前言 不管一个系统或网站的大与小,都存在相应的图片处理,生成缩略图.为图片加水印等等,如果涉及到APP端,这个图片的处理需求变得更加重要了,因为在目前看来,客户端的屏幕大小不一,会导致以下问题: 1. ...
随机推荐
- JSP标签和EL表达式
1.jsp标签: sun原生的,直接jsp使用 <jsp:include> -- 实现页面包含,动态包含 <jsp:include page="/index.jsp&quo ...
- Python图片识别——人工智能篇
一.安装pytesseract和PIL PIL全称:Python Imaging Library,python图像处理库,这个库支持多种文件格式,并提供了强大的图像处理和图形处理能力. 由于PIL仅 ...
- Java常见设计模式之观察者模式
在阎宏博士的<JAVA与模式>一书中开头是这样描述观察者(Observer)模式的: 观察者模式是对象的行为模式,又叫发布-订阅(Publish/Subscribe)模式.模型-视图(Mo ...
- Python模块-logging模块(一)
logging模块用来写日志文件 有5个级别,debug(),info(),warning(),error()和critical(),级别最高的为critical() debug()为调试模式,inf ...
- 可定制的分词库——Yaha(哑哈)分词
可定制的分词库——Yaha(哑哈)分词在线测试地址:http://yaha.v-find.com/ 部署于GAE yahademo.appspot.comYaha分词主要特点是把分词过程分成了4个阶段 ...
- kvm基础 虚拟机内存、CPU调整
转自http://blog.csdn.net/hnhuangyiyang/article/details/50902223 一.调小虚拟机内存 调小虚拟机内存可以动态实现,不用关机1.查看当前内存大小 ...
- 面试题: 数据库 已看1 group by 和order by的练习 sql语句练习简单 有用
1.Sql 约束 http://www.cnblogs.com/henw/archive/2012/08/15/2639510.html 2.修改列类型 MySQL:ALTER TABLE table ...
- 2、Tophat align_summary.txt and samtools flagstat accepted_hits.bam disagree
###https://www.biostars.org/p/195758/ Left reads: Input : 49801387 Mapped : 46258301 (92.9% of input ...
- 3. 从零开始学CSRF
为什么要拿CSRF来当“攻击手法系列”的开头篇呢?因为CSRF/XSRF我个人喜爱他的程度已经超过XSS了.如果说XSS是一个老虎,那么CSRF就是隐藏在暗处的蛇. 相信现在很多人不明 ...
- 【Strtus2】
基于mvc设计模式的web应用框架!strtus2作为控制器来建立模型与视图数据的交互.