打造高性能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
Java本地高性能缓存实践
本篇博文将首先介绍常见的本地缓存技术,对本地缓存有个大概的了解;其次介绍本地缓存中号称性能最好的Cache,可以探讨看看到底有多好?怎么做到这么好?最后通过几个实战样例,在日常工作中应用高性能的本地缓存。
|
2天前
|
应用服务中间件 nginx
解密Nginx的高性能魔法:事件驱动与异步非阻塞模型
总之,Nginx的高性能魔法基于事件驱动和异步非阻塞模型,使其能够处理大量并发连接,同时保持低系统资源消耗。这是Nginx在处理Web请求时出色性能的关键因素。
14 1
|
3天前
|
缓存 负载均衡 安全
深入探索Nginx高性能Web服务器配置与优化
【5月更文挑战第7天】本文深入探讨了Nginx的配置与优化,重点介绍了基础配置参数如`worker_processes`、`worker_connections`和`keepalive_timeout`,以及优化策略,包括使用epoll事件驱动模型、开启gzip压缩、启用缓存、负载均衡和安全配置。此外,还提到了性能调优工具,如ab、nginx-stats和nmon,以助于提升Nginx的性能和稳定性。
|
10天前
|
负载均衡 网络协议 应用服务中间件
【亮剑】在Linux中构建高可用性和高性能网络服务的负载均衡工具HAProxy、Nginx和Keepalived。
【4月更文挑战第30天】本文介绍了在Linux中构建高可用性和高性能网络服务的负载均衡工具HAProxy、Nginx和Keepalived。HAProxy是一个高性能的开源TCP和HTTP负载均衡器,适合处理大量并发连接;Nginx是一个多功能Web服务器和反向代理,支持HTTP、HTTPS和TCP负载均衡,同时提供缓存和SSL功能;Keepalived用于监控和故障切换,通过VRRP实现IP热备份,保证服务连续性。文中详细阐述了如何配置这三个工具实现负载均衡,包括安装、配置文件修改和启动服务,为构建可靠的负载均衡系统提供了指导。
|
16天前
|
负载均衡 监控 Unix
[AIGC] Nginx:一个高性能的 Web 服务器和反向代理
[AIGC] Nginx:一个高性能的 Web 服务器和反向代理
|
23天前
|
应用服务中间件 Linux 开发工具
如何在阿里云服务器快速搭建部署Nginx环境
以下是内容的摘要: 本文档主要介绍了在阿里云上购买和配置服务器的步骤,包括注册阿里云账号、实名认证、选择和购买云服务器、配置安全组、使用Xshell和Xftp进行远程连接和文件传输,以及安装和配置Nginx服务器的过程。在完成这些步骤后,你将能够在服务器上部署和运行自己的网站或应用。
|
28天前
|
弹性计算 应用服务中间件 Linux
阿里云ECS服务器上从零开始搭建nginx服务器
阿里云ECS服务器上从零开始搭建nginx服务器
|
1月前
|
存储 缓存 NoSQL
Redis 服务器指南:高性能内存数据库的完整使用指南
Redis 服务器指南:高性能内存数据库的完整使用指南
|
1月前
|
网络协议 应用服务中间件 Apache
Nginx直播服务器搭建及推拉流测试
Nginx直播服务器搭建及推拉流测试
55 2
|
1月前
|
负载均衡 架构师 应用服务中间件
FastDFS+Nginx搭建一个本地文件服务器
FastDFS+Nginx搭建一个本地文件服务器
38 0