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. ...
随机推荐
- 【转】Pro Android学习笔记(十四):用户界面和控制(2):Text类控制
目录(?)[-] TextView 例子1在XML中设置autoLink属性 例子2在代码中设置autoLink属性 EditText AutoCompleteTextView MultiAutoCo ...
- 资料:MVC框架+SQL Server 数据集成引擎
ylbtech-资料:MVC框架+SQL Server 数据集成引擎 1.返回顶部 1. 功能特点: MVC框架耦合性低视图层和业务层分离,这样就允许更改视图层代码而不用重新编译模型和控制器代码,同样 ...
- 1.Apache+Tomcat负载均衡+集群配置
1.本文Apache+Tomcat集群配置 基于最新的Apache和Tomcat,具体是2011年4月20日最新的Tomcat和Apache集群和负载均衡配置. 准备环境 Apache Apache是 ...
- [51nod1094]和为k的连续区间
法一:暴力$O({n^2})$看脸过 #include<bits/stdc++.h> using namespace std; typedef long long ll; ],sum[]; ...
- warning no newline at the end of file
main.c :10:2 warning: no newline at the end of file 修复这个警告,在文件结尾回车一下就行了.可以很少会有人去仔细探究,为什么gcc会给出这么一个警告 ...
- 【PHP】composer 常用命令
- 8.使用hydra对端口进行爆破
如果对开启端口的服务不清楚,请看我之前写的文章:https://www.cnblogs.com/bmjoker/p/8833316.html 2018,网站的防护(sql,xss...)的安全保护也已 ...
- 发现fork容易出错的一个地方
今天在看代码时发现一段有意思的代码 #include<stdio.h> #include<stdlib.h> #include<unistd.h> #include ...
- 《JavaScript语言精粹》第二章-语法 简单笔记
注释 JavaScript提供两种注释: /* */包围的块注释及//开头的行注释. 注释应该被优先用来提高程序的可读性,注释要精确地描述代码,没有用的注释比没有注释更糟糕. /* */块注释对于被注 ...
- 滴水穿石 C#中多线程 委托的使用
什么是多线程?我们在建立以个C#项目时,往往会在Form1上添加控件,然后写代码,初 学者都是在重复这个过程,其实这个过程是单线程的,可以理解为只有“main”主线程,有 的时候往往需要同时测量多个东 ...