[Day2] Nginx静态文件
上一节我们介绍了nginx的三个使用场景和一些配置语法参数,今天我们就用一章的内容来介绍一下Nginx作为静态资源服务器的配置和常见问题。
一. 简单的静态服务器
话不多说,直接上配置代码。
server{
listen 8080;
server_name localhost;
location / {
alias /home/user/nginx/html/static_html/;
index index_static.html;
}
}
二. 压缩静态文件
静态文件如html、css、js等有时候比较大,使用压缩可以很好的提升网络传输的性能。不过压缩需要占用服务器的cpu时间,是否启用压缩以及选择压缩率还是要视情况而定。
命令:
gzip on;
gzip_min_length 1024;
gzip_comp_level 2;
gzip_types test/plain application/x-javascript application/javascript text/css application/xml image/jpeg image/gif image/png;
注解:
可配置到server中局部生效。也可以配置在server外 http中文件内生效。
gzip: on 启动压缩 off 关闭压缩
gzip_min_length: 需要压缩的最小字节数,小于此配置的文件将不会被压缩
gzip_comp_level: 压缩级别,1-10,数字越大压缩的越好,也越占用CPU时间。一般设置为1- 2,过高的设置压缩效果提升的不明显。
gzip_types: 需要压缩的文件类型
三. 设置成目录文件
有时候一个nginx服务就是为了用来下载文件的,例如prce官网的下载页面。这个在nginx中配置一个命令即可。
命令:
auto_index on;
注:如果server首页就要显示目录文件,应该将 index 配置的首页设置为不存在的文件。Nginx的处理流程中index模块要先与auto_index模块,如果index模块生效,auto_index模块将不会执行。
四. 设置大文件时的限速
为了避免用户请求大文件时将带宽占满,而对其他用户访问小文件产生影响,我们可以在nginx上进行配置,对文件的下载速度进行限速。
命令:
set $limit_rate 300k;
注:$limit_rate是Nginx提供的参数变量,几乎所有Nginx模块都有变量,在官网文档中可以在相关模块的Embedded Variables中找到该模块提供的所有变量以及其用处。
300k是设置的每秒请求文件大小
五. 设置日志文件
Nginx日志文件access.log可以记录每一次访问请求的相关数据,根据这些数据我们了解网站的整个运行情况。Nginx会默认开启日志模块功能,并允许我们对日志格式、文件路径做自定义的配置。
命令:
1. 设置日志格式规则
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
注:main是格式规则名,后边是日志的格式
2. 设置启用main格式规则
access_log logs/host.access.log main;
注:logs/host.accesss.log 是日志文件路径,main则表示启用规则名为main的日志
六. GoAccess
GoAccess是一款可视化监控access日志的组件,用起来非常简单,它会将access文件的内容解析成各种维度的图表,在生产环境经常会使用到它。
[Day2] Nginx静态文件的更多相关文章
- Nginx 静态文件服务
Nginx 静态文件服务 我们先来看看最简单的本地静态文件服务配置示例: server { listen 80; server_name www.test.com; charset utf-8; ro ...
- nginx静态文件缓存的解决方案
nginx的一大功能就是完成静态资源的分离部署,减轻后端服务器的压力,如果给这些静态资源再加一级nginx的缓存,可以进一步提升访问效率. 第一步:添加nginx.conf的http级别的缓存配置 # ...
- 记一次vue2项目部署nginx静态文件404解决过程
github上下的一个vue2的项目,运行可以的,webpack打包后,nginx请求报错: 发现路径很奇怪啊,所以果断来到build.js文件中看看是不是哪里不对. 已经一番引用查找: 发现在这里配 ...
- nginx静态文件访问404
在http模块下加入下面的代码 server { listen 80; server_name 192.168.1.249; #本机ip #access_log logs/host.access.lo ...
- Nginx静态文件服务器配置方法
在Java开发以及生产环境中,最常用的web应用服务器当属Tomcat,尽管这只猫也能够处理一些静态请求,例如图片.html.样式文件等,但是效率并不是那么尽人意.在生产环境中,我们一般使用Nginx ...
- nginx静态文件不设置缓存
找到nginx安装目录下的nginx.conf文件,再nginx里面添加如下的内容 location / { add_header Cache-Control no-cache; add_header ...
- Nginx静态文件路径配置
root目录与alias目录的区别 Nginx路径location配置中,使用root目录与alias目录的区别 1)alias指定的目录是准确的,即location匹配访问的path目录下的文件直接 ...
- 用Lua控制Nginx静态文件的url访问权限
需求背景:比如我们有一个存储文件的web服务器,一般通过url可直接访问到:http://127.0.0.1/uploads/test.rar,如果我们需要限制别人的访问,可以通过添加lua脚本来控制 ...
- nginx静态文件缓存
open_file_cache max=65535 inactive=30s; open_file_cache 打开缓存的同时也指定了缓存最大数目,以及缓存的时间 open_file_cache_va ...
随机推荐
- Java笔记 - Socket编程
两个Java应用程序可以通过一个双向的网络通讯连接实现数据交换,这个双向链路的一端称为一个Socket.java.net包中定义的两个类Socket和ServerSocket,分别用来实现双向链路的c ...
- maven项目依赖其他jar包的时候,idea运行没问题,java -jar 报错:java.lang.SecurityException: Invalid signature file digest
当项目依赖其他jar包的时候,打出的jar包执行出错,抛出这个异常. 原因:因为依赖jar包中的META-INF中有多余的.SF文件与当前jar包冲突, 解决方案 一 在打包前删除依赖jar包的.SF ...
- 前端笔记:animate+easing用法(hexo next主题自定义动画)
个人博客:https://mmmmmm.me 源码:https://github.com/dataiyangu/dataiyangu.github.io easing介绍 animate默认是有加速度 ...
- selector是在文件夹drawable中进行定义的xml文件转载 https://www.cnblogs.com/fx2008/p/3157040.html
获取Drawable对象: Resources res = mContext.getResources(); Drawable myImage = res.getDrawable(R.drawable ...
- 搞笑:Java & PHP & C++ 之间的战斗!
Java 拥有十八般武艺,PHP一招致命!PHP 果然是世界上最好的编程语言~ Java 连老将 C++ 也干不过,直接一招 KO,我也是醉了... 这里并不是贬低Java,只有资深老司机能看懂的图吧 ...
- Redis相关语法
设置用户密码 config set requirepass yourPassword
- 六. Default arguments 参数默认值
示例: 注意点:函数是会默认声明参数变量的,所以不需要再重新声明一次,否则会报错 错误示例如下: 函数参数的传值方法: 需要注意的是:如果要给第二个参数传值,那第一个参数要传undefined,而不能 ...
- ros python
https://www.ncnynl.com/archives/201611/1059.html python的节点需要对节点设置权限为可执行,在.py文件所在的路径执行如下命令 $ touch ta ...
- duilib教程之duilib入门简明教程1.前言
关于duilib的介绍就不多讲了,一来不熟,二来小伙伴们想必已经对比了多个界面库,也无需赘述.下面进入正题: 不看广告看疗效! 已有众多知名公司采用duilib做为界面库,如华为网盘.PPS(P ...
- Jeecg-Boot 2.0.1 版本发布,前后端分离快速开发平台
Jeecg-Boot项目简介 Jeecg-boot 是一款基于代码生成器的快速开发平台! 采用前后端分离技术:SpringBoot,Mybatis,Shiro,JWT,Vue & Ant De ...