Nginx缓存服务

简介: Nginx缓存服务

一、缓存概述


(1)缓存的作用


  • 通常情况下缓存是用来减少后端压力的,将压力尽可能的往前推,也就是往代理服务器上推,减少后端压力,提高网站并发延迟


(2)缓存常见的类型


  • 后端服务器缓存


20210526101756757.png


  • 代理缓存

20210526101807295.png


  • 客户端缓存


20210526101817618.png

最常用的就是代理缓存,所以这里主要说代理缓存


(3)Nginx缓存的原理


20210526101827857.png


二、配置Nginx缓存


(1)主配置文件中缓存的语法


proxy_cache


  • 配置缓存路径


语法: proxy_cache zone\off;

默认是off也就是关闭,zone就是指定区域名称

可以配置的区域: http、server、location


  • 配置缓存周期


语法: proxy_cache_valid [code …] time;

可以配置的区域: http、server、location

示例: proxy_cache_valid 200 302 10m; 这个表示,出现了200、302状态码的页面的话,页面就缓存10分钟


  • 缓存的维度


语法: proxy_cache_key string;


默认: proxy_cache_key s c h e m e schemeschemeproxy_host$request_uri;


可配置的区域: http、server、location


示例: proxy_cache_key s c h e m e schemeschemeproxy_hostu r i uriuriis_args$args;


$scheme: 请求方案,http或https。


$proxy_host: 默认80端口不显示,其它显示


$uri: 对路径的资源


$is_args: 如果URL包含参数则为?,否则为空字符串


$args: 请求URL中包含的参数。


$request_uri: 完整的原始请求的URI(带有参数)


(2)配置Nginx缓存


-实验环境


系统 主机名 ip地址 Nginx版本 扮演角色
Centos7.4 proxy 192.168.100.202 Nginx-1.18.0 代理服务器
Centos7.4 web 192.168.100.203 Nginx-1.18.0 后端web


-实验目的


客户端通过代理缓存,加快访问web服务器的速度


-实验步骤


proxy的配置:


******(1)先做基础配置
[root@Centos7 ~]# hostnamectl set-hostname proxy
[root@Centos7 ~]# su
[root@proxy ~]# systemctl stop firewalld
[root@proxy ~]# setenforce 0
setenforce: SELinux is disabled
[root@proxy ~]# mount /dev/cdrom /mnt/
mount: /dev/sr0 写保护,将以只读方式挂载
mount: /dev/sr0 已经挂载或 /mnt 忙
       /dev/sr0 已经挂载到 /mnt 上
******(2)上传Nginx源码包进行安装
[root@proxy ~]# yum -y install zlib-devel pcre-devel  #安装依赖包
。。。。。。
完毕!
[root@proxy ~]# ll
总用量 1020
-rw-------. 1 root root    1264 1月  12 18:27 anaconda-ks.cfg
-rw-r--r--  1 root root 1039530 4月  19 10:03 nginx-1.18.0.tar.gz
[root@proxy ~]# tar xf nginx-1.18.0.tar.gz  -C /usr/src/
[root@proxy ~]# cd /usr/src/nginx-1.18.0/
[root@proxy nginx-1.18.0]# useradd -M -s /sbin/nologin  nginx
[root@proxy nginx-1.18.0]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module && make && make install 
[root@proxy nginx-1.18.0]# ln -s /usr/local/nginx/sbin/nginx  /usr/local/sbin/
[root@proxy nginx-1.18.0]# vim /lib/systemd/system/nginx.service
[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s stop
PrivateTmp=true
[Install]
WantedBy=multi-user.target
[root@proxy nginx-1.18.0]# systemctl start nginx 
[root@proxy nginx-1.18.0]# netstat -anpt | grep nginx
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      3714/nginx: master  
******(3)修改配置文件
[root@proxy nginx-1.18.0]# cd /usr/local/nginx/conf/
[root@proxy conf]# cp nginx.conf  nginx.conf.bak 
[root@proxy conf]# sed -i '/#/d' nginx.conf
[root@proxy conf]# sed -i '/^$/d' nginx.conf
[root@proxy conf]# mkdir -p /aaa/cache #创建放缓存文件的目录
[root@proxy conf]# vim nginx.conf
    1 worker_processes  1;
  2 events {
  3     worker_connections  1024;
  4 }
  5 http {
  6     include       mime.types;
  7     default_type  application/octet-stream;
  8     sendfile        on;
  9     keepalive_timeout  65;
 10     upstream cache {
 11     server 192.168.100.203:8081;
 12     server 192.168.100.203:8082;
 13     server 192.168.100.203:8083;
 14     }
 15     proxy_cache_path /aaa/cache levels=1:2 keys_zone=code_cache:10m max_size=10g inactive=60m use_temp_path=off;
 16     server {
 17         listen       80;
 18         server_name  localhost;
 19         root html;
 20         index index.html;
 21         location / {
 22         proxy_pass http://cache; #指定跳转,cache就是上面的负载均衡
 23         proxy_cache code_cache;
 24         proxy_cache_valid 200 304 12h;
 25         proxy_cache_valid any 10m;
 26         add_header Nginx-cache "$upstream_cache_status";
 27         proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
 28         #include proxy_params;
 29         }
 30     }
 31 }
[root@proxy conf]# nginx -t 
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
******注释:
proxy_cache_path /aaa/cache levels=1:2 keys_zone=code_cache:10m max_size=10g inactive=60m use_temp_path=off;
/aaa/cache:指定缓存数据存放目录,在配置之前要先创建好
levels=1:2 :按照两层目录分级去存放缓存数据,也就是数据会分两层目录进行存放
keys_zone=code_cache:10m :开辟缓存空间的名称,10m表示大小,1m可以存放8000key
max_size=10g :限制缓存数据最大的大小,超过指定大小后Nginx会清除时间最远的缓存数据
inactive=60m :表示保存的缓存60分钟内没有被访问的话就会被清除
use_temp_path=off :临时文件,会影响性能,建议关闭,不关的话Nginx默认是有一个存放缓存的目录的,关了可以指定缓存的目录
proxy_cache code_cache :开启缓存,后面跟的是区域的名称,就是 proxy_cache_path中keys_zone指定的区域
proxy_cache_valid 200 304 12h :表示状态码是200和304的页面缓存12个小时
proxy_cache_valid any 10m :其他的所有状态码缓存10分钟
add_header Nginx-cache "$upstream_cache_status":修改头部信息,增加Nginx-cache变量的值,值为$upstream_cache_status
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504 :出现500、502、503、504状态码的页面直接交给后端服务器处理,不进行缓存
******
[root@proxy conf]# systemctl start nginx
[root@proxy conf]# netstat -anpt | grep nginx
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      3714/nginx: master  


web的配置:

******(1)和proxy相同做基础配置,安装Nginx(略)
******(2)编写网页页面
[root@web ~]# mkdir -p /zhangsan/A/
[root@web ~]# mkdir -p /zhangsan/B/
[root@web ~]# mkdir -p /zhangsan/C/
[root@web ~]# echo "A"  > /zhangsan/A/A1.html
[root@web ~]# echo "B"  > /zhangsan/B/B1.html
[root@web ~]# echo "C"  > /zhangsan/C/C1.html
[root@web ~]# vim /usr/local/nginx/conf/nginx.conf #修改配置文件
  1 worker_processes  1;
  2 events {
  3     worker_connections  1024;
  4 }
  5 http {
  6     include       mime.types;
  7     default_type  application/octet-stream;
  8     sendfile        on;
  9     keepalive_timeout  65;
 10     server {
 11         listen       8081;
 12         root /zhangsan/A;
 13     }
 14     server {
 15         listen       8082;
 16         root /zhangsan/B;
 17     }
 18     server {
 19         listen       8083;
 20         root /zhangsan/C;
 21     }
 22 }
[root@web ~]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@web ~]# systemctl start nginx
[root@web ~]# netstat -anpt | grep nginx #检查是否有三个端口
tcp        0      0 0.0.0.0:8081            0.0.0.0:*               LISTEN      1136/nginx: master  
tcp        0      0 0.0.0.0:8082            0.0.0.0:*               LISTEN      1136/nginx: master  
tcp        0      0 0.0.0.0:8083            0.0.0.0:*               LISTEN      1136/nginx: master  

使用客户端测试


20210526101852711.png

使用本机查看是否有缓存,注意选项是大写的i


20210526101902449.png

删除缓存,再次查看,直接清空指定的缓存目录即可


20210526101916496.png

(3)配置指定页面不进行缓存

******(1)在代理服务器上做配置
#修改配置文件
[root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
  1 worker_processes  1;
  2 events {
  3     worker_connections  1024;
  4 }
  5 http {
  6     include       mime.types;
  7     default_type  application/octet-stream;
  8     sendfile        on;
  9     keepalive_timeout  65;
 10     upstream cache {
 11     server 192.168.100.203:8081;
 12     server 192.168.100.203:8082;
 13     server 192.168.100.203:8083;
 14     }
 15     proxy_cache_path /aaa/cache levels=1:2 keys_zone=code_cache:10m max_size=10g inactive=60m use_temp_path=off;
 16     server {
 17         listen       80;
 18         server_name  localhost;
 19         if ($request_uri ~ ^/(A1|login|register|password)) {
 20         set $cookie_nocache 1;
 21         }
 22         root html;
 23         index index.html;
 24         location / {
 25         proxy_pass http://cache;
 26         proxy_cache code_cache;
 27         proxy_cache_valid 200 304 12h;
 28         proxy_cache_valid any 10m;
 29         proxy_cache_key $host$uri$is_args$args;
 30         proxy_no_cache $cookie_nocache $arg_nocache $arg_comment $http_pargma $http_authorization;
 31         add_header Nginx-cache "$upstream_cache_status";
 32         proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
 33         #include proxy_params;
 34         }
 35     }
 36 }
[root@proxy ~]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@proxy ~]# nginx -s reload
******(2)进行测试
[root@proxy ~]# rm -rf /aaa/cache/*      #先清除缓存
[root@proxy ~]# curl -s -I http://192.168.100.202/A1.html | grep "Nginx-cache" #不断进行访问
Nginx-cache: MISS
[root@proxy ~]# curl -s -I http://192.168.100.202/A1.html | grep "Nginx-cache"
[root@proxy ~]# curl -s -I http://192.168.100.202/A1.html | grep "Nginx-cache"
[root@proxy ~]# curl -s -I http://192.168.100.202/A1.html | grep "Nginx-cache"
Nginx-cache: MISS
[root@proxy ~]# curl -s -I http://192.168.100.202/A1.html | grep "Nginx-cache"
[root@proxy ~]# curl -s -I http://192.168.100.202/A1.html | grep "Nginx-cache"
[root@proxy ~]# curl -s -I http://192.168.100.202/A1.html | grep "Nginx-cache"
Nginx-cache: MISS

(4)统计缓存日志

******(1)修改配置文件
[root@proxy ~]# touch /usr/local/nginx/logs/proxy_cache.log
[root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
  1 worker_processes  1;
  2 events {
  3     worker_connections  1024;
  4 }
  5 http {
  6     include       mime.types;
  7     default_type  application/octet-stream;
  8     sendfile        on;
  9     keepalive_timeout  65;
 10     upstream cache {
 11     server 192.168.100.203:8081;
 12     server 192.168.100.203:8082;
 13     server 192.168.100.203:8083;
 14     }
 15     log_format  main  '$http_user_agent' '$request_uri' '$remote_addr - $remote_user [$time_local] "$request" '
 16                       '$status $body_bytes_sent "$http_referer" '
 17                       '"$http_user_agent" "$http_x_forwarded_for"' '"$upstream_cache_status"';
 18 
 19     access_log  /var/log/nginx/proxy_cache.log  main;
 20     proxy_cache_path /aaa/cache levels=1:2 keys_zone=code_cache:10m max_size=10g inactive=60m use_temp_path=off;
 21     server {
 22         listen       80;
 23         server_name  localhost;
 24         if ($request_uri ~ ^/(A1|login|register|password)) {
 25         set $cookie_nocache 1;
 26         }
 27         root html;
 28         index index.html;
 29         location / {
 30         proxy_pass http://cache;
 31         proxy_cache code_cache;
 32         proxy_cache_valid 200 304 12h;
 33         proxy_cache_valid any 10m;
 34         proxy_cache_key $host$uri$is_args$args;
 35         proxy_no_cache $cookie_nocache $arg_nocache $arg_comment $http_pargma $http_authorization;
 36         add_header Nginx-cache "$upstream_cache_status";
 37         proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
 38         #include proxy_params;
 39         }
 40     }
 41 }
[root@proxy ~]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@proxy ~]# tail -1 /usr/local/nginx/logs/proxy_cache.log 
Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.25 Safari/537.36 Core/1.70.3861.400 QQBrowser/10.7.4313.400/A1.html192.168.100.230 - - [26/Apr/2021:00:57:49 +0800] "GET /A1.html HTTP/1.1" 200 2 "-" "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.25 Safari/537.36 Core/1.70.3861.400 QQBrowser/10.7.4313.400" "-""MISS"  
#最后有MISS或者HIT


目录
相关文章
|
3月前
|
自然语言处理 大数据 应用服务中间件
大数据-172 Elasticsearch 索引操作 与 IK 分词器 自定义停用词 Nginx 服务
大数据-172 Elasticsearch 索引操作 与 IK 分词器 自定义停用词 Nginx 服务
80 5
|
2月前
|
负载均衡 前端开发 JavaScript
Nginx 代理多服务
以上是 Nginx 代理多服务的几种常见方式,在实际应用中,可以根据具体的业务需求和系统架构选择合适的代理方式,并结合其他 Nginx 的功能和配置来优化和完善系统的性能和功能。
|
3月前
|
缓存 负载均衡 应用服务中间件
Nginx 实现一个端口代理多个前后端服务
【10月更文挑战第19天】Nginx 的强大功能不仅限于此,它还可以与其他技术和工具相结合,为我们的应用提供更强大的支持和保障。在不断发展的互联网时代,掌握 Nginx 的使用技巧将为我们的工作和生活带来更多的便利和效益。
|
3月前
|
存储 缓存 监控
|
3月前
|
存储 缓存 负载均衡
Nginx代理缓存机制
【10月更文挑战第2天】
113 4
|
3月前
|
存储 缓存 NoSQL
Nginx缓存
Nginx缓存
34 2
|
3月前
|
应用服务中间件 Apache 开发工具
nginx服务企业应用
nginx服务企业应用
|
3月前
|
应用服务中间件 网络安全 nginx
nginx作为web服务以及nginx.conf详解
nginx作为web服务以及nginx.conf详解
|
3月前
|
Kubernetes 应用服务中间件 nginx
k8s基础使用--使用k8s部署nginx服务
本文介绍了Kubernetes中核心概念Deployment、Pod与Service的基本原理及应用。Pod作为最小调度单元,用于管理容器及其共享资源;Deployment则负责控制Pod副本数量,确保其符合预期状态;Service通过标签选择器实现Pod服务的负载均衡与暴露。此外,还提供了具体操作步骤,如通过`kubectl`命令创建Deployment和Service,以及如何验证其功能。实验环境包括一台master节点和两台worker节点,均已部署k8s-1.27。
232 1
|
3月前
|
应用服务中间件 Linux Shell
Linux 配置 Nginx 服务的详细步骤,绝对干货
Linux 配置 Nginx 服务的详细步骤,绝对干货
106 0