nginx的缓存和gzip

nginx的缓存

缓存的基本思想是利用客户端访问的时间局限性,将客户端访问过的内容做一个副本,在一定时间内存放到本地,当改数据下次被访问时,不必连接到后端服务器反复去查询数据,而是由本地保存的副本响应数据。
保存在本地的这些副本具有一个过期时间,超过该时间将会更新。判断一个副本数据是否为过期数据的办法有很多,可以使用保留时间来判断,也可以使用数据完整度来判断。

缓存的好处
  1. 减轻服务器负载
  2. 提供网页响应效率
  3. 降低网络阻塞,增强网络可扩展性
为什么使用缓存?
  1. 服务器处理能力以及负载能力出现瓶颈,响应效率大大降低

  2. 为了减少网络传输延迟,提升响应效率

  3. 能够避免因为后端服务器出现异常以及网络故障,客户端请求数据副本能够及时响应

    proxy_cache imooc_cache; #用于配置一块公用的内存区域的名称
    proxy_pass http://www.blogs-s.com:8080/api/; #代理的服务器
    proxy_cache_valid 200 304 12h; #针对不同的HTTP响应状态设置不同的缓存时间
    proxy_cache_valid any 10m;
    proxy_cache_key hosturiis_argsargs; #用于设置Nginx服务器在内存中为缓存数据建立索引时使用的关键字
    include proxy_params; #引入缓存文件
    proxy_set_header Host http_host; # 设置请求头信息 proxy_set_header X-Real-IP remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_connect_timeout 30; #代理服务器超时时间
    proxy_send_timeout 60; #发送请求给代理服务器的超时时间
    proxy_read_timeout 60; #读取代理服务器超时时间
    proxy_buffering on; #开启缓冲区
    proxy_buffer_size 32k; #缓冲区大小
    proxy_buffers 4 128k; #指定一个请求的缓冲大小以及数量

开启代理缓存**:**
复制代码
location ^~ /abc {
proxy_cache cache_one;
proxy_pass http://larave.xym/;
proxy_cache_valid 200 304 12h;
proxy_cache_valid any 10m;
proxy_cache_key $host$uri$is_args$args;
}

客户端缓存一般指的是 浏览器缓存、 app 缓存 等等,目的就是 加速各种静态资源的访问 ,降低服务器压力。


Nginx的gzip

Gzip 是一种流行的文件压缩算法,现在的应用十分广泛,尤其是在 Linux 平台。当应用Gzip 压缩到一个纯文本文件时,效果是非常明显的,大约可以减少70%以上的文件大小。这取决于文件中的内容。


Gzip on;
Gzip_min_length 1024;
Gzip_buffers 4 16k;
Gzip_comp_level 2;
Gzip_types text/plain application/x-javascript text/css application/xml;
Gzip_vary on;
Gunzip_static on;

相关推荐
LYFlied3 小时前
【每日算法】LeetCode 146. LRU 缓存机制
前端·数据结构·算法·leetcode·缓存
FrameNotWork5 小时前
HarmonyOS 教学实战(二):加入网络请求与缓存(让你的应用真正“像个正式 App”)
缓存·华为·harmonyos
叫我龙翔6 小时前
【Redis】从零开始掌握redis --- 认识redis
数据库·redis·缓存
源代码•宸6 小时前
goframe框架签到系统项目(安装 redis )
服务器·数据库·经验分享·redis·后端·缓存·golang
忍冬行者16 小时前
清理三主三从redis集群的过期key和键值超过10M的key
数据库·redis·缓存
TimberWill16 小时前
使用Redis队列优化内存队列
数据库·redis·缓存
梦里不知身是客111 天前
redis的缓存击穿原因
redis·缓存·bootstrap
GGBondlctrl1 天前
【Redis】从单机架构到分布式,回溯架构的成长设计美学
分布式·缓存·架构·微服务架构·单机架构
不穿格子的程序员1 天前
Redis篇4——Redis深度剖析:内存淘汰策略与缓存的三大“天坑”
数据库·redis·缓存·雪崩·内存淘汰策略
想搞艺术的程序员1 天前
Go语言环形队列:原理剖析、编程技巧与核心优势
后端·缓存·golang