nginx代理缓存配置-Linux(CentOS)

代理缓存

  • 1. 编写主配置文件
  • 2. 编辑虚拟机配置文件
  • 3. 重启nginx服务

nginx代理服务配置,基于http协议
开启代理缓存的前提是已经开启了代理服务,请确保已经开启代理服务

1. 编写主配置文件

主配置文件通常在/etc/nginx/nginx.conf,在该文件中的http块中添加下面配置

http {proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m max_size=10g inactive=60m use_temp_path=off;
}

该命令的详解:

# 定义 Nginx 缓存区域的配置
# cache_path 指令指定了缓存存储的位置以及相关的缓存设置# /var/cache/nginx: 缓存文件存储的目录
# 这里定义了所有缓存文件将被存储到 /var/cache/nginx 目录下
proxy_cache_path /var/cache/nginx# levels=1:2: 指定了缓存目录的层级结构
# 这有助于避免在存储大量缓存文件时目录变得过于庞大
# 'levels=1:2' 表示缓存目录将分为两级,第一层有 1 个子目录,第二层有 2 个子目录
# 例如:/var/cache/nginx/a/ab,其中 'a' 是第一层目录,'ab' 是第二层目录
levels=1:2# keys_zone=my_cache:10m: 定义了缓存区域的名称和大小
# 'my_cache' 是缓存区域的名称,用于在 proxy_cache 指令中引用
# '10m' 指定了缓存区域的共享内存区域的大小为 10 兆字节
# 该内存用于存储缓存的元数据,例如缓存键和缓存条目的过期时间
keys_zone=my_cache:10m# max_size=10g: 设置缓存区域的最大大小
# '1g' 表示缓存目录的最大存储空间为 1 吉字节
# 一旦缓存目录的大小达到这一限制,旧的缓存条目将被清除以释放空间
max_size=1g# inactive=60m: 设置缓存条目的非活动时间
# '60m' 表示如果缓存条目在 60 分钟内没有被访问,则会被删除
# 这个设置有助于清理不再使用的缓存数据,防止缓存目录变得过于庞大
inactive=60m# use_temp_path=off: 指定是否使用临时路径存储缓存数据
# 'off' 表示缓存数据不会先存储到临时路径中,而是直接写入到缓存目录
# 如果设置为 'on',缓存数据会首先存储到一个临时文件中,写入成功后再移动到缓存目录
use_temp_path=off;

确保路径存在

ls /var/cache/nginx

2. 编辑虚拟机配置文件

虚拟机配置文件通常位于/etc/nginx/conf.d/default.conf
注意:该虚拟机一定要开启代理服务

server {listen       80;server_name  your_domain_or_ip;location / {proxy_cache my_cache;proxy_cache_valid 200 304 12h;proxy_cache_valid any 10m;proxy_cache_key $host$uri$is_args$args;add_header  Nginx-Cache "$upstream_cache_status";proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;}
}

以下是配置项的解释:

# 启用名为 'my_cache' 的缓存区域
# 在 http 块中必须已经定义了名为 'my_cache' 的缓存区域
# 例如,通过 cache_path 指令设置了这个区域
proxy_cache my_cache;# 设置缓存有效时间
# 对于 HTTP 状态码 200(成功)和 304(未修改)的响应,将缓存存储 12 小时
# 这意味着在这段时间内,相同请求的响应将直接从缓存中提供,而不是转发到上游服务器
proxy_cache_valid 200 304 12h;# 对于其他所有 HTTP 状态码的响应(如 400、403、404 等),缓存时间设置为 10 分钟
# 这样即使响应不是成功或未修改的情况,也会在缓存中保留一段时间,减少对上游服务器的请求
proxy_cache_valid any 10m;# 定义缓存键
# 这里使用 $host 和 $uri$is_args$args 作为缓存键的一部分,以确保不同的请求生成唯一的缓存条目
# - $host: 请求的主机名
# - $uri: 请求的路径
# - $is_args: 如果请求有查询参数,添加 '?',否则为空
# - $args: 查询参数
# 这种组合可以有效地区分不同的请求,避免缓存冲突
proxy_cache_key $host$uri$is_args$args;# 添加自定义响应头,显示缓存状态
# 响应头 Nginx-Cache 的值由 $upstream_cache_status 变量提供
# 可能的值包括 'MISS'(缓存未命中)、'HIT'(缓存命中)、'STALE'(缓存过时但仍提供)
# 这对于调试和监控缓存行为非常有用
add_header Nginx-Cache "$upstream_cache_status";# 定义在以下情况下将请求转发到下一个上游服务器
# - error: 上游服务器出现错误
# - timeout: 请求超时
# - invalid_header: 上游服务器返回的头部无效
# - http_500, http_502, http_503, http_504: 上游服务器返回这些错误状态码时
# 这确保了在遇到问题时,Nginx 可以尝试其他上游服务器继续处理请求
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;

3. 重启nginx服务

检测nginx配置文件

nginx -t

重启服务

systemctl restart nginx

访问代理服务器IP地址,通过浏览器开发者功能(F12)。观察是否命中缓存。
Nginx-Cache: HIT为命中
在这里插入图片描述
如果结果为下图,也不要慌初次访问均为miss
Nginx-Cache: HIT为未命中
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/49777.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【云原生】ReplicationController控制器详解

ReplicationController 文章目录 ReplicationController说明一、ReplicationControllere介绍二、ReplicationController如何工作三、运行一个ReplicationController四、编写一个ReplicationController清单注意事项4.1、Pod模板4.2、ReplicationController上的标签4.3、Pod选择算…

python机器学习8--自然语言处理(1)

1.基本定义: 语义:就是一句话的重点是什么。 自定词汇:因为语言、文字太多,自定和处理你所关心的重点词汇。 简体转繁体代码 from opencc import OpenCCtext1 "我去过清华大学" openCC OpenCC(s2t) line openCC.…

Typora 【最新1.8.6】版本安装下载教程 (轻量级 Markdown 编辑器),图文步骤详解,免费领取(软件可激活使用)

文章目录 软件介绍软件下载安装步骤激活步骤 软件介绍 Typora 是一款专为 Markdown 爱好者设计的文本编辑器,它结合了简洁的界面设计与强大的 Markdown 渲染能力,为用户提供了一个流畅、高效的写作环境。以下是对 Typora 更详细的介绍: 核心特…

vue使用mavonEditor(流程图、时序图、甘特图实现)

mavonEditor 安装mavonEditor $ npm install mavon-editor --save使用 // 全局注册import Vue from vueimport mavonEditor from mavon-editorimport mavon-editor/dist/css/index.css// useVue.use(mavonEditor)new Vue({el: #main,data() {return { value: }}})//局部使用…

js-vue中多个按钮状态选中类似于复选框与单选框实现

1.vue中多个按钮状态选中类似于复选框 在Vue中处理多个按钮的选中状态切换&#xff0c;通常我们会利用Vue的响应式数据系统来追踪每个按钮的选中状态。 html <div id"app"> <button v-for"button in buttons" :key"button.id" :c…

MATLAB绘制方波、锯齿波、三角波、正弦波和余弦波、

一、引言 MATLAB是一种具有很强的数值计算和数据可视化软件&#xff0c;提供了许多内置函数来简化数学运算和图形的快速生成。在MATLAB中&#xff0c;你可以使用多种方法来快速绘制正弦波、方波和三角波。以下是一些基本的示例&#xff0c;展示了如何使用MATLAB的命令来实现正弦…

数据科学统计面试问题 -40问

前 40 名数据科学统计面试问题 一、介绍 正如 Josh Wills 曾经说过的那样&#xff0c;“数据科学家是一个比任何程序员都更擅长统计、比任何统计学家都更擅长编程的人”。统计学是数据科学中处理数据及其分析的基本工具。它提供了工具和方法&#xff0c;可帮助数据科学家获得…

第五节shell脚本中的运行流程控制(5.2)

b)应答语句中的变量 #!/usr/bin/expect spawn sh ask.sh set timeout 5 set NAME [ lindex $argv 0 ] set AGE [ lindex $argv 1 ] set SUB [ lindex $argv 2 ] set FEEL [ lindex $argv 3 ] expect {"name" { send "$NAME\r";exp_continue }"old&qu…

【React】条件渲染:深入探讨高效开发技巧与最佳实践

文章目录 一、什么是条件渲染&#xff1f;二、条件渲染的实现方式三、条件渲染的最佳实践四、复杂条件渲染的实现 在现代前端开发中&#xff0c;React 已成为开发者构建用户界面的首选框架之一。React 的强大之处在于其组件化和状态管理能力&#xff0c;而条件渲染则是 React 开…

Linux Vim教程(六):文件操作与保存

目录 1. 打开与关闭文件 1.1 打开文件 1.2 关闭文件 1.3 保存文件 2. 创建和删除文件 2.1 创建新文件 2.2 删除文件 3. 文件浏览与导航 3.1 切换文件 3.2 文件列表 4. 文件保存技巧 4.1 强制保存 4.2 保存为新文件 4.3 自动保存 5. 文件操作的高级技巧 5.1 分割…

防火墙限制docker了

今天有个安全方面的需求&#xff0c;演示环境禁止将3306等高危端口暴露到外网。 于是同事开启了防火墙&#xff0c;仅将应用端口暴露。结果导致演示环境无法使用。 由于公司的应用是基于docker部署的。结果他问我为什么同一台机器&#xff0c;应用无法访问mysql。 docker对于…

ELK Stack入门之部署EFK架构

前言&#xff1a; 日志分析对于现代IT系统来说至关重要&#xff0c;它可以帮助组织机构理解和优化其业务和技术基础设施。以下是日志分析的一些重要性方面&#xff1a; 问题诊断与故障排除&#xff1a; 当系统发生故障或出现异常时&#xff0c;通过对相关日志进行分析&#xf…

SQL labs-SQL注入(五,使用sqlmap进行cookie注入)

本文仅作为学习参考使用&#xff0c;本文作者对任何使用本文进行渗透攻击破坏不负任何责任。 引言&#xff1a; Cookie 是一些数据, 存储于你电脑上的文本文件中。当 web 服务器向浏览器发送 web 页面时&#xff0c;在连接关闭后&#xff0c;服务端不会记录用户的信息。Cookie…

第十一章 数据结构

第十一章 数据结构 11.1 数组 数组是元素的顺序集合&#xff0c;通常这些元素具有相同的数据类型 索引表示元素在数组中的顺序号&#xff0c;顺序号从数组开始处计数 数组元素通过索引被独立给出了地址&#xff0c;数组整体上有一个名称&#xff0c;但每个元素利用数组的的…

elasticsearch 解决全模糊匹配最佳实践

事件背景&#xff1a; 某 CRM 系统&#xff0c;定义了如下两个表&#xff1a; 客户表 t_custom 字段名 类型 描述 idlong自增主键phonestring客户手机......... 客户产品关系表 t_custom_product 字段名 类型 描述 idlong自增主键custom_idlong客户idproduct_idlong产品…

【buildroot系统中qt显示屏触摸方向更改】

buildroot系统和qt的显示触摸不一致&#xff0c;qt程序出现显示触摸上下颠倒问题 操作全部在启动qt程序之前设置系统显示配置 操作全部在启动qt程序之前设置系统显示配置 我的设备是上电自启动我的qt程序&#xff0c;所以为了方便我全部在调用我的qt程序位置处修改vi /etc/ini…

vue如何适应多个页面不同的布局

在 Vue.js 中&#xff0c;要适应多个页面不同的布局&#xff0c;你可以采用以下几种方法&#xff1a; 使用动态组件 (Dynamic Components)&#xff1a; 通过使用 Vue 的动态组件&#xff0c;可以在同一个页面中根据路由动态加载不同的布局组件。 <template><component…

笔记本检测工具 | 爱回收笔记本质检系统 v1.9.6

软件简介 爱回收笔记本质检系统是一款专为笔记本电脑硬件检测而设计的软件。它以其快速的检测速度、简便的操作流程和直观的检测结果&#xff0c;为用户提供了一种高效、易懂的硬件检测解决方案。 这款软件不仅适用于对电脑硬件有一定了解的用户&#xff0c;也特别适合对硬件…

SQL进阶:解锁高级特性,深化数据洞察

掌握了SQL的基础知识后&#xff0c;进一步探索其高级特性将帮助您更高效地处理复杂数据&#xff0c;深化数据分析的广度和深度。本文将带您领略SQL的高级功能&#xff0c;包括窗口函数、存储过程、触发器以及高级查询技巧等&#xff0c;让您在数据处理的道路上更进一步。 一、…

C#使用csvhelper实现csv的操作

新建控制台项目 安装csvhelper 33.0.1 写入csv 新建Foo.cs namespace CsvSut02;public class Foo {public int Id { get; set; }public string Name { get; set; } }批量写入 using System.Globalization; using CsvHelper; using CsvHelper.Configuration;namespace Csv…