​上一节我们介绍了nginx的三个使用场景和一些配置语法参数,今天我们就用一章的内容来介绍一下Nginx作为静态资源服务器的配置和常见问题。

一. 简单的静态服务器

​话不多说,直接上配置代码。

  server{
       listen    8080;
       server_name    localhost;
       location / {
      alias    /home/user/nginx/html/static_html/;
      index    index_static.html;
       }
  }

注:
  listen: 监听的端口号
  server_name: 域名
  location:配置的静态文件域
  /: 表示所有的请求
  alias:本地资源路径。(root可实现类似功能,两者的区别是root会将location /后的路径拼接到转换后的路径,alias则不会)
  index: 默认页,如果不配置此参数Nginx会找目录下的index.html index.htm作为默认页
小技巧:在配置Nginx时,可以在其他文件中写上诉的配置。并使用include 文件名的方式,将其他配置文件注入到nginx.conf中。nginx.conf是Nginx在启动或者reload时默认载入的配置文件,当然我们可以使用nginx命令 -c重新指定。

二. 压缩静态文件

​静态文件如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静态文件的更多相关文章

  1. Nginx 静态文件服务

    Nginx 静态文件服务 我们先来看看最简单的本地静态文件服务配置示例: server { listen 80; server_name www.test.com; charset utf-8; ro ...

  2. nginx静态文件缓存的解决方案

    nginx的一大功能就是完成静态资源的分离部署,减轻后端服务器的压力,如果给这些静态资源再加一级nginx的缓存,可以进一步提升访问效率. 第一步:添加nginx.conf的http级别的缓存配置 # ...

  3. 记一次vue2项目部署nginx静态文件404解决过程

    github上下的一个vue2的项目,运行可以的,webpack打包后,nginx请求报错: 发现路径很奇怪啊,所以果断来到build.js文件中看看是不是哪里不对. 已经一番引用查找: 发现在这里配 ...

  4. nginx静态文件访问404

    在http模块下加入下面的代码 server { listen 80; server_name 192.168.1.249; #本机ip #access_log logs/host.access.lo ...

  5. Nginx静态文件服务器配置方法

    在Java开发以及生产环境中,最常用的web应用服务器当属Tomcat,尽管这只猫也能够处理一些静态请求,例如图片.html.样式文件等,但是效率并不是那么尽人意.在生产环境中,我们一般使用Nginx ...

  6. nginx静态文件不设置缓存

    找到nginx安装目录下的nginx.conf文件,再nginx里面添加如下的内容 location / { add_header Cache-Control no-cache; add_header ...

  7. Nginx静态文件路径配置

    root目录与alias目录的区别 Nginx路径location配置中,使用root目录与alias目录的区别 1)alias指定的目录是准确的,即location匹配访问的path目录下的文件直接 ...

  8. 用Lua控制Nginx静态文件的url访问权限

    需求背景:比如我们有一个存储文件的web服务器,一般通过url可直接访问到:http://127.0.0.1/uploads/test.rar,如果我们需要限制别人的访问,可以通过添加lua脚本来控制 ...

  9. nginx静态文件缓存

    open_file_cache max=65535 inactive=30s; open_file_cache 打开缓存的同时也指定了缓存最大数目,以及缓存的时间 open_file_cache_va ...

随机推荐

  1. Android Support Library详细介绍

    网上对Android Support Library中各个依赖包介绍的中文资料太少了,结合官方文档和有限的参考资料做了一次总结,有描述得不对的地方还请指正. 一.主工程.依赖包.jar包.androi ...

  2. 18.scrapy_maitian_analysis

    1_info.py # encoding: utf-8 import pandas as pd # 租房 基本信息 # 读取文件 df=dataframe df = pd.read_json(&quo ...

  3. spring boot中使用javax.validation以及org.hibernate.validator校验入参

    这里springboot用的版本是:<version>2.1.1.RELEASE</version> 自带了hibernate.validator,所以不用添加额外依赖 1.创 ...

  4. 第五周课堂笔记1th

    可迭代对象   Isinstance  判断一个对象是否属于某种类型 接受两个参数 迭代器 以下数据类型都没迭代器: 把没有迭代器的类型更改为有迭代器类型 用迭代器进行取值: 判断迭代器的方法: 3. ...

  5. Identifying a Blocking Query After the Issuing Session Becomes Idle

    Identifying a Blocking Query After the Issuing Session Becomes Idle #查看阻塞信息 select * from sys.innodb ...

  6. vuex的使用入门-官方用例

    store/index.js import Vue from 'vue' import Vuex from 'vuex'; // 使用vuex Vue.use(Vuex) const store = ...

  7. CSS——div内文字的溢出部分用省略号显示

    使得div内文字的溢出部分用省略号显示,可归纳为两种解决办法,一种方法是用CSS解决,另一种方法是js解决. 一.通过CSS控制显示 div内显示一行,超出部分用省略号显示 div内显示多行,超出部分 ...

  8. vue+layui制作列表页

    优点: 1.选用layui国产. 2.layui有一套完整的前端框架,基本哪来就可以用. 3.选用vue去掉了很多页面元素js拼接的繁琐,及不易修改. 4.vue里面还有一些过滤器等,用起来很方便. ...

  9. 转载:shell中#*,##*,#*,##*,% *,%% *的含义及用法

    介绍下Shell中的${}.##和%%使用范例,本文给出了不同情况下得到的结果.假设定义了一个变量为:代码如下:file=/dir1/dir2/dir3/my.file.txt可以用${ }分别替换得 ...

  10. Mysql的数据列类型效率

    1.    能短就不要长.(磁盘I/O少一些) 比如固定 长度的CHAR数据列,定义 CHAR(40),而不是 CHAR(255); 比如MEDIUMINT代替BIGINT,数据表就小一些, 值的处理 ...