当前位置: 首页 > news >正文

Nginx静态资源配置

基本配置原则

  1. 明确资源目录:为不同类型的静态资源指定不同的路径,这样可以避免路径冲突,并且便于管理。
  2. 正确设置文件权限:确保 Nginx 具有读取静态资源的权限。
  3. 缓存优化:为静态资源设置缓存头(如 expires),提高性能。
  4. 目录结构清晰:保持清晰、合理的目录结构,避免将所有资源放在同一目录下。

示例配置:

server {listen 80;server_name www.example.com;  # 域名# 设置网站的根目录root /usr/local/nginx/html;  # 网站根目录index index.html index.htm;# 配置静态资源路径# 配置 CSS 目录location /css/ {root /usr/local/nginx/html;  # 静态资源根目录# 缓存静态资源 1 周expires 7d;add_header Cache-Control "public";}# 配置 JS 目录location /js/ {root /usr/local/nginx/html;  # 静态资源根目录# 缓存静态资源 1 周expires 7d;add_header Cache-Control "public";}# 配置图片目录location /images/ {root /usr/local/nginx/html;  # 静态资源根目录# 缓存图片 1 月expires 30d;add_header Cache-Control "public";}# 配置其他文件类型的静态资源(如视频、音频等)location /media/ {root /usr/local/nginx/html;  # 静态资源根目录# 设置缓存时间expires 30d;add_header Cache-Control "public";}# 为静态文件配置错误页面error_page 404 /404.html;location = /404.html {root /usr/local/nginx/html;  # 设置404错误页面的目录}}

配置解析:

  1. root /usr/local/nginx/html;
    • root 指令指定了网站的根目录,静态资源将会相对于此目录来寻找。比如 location /css/ 配置意味着当访问 http://your-site/css/style.css 时,Nginx 会从 /usr/local/nginx/html/css/style.css 文件路径提供资源。
  2. expiresCache-Control
    • expires 7d; 设置资源的过期时间(在客户端缓存中存储)。例如,cssjs 文件缓存时间为 7 天,imagesmedia 目录的文件缓存时间更长,设置为 30 天。
    • add_header Cache-Control "public"; 使得这些资源可以被缓存。
  3. location /css/location /js/location /images/ 等:
    • 每个资源目录都单独配置了 location,Nginx 根据请求的路径 /css//js/ 来匹配相应的目录。
    • 这些资源将直接从 Nginx 的根目录下提供,无需代理到后端应用。
  4. error_page
    • error_page 404 /404.html; 用于配置自定义的错误页面。当文件未找到时,Nginx 将显示自定义的 404.html 页面。
  5. location = /404.html
    • 配置 404 错误页面的位置,Nginx 会提供一个静态的 404.html 页面。

其他注意事项:

  1. 文件权限
    • 确保 Nginx 用户(通常是 nginxwww-data)对静态资源目录具有 读取权限
  2. 避免缓存冲突
    • 通过合理设置缓存头(如 Cache-Control)来避免客户端缓存过期的资源。对于不经常更新的资源(如图片、字体),可以设置较长的缓存时间;对于经常更新的资源(如 CSS 和 JS),可以设置较短的缓存时间。
  3. 路径避免冲突
    • 确保静态资源的路径(如 /css/, /js/)和动态路径(如应用请求路径)没有冲突,避免路径匹配错误。

总结:

  1. 通过 location 配置不同静态资源的目录,可以提高配置的可维护性和清晰度。
  2. 使用 expiresCache-Control 来设置缓存策略,提高性能。
  3. 确保静态资源文件的权限和路径正确,避免出现无法访问的情况。
  4. 定期检查日志文件,确保静态资源配置生效。

这种配置方式不仅能够有效提高网站的访问速度,还能减轻服务器的压力,因为浏览器可以缓存静态资源,减少每次访问时对服务器的请求。

Tips

500页面参考

在这里插入图片描述

404页面参考

在这里插入图片描述

静态资源集合仓库:https://gitee.com/lin_yi1/html-resources.git

相关文章:

Nginx静态资源配置

基本配置原则 明确资源目录:为不同类型的静态资源指定不同的路径,这样可以避免路径冲突,并且便于管理。正确设置文件权限:确保 Nginx 具有读取静态资源的权限。缓存优化:为静态资源设置缓存头(如 expires&…...

困扰解决:mfc140u.dll丢失的解决方法,多种有效解决方法全解析

当电脑提示“mfc140u.dll丢失”时,这可能会导致某些程序无法正常运行,给用户带来不便。不过,有多种方法可以尝试解决这个问题。这篇文章将以“mfc140u.dll丢失的解决方法”为主题,教大家有效解决mfc140u.dll丢失。 判断是否是“mf…...

D3.js 初探

文章目录 D3.js 简单介绍选择集与方法数据绑定方法选择集添加DOM元素以及删除元素理解update enter 以及 exit关于比例尺layout 布局force layout 坐标轴元素添加动态效果demo1: 绘制简单柱状图 #D3.js 初探 最近在做一个Data Visualization 的项目,由于对最终呈现的…...

linux常用指令 | 适合初学者

linux常用指令 1.ls: 列出当前,目录中的文件和子目录 ls 2.pwd: 显示当前工作目录的路径 pwd3.cd切换工作目录 cd /path/to/director4.mkdir:创建新目录 mkdir directory_name5.rmdir:删除空目录 rmdir directory_name6.rm: 删除文件或目录 rm file_name r…...

用 NotePad++ 运行 Java 程序

安装包 网盘链接 下载得到的安装包: 安装步骤 双击安装包开始安装. 安装完成: 配置编码 用 NotePad 写 Java 程序时, 需要设置编码. 在 设置, 首选项, 新建 中进行设置, 可以对每一个新建的文件起作用. 之前写的文件不起作用. 在文件名处右键, 可以快速打开 CMD 窗口, 且路…...

在 Linux 环境下搭建 OpenLab Web 网站并实现 HTTPS 和访问控制

实验要求 综合练习:请给openlab搭建web网站 ​ 网站需求: ​ 1.基于域名[www.openlab.com](http://www.openlab.com)可以访问网站内容为 welcome to openlab!!! ​ 2.给该公司创建三个子界面分别显示学生信息,教学资料和缴费网站&#xff0c…...

微信小程序wx.showShareMenu配置全局分享功能

在app.js文件中配置如下即可: onLaunch() {//开启分享功能this.overShare()},/*** 开启朋友圈分享功能* 监听路由切换/自动执行*/overShare() {wx.onAppRoute((res) > {// console.log(route, res)let pages getCurrentPages()let view pages[pages.length - …...

机器学习面试八股总结

下面是本人在面试中整理的资料和文字,主要针对机器学习面试八股做浅显的总结,大部分来源于ChatGPT,中间有借鉴一些博主的优质文章,已经在各文中指出原文。有任何问题,欢迎随时不吝指正。 文章系列图像使用动漫 《星游…...

南京邮电大学《2024年812自动控制原理真题》 (完整版)

本文内容,全部选自自动化考研联盟的:《南京邮电大学812自控考研资料》的真题篇。后续会持续更新更多学校,更多年份的真题,记得关注哦~ 目录 2024年真题 Part1:2024年完整版真题 2024年真题...

大数据新视界 -- Hive 数据湖集成与数据治理(下)(26 / 30)

💖💖💖亲爱的朋友们,热烈欢迎你们来到 青云交的博客!能与你们在此邂逅,我满心欢喜,深感无比荣幸。在这个瞬息万变的时代,我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…...

Android EventBus最全面试题及参考答案

目录 什么是 EventBus? 请解释 EventBus 是什么,以及它的工作原理。 简述 EventBus 的工作原理。 EventBus 的主要组成部分有哪些? EventBus 是如何实现发布订阅模式的? EventBus 与观察者模式有什么区别? Even…...

C++ 游戏开发:开启游戏世界的编程之旅(1)

在游戏开发领域,C 一直占据着极为重要的地位。它以高效的性能、对底层硬件的良好控制能力以及丰富的库支持,成为众多大型游戏开发项目的首选编程语言。今天,就让我们一同开启 C 游戏开发的探索之旅。 一、C 游戏开发基础 (一&am…...

SpringBoot mq快速上手

1.依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId> </dependency> 2.示例代码 基础信息配置 package com.example.demo.config;import org.springframework.amqp.co…...

图像处理网络中的模型水印

论文信息&#xff1a;Jie Zhang、Han Fang、Weiming Zhang、Wenbo Zhou、Hao Cui、Hao Cui、Nenghai Yu&#xff1a;Model Watermarking for Image Processing Networks 本文首次提出了图像处理网络中深度水印问题&#xff0c;将知识产权问题引入图像处理模型 提出了第一个深…...

Halcon 瑕疵检测原理及应用

摘要&#xff1a; 本文详细阐述了 Halcon 在瑕疵检测领域的原理、相关技术以及广泛的应用场景。首先介绍了 Halcon 软件的基本概况及其在机器视觉领域的重要地位&#xff0c;接着深入剖析了瑕疵检测所涉及的图像采集、预处理、特征提取与分析以及分类与判定等核心原理&#xff…...

JAVA 架构师面试 100套含答案:JVM+spring+ 分布式 + 并发编程》...

今年的行情&#xff0c;让招聘面试变得雪上加霜。已经有不少大厂&#xff0c;如腾讯、字节跳动的招聘名额明显减少&#xff0c;面试门槛却一再拔高&#xff0c;如果不用心准备&#xff0c;很可能就被面试官怼得哑口无言&#xff0c;甚至失去了难得的机会。 现如今&#xff0c;…...

多模态学习详解

多模态学习详解 引言 多模态&#xff08;Multimodal&#xff09;学习是机器学习和人工智能领域的一个重要分支&#xff0c;它涉及从多个不同类型的输入数据中提取信息&#xff0c;并将这些信息融合以改善模型的性能。多模态学习能够处理的数据类型广泛&#xff0c;包括但不限…...

C#应用开发:基于C# WPF界面实现本机网络通讯状态(下载速度)的显示

目录 概述 具体实现 第一步&#xff1a;获取网络接口信息 代码解释&#xff1a; 第二步&#xff1a;创建 WPF 界面 第三步&#xff1a;绑定数据 注意事项 概述 在 WPF 中实现一个界面来显示本机网络接口的状态&#xff0c;通常需要以下几个步骤&#xff1a; 获取网络接口…...

Octo—— 基于80万个机器人轨迹的预训练数据集用于训练通用机器人,可在零次拍摄中解决各种任务

概述 论文地址&#xff1a;https://arxiv.org/abs/2405.12213 在机器人学中&#xff0c;通常使用针对特定机器人或任务收集的数据集来学习策略。然而&#xff0c;这种方法需要为每项任务收集大量数据&#xff0c;由此产生的策略只能实现有限的泛化性能。利用其他机器人和任务的…...

2022高等代数下【南昌大学】

设 ε 1 , ε 2 , ε 3 \varepsilon_1, \varepsilon_2, \varepsilon_3 ε1​,ε2​,ε3​ 是复数域上线性空间 V V V 的一组基,线性变换 σ \sigma σ 在 ε 1 , ε 2 , ε 3 \varepsilon_1, \varepsilon_2, \varepsilon_3 ε1​,ε2​,ε3​ 下的矩阵为 J = ( 2 0 0 1 2…...

相控阵天线设计避坑指南:为什么低副瓣方案里,Chebyshev加权比单纯调相位更靠谱?

相控阵天线设计避坑指南&#xff1a;为什么低副瓣方案里&#xff0c;Chebyshev加权比单纯调相位更靠谱&#xff1f; 在相控阵天线设计中&#xff0c;低副瓣性能往往是工程师们追求的关键指标之一。副瓣过高不仅会浪费辐射能量&#xff0c;还可能造成信号干扰、目标识别困难等一…...

Ollama REST API 深度解析:如何用 HTTP 接口调用模型

系列导读 你现在看到的是《Ollama 本地大模型管理实战:从部署到调优的完整指南》的第 4/10 篇,当前这篇会重点解决:让读者掌握通过 HTTP 接口编程调用 Ollama 模型的核心技能。 上一篇回顾:第 3 篇《模型加载与运行参数调优:从默认到高性能的实战配置》主要聚焦 教会读者…...

Unlock Music终极指南:5分钟掌握音乐格式转换的隐藏技巧

Unlock Music终极指南&#xff1a;5分钟掌握音乐格式转换的隐藏技巧 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库&#xff1a; 1. https://github.com/unlock-music/unlock-music &#xff1b;2. https://git.unlock-music.dev/um/web 项目地址: htt…...

3步快速掌握罗技鼠标宏:PUBG压枪新手完全指南

3步快速掌握罗技鼠标宏&#xff1a;PUBG压枪新手完全指南 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 还在为《绝地求生》中难以控制的武器后…...

Photoshop+Unity法线贴图工作流:从NMF生成到URP Decal正确显示

1. 这不是一张“凹凸贴图”&#xff0c;而是一套从PS到Unity的法线工作流闭环你有没有试过在Photoshop里用滤镜生成法线贴图&#xff0c;导出后放进Unity——结果模型表面像被砂纸磨过一样全是噪点&#xff1f;或者更糟&#xff1a;Decal&#xff08;贴花&#xff09;明明贴在墙…...

热门推荐:收藏!软件研发小白必看:AI转型从思维转变开始,轻松掌握大模型协作

本文探讨了软件研发团队如何进行AI转型&#xff0c;强调不应从购买工具或引入Agent开始&#xff0c;而是应首先关注个体思维的转变、团队知识底座的统一以及协作流程的重新设计。文章指出&#xff0c;开发者需要从关注代码实现转向关注编码前的设计、上下文组织和边界定义&…...

3分钟搞定Windows苹果USB驱动安装:终极免费解决方案

3分钟搞定Windows苹果USB驱动安装&#xff1a;终极免费解决方案 【免费下载链接】Apple-Mobile-Drivers-Installer Powershell script to easily install Apple USB and Mobile Device Ethernet (USB Tethering) drivers on Windows! 项目地址: https://gitcode.com/gh_mirro…...

苏州晟雅泰电子:关于长鑫存储与兆易创新的关系

长鑫存储&#xff08;及其母公司长鑫科技&#xff09;与兆易创新的关系极为紧密&#xff0c;是由一位核心人物——董事长朱一明联结而成的深度战略联盟。这两家公司在股权、人事和业务等多个层面相互绑定&#xff0c;形成了“一个核心、两个支点”的独特格局。以下是其关系的具…...

DazToBlender:3D创作工作流的无缝桥梁

DazToBlender&#xff1a;3D创作工作流的无缝桥梁 【免费下载链接】DazToBlender Daz to Blender Bridge 项目地址: https://gitcode.com/gh_mirrors/da/DazToBlender 在3D数字创作的世界里&#xff0c;艺术家们常常面临一个现实困境&#xff1a;如何在不同的专业软件之…...

观察Taotoken在不同网络环境下API调用的延迟表现

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 观察Taotoken在不同网络环境下API调用的延迟表现 在将大模型API集成到实际应用时&#xff0c;网络环境是影响开发者体验的关键因素…...