打造高性能nginx缓存服务器

简介:

一、nginx缓存

    Nginx从0.7.48版本开始,支持了类似Squid的缓存功能。这个缓存是把URL及相关组合当作Key,用md5编码哈希后保存在硬盘上,所以它可以支持任意URL链接,同时也支持404/301/302这样的非200状态码。虽然目前官方的Nginx Web缓存服务只能为指定URL或状态码设置过期时间,不支持类似Squid的PURGE指令,手动清除指定缓存页面,但是,通过一个第三方的Nginx模块,可以清除指定URL的缓存。 

 

二、如何实现nginx缓存

 

1)实验图

 

153721361.png

2)安装包

nginx-1.5.0.tar.gz

wget http://nginx.org/download/nginx-1.5.0.tar.gz

ngx_cache_purge-2.1.tar.gz

wget http://labs.frickle.com/files/ngx_cache_purge-2.1.tar.gz

 

3)安装前准备:

在nginx服务器根目录下创建cache目录,用于挂在缓存盘或存放缓存数据,名字可以随便命名,我这里用的是将4块磁盘做raid5,挂在到/cache上面。

 

4)安装:

1 useradd-r www -s /sbin/nologin

2 tar-zvxf ngx_cache_purge-2.1.tar.gz 

3 tar-zvxf nginx-1.5.0.tar.gz

4 cdnginx-1.5.0

5 yum-y install pcre-* openssl-*

6 ./configure \

--prefix=/usr/local/nginx \

--user=www \

--group=www \

--with-http_stub_status_module \

--with-http_ssl_module \

--add-module=/usr/src/ngx_cache_purge-2.1

7 make

8 make install

/usr/local/nginx/sbin/nginx ##start nginx service

 

5)测试nginx:

   firefox http://localhost &

 

154705464.png

看到此测试页面说明你的nginx安装成功。

 

 

6) 配置nginx-cache

vim /usr/local/nginx/conf/nginx.conf

#usernobody;

worker_processes1;

events {

use epoll;

worker_connections 65535;

}

http {

includemime.types;

default_type application/octet-stream; 

sendfile on;

keepalive_timeout 65;

upstream web {

server 192.168.1.201;

server 192.168.1.202;

}

proxy_temp_path/cache/proxy_temp_dir; 

proxy_cache_path /cache/proxy_dir levels=1:2 keys_zone=cache0:200minactive=1d max_size=30g;

server {

listen80;

server_namelocalhost;

location / {

proxy_pass http://web;

proxy_next_upstream http_502 http_504 error timeout invalid_header;

proxy_cache cache0;

proxy_cache_valid 200 304 30m;

proxy_cache_valid any 1m;

proxy_cache_key $host$uri$is_args$args;

proxy_set_header Host$host;

proxy_set_header X-Forwarded-For $remote_addr;

expires 60m;

}

location ~/purge(/.*)

{

allow 127.0.0.1;

allow 192.168.1.0/24;

proxy_cache_purge cache0$host$1$is_args$args;

}

location ~*/.(php|jsp|cgi)?$

{

proxy_set_header Host $host;

proxy_set_header X-Forwarded-For $remote_addr;

proxy_pass http://web;

}

error_page500 502 503 504/50x.html;

location = /50x.html{

roothtml;

      }

    }

}

 

7)配置文件关键语句解释

proxy_temp_path/data0/proxy_temp_dir; 

##临时缓存目录

proxy_cache_path /data0/proxy_dir levels=1:2 keys_zone=cache0:200minactive=1d max_size=30g;

##定义缓存目录路径/data0/proxy_dir

##硬盘缓存中目录分为两级,第一级文件夹名字是1个字母,第二级文件夹名字是两个字母levels=1:2

##定义缓存区域名字(新建内存缓存区域为200M)keys_zone=cache0:200m

##缓存内容1天后自动到期清除inactive=1d

##在缓存硬盘上划分30G空间max_size=30g

##超过2M不缓存max_size=2m

## clean_time指定一分钟清理一次缓存clean_time=1m

proxy_next_upstream http_502 http_504 errortimeout invalid_header;

##如果后端的服务器返回502、504、执行超时等错误,自动将请求转发到upstream负载均衡池中的另一台服务器,实现故障转移。

proxy_cachecache0;

##启用上述创建的缓存区域cache0

proxy_cache_valid 200 304 30m;

##对返回状态200 304 缓存30分钟

proxy_cache_validany 1m;

##对其他状态码缓存10分钟

proxy_cache_key $host$uri$is_args$args;

##以域名、URI、参数组合成Web缓存的Key值,Nginx根据Key值哈希,存储缓存内容到二级缓存目录内。指令指定了包含在缓存中的缓存关键字。

proxy_set_header Host $host;

##修改客户GET请求头中的 HOST字段。在取源的时候保持客户端的请求字段没变。

proxy_set_header X-Forwarded-For $remote_addr;

##修改远端地址,保持在缓存服务器取源的时候,让源访问日志中能记录到是那个真正远端客户地址,否则默认都是认为是缓存服务器地址,这样源永远不知道到底是谁在访问它。

expires 60m;

##在服务器http响应头中加入过期时间为60分钟,启用客户端本地缓存。时间为60分。

location ~/purge(/.*)

{

allow 127.0.0.1;

allow 192.168.1.0/24;

proxy_cache_purge cache0$host$1$is_args$args;

}

#使用purge工具清除缓存URL

例如需要清除的URL为:

http://192.168.1.200/test.html

在浏览器中访问

http://192.168.1.200/purge/test.html就可以清除该URL的缓存。

通过访问控制定义允许那些机器可以使用purge清空URL,不是谁都能随便清空的。

location ~*/.(php|jsp|cgi)?$

{

proxy_set_header Host $host;

proxy_set_header X-Forwarded-For $remote_addr;

proxy_pass http://web;

}

不缓存动态页面

error_page500 502 503 504/50x.html;

location = /50x.html{

roothtml;

}

错误代码由本机提供页面


本文转自 msj0905 51CTO博客,原文链接:http://blog.51cto.com/sky66/1656300


相关文章
|
2月前
|
缓存 算法 Java
Caffeine Cache~高性能 Java 本地缓存之王
Caffeine Cache~高性能 Java 本地缓存之王
75 1
|
2月前
|
存储 缓存 Java
Openresty(lua+nginx)-Guava-Redis做多级缓存
Openresty(lua+nginx)-Guava-Redis做多级缓存
24 1
|
2月前
|
前端开发 应用服务中间件 nginx
使用Docker快速搭建Web服务器Nginx
本文指导如何使用Docker快速搭建Nginx服务器。首先,通过`docker pull`命令获取Nginx镜像,然后以容器形式运行Nginx并映射端口。通过挂载目录实现本地文件与容器共享,便于自定义网页。使用`docker ps`检查运行状态,访问IP:8088确认部署成功。最后,介绍了停止、删除Nginx容器的命令,强调Docker简化了服务器部署和管理。
57 0
|
8天前
|
缓存 负载均衡 应用服务中间件
Nginx缓存及HTTPS配置小记(上)
Nginx缓存及HTTPS配置小记
22 0
|
19天前
|
应用服务中间件 Linux 开发工具
如何在阿里云服务器快速搭建部署Nginx环境
以下是内容的摘要: 本文档主要介绍了在阿里云上购买和配置服务器的步骤,包括注册阿里云账号、实名认证、选择和购买云服务器、配置安全组、使用Xshell和Xftp进行远程连接和文件传输,以及安装和配置Nginx服务器的过程。在完成这些步骤后,你将能够在服务器上部署和运行自己的网站或应用。
|
24天前
|
弹性计算 应用服务中间件 Linux
阿里云ECS服务器上从零开始搭建nginx服务器
阿里云ECS服务器上从零开始搭建nginx服务器
|
1月前
|
存储 缓存 NoSQL
Redis 服务器指南:高性能内存数据库的完整使用指南
Redis 服务器指南:高性能内存数据库的完整使用指南
|
1月前
|
网络协议 应用服务中间件 Apache
Nginx直播服务器搭建及推拉流测试
Nginx直播服务器搭建及推拉流测试
52 2
|
1月前
|
负载均衡 架构师 应用服务中间件
FastDFS+Nginx搭建一个本地文件服务器
FastDFS+Nginx搭建一个本地文件服务器
35 0
|
2月前
|
负载均衡 应用服务中间件 Linux
深入浅出学习透析Nginx服务器的架构分析及原理分析「底层技术原理+运作架构机制」
深入浅出学习透析Nginx服务器的架构分析及原理分析「底层技术原理+运作架构机制」
37 0