0


Nginx的指令及基础配置

1. Nginx的概念

    Nginx经常作为反向代理服务器使用。

    它接收外网的HTTP/HTTPS请求,作为代理中间将这些请求转发到内网的后端服务器上;

    同时也将内网的后端服务器的响应,返回给外网的客户端。

    也就是说,Nginx作为反向代理,通过合理的配置可以实现内网和外网的“隔离”。

    让外网用户有条件的通过Nginx访问内网的Web服务,同时内网的服务器地址不会暴露给外网,避免外网用户直接访问内网的风险。

   

1.1 正向代理

    可以理解为面向客户端的代理,代替客户端向服务器发送和接受请求,服务端不知道实际发起请求的客户端是什么。

例如:

    我们访问谷歌,但是由于某些原因,无法直接访问到谷歌。

    我们可以通过连接一台代理服务器,代理服务将我们的请求提交到谷歌,然后再将谷歌的响应反馈给我们。

    对于谷歌而言,它只知道有一个请求过来,但是并不知道是我们在访问它。

1.2 反****向代理

    可以理解为面向服务端的代理,代替服务端接收和返回客户端的请求,客户端不知道实际为它提供服务的服务端。

例如:

    我们访问百度网站,百度内部肯定不是只有一台服务器,它的内部有很多台服务器。

   我们进行访问的时候,因为服务器彼此间session不共享(而资源存放在不同的服务器上),我们在服务器之间访问需要频繁登录。

    此时百度搭建一个过渡服务器,对我们用户不会有任何影响。

    我们只需要登录一次,就可以访问所有,这种情况就是反向代理。

    配置了反向代理后,我们访问百度网站时,实际并不知道百度内部的服务器节点是什么。

    只是访问百度的代理服务器后,代理服务器帮我们转发请求到他们N多的服务器节点中的一个,进行搜索后将结果返回给我们。

    此时代理服务器对我们客户端来说就充当了提供响应的服务器角色,但是对于目标服务器来说,它只是进行了一个请求和转发的功能。

1.3 Nginx优点

高性能

    Nginx采用事件驱动的异步架构,能够处理大量并发连接而不会消耗过多的系统资源。

    它的处理能力比传统的Web服务器更高,在高并发负载下表现出色。

高可靠性

    Nginx具有强大的容错能力和稳定性,能够在面对高流量和DDoS攻击等异常情况下保持可靠运行。

    它能通过健康检查和自动故障转移来保证服务的可用性。

负载均衡

   反向代理服务器可以做负载均衡,根据所有真实服务器的负载情况,将客户端请求分发到不同的真实服务器上。

    也就是说哪个服务器没那么忙,哪个服务器就来响应请求。

静态文件服务

    在访问服务端时,一般会请求一些静态资源,如js、css、图片等;

    这些资源可以在反向代理服务器中进行缓存,减少服务器的压力。

扩展性

    Nginx支持丰富的模块化扩展,可以通过添加第三方模块来提供额外的功能,如gzip压缩、SSL/TLS加密、缓存控制等。

2. Nginx项目准备

2.1. 下载项目

地址:nginx: download

    下载对应安装包,解压后放入本地目录并启动,这里我选择的是:D:\Nginx\nginx-1.25.4

2.2. Nginx相关命令

** **启动Nginx服务:start nginx.exe

** ** 修改配置项后重启Nginx服务:.\nginx.exe -s reload

    停止Nginx服务:.\nginx.exe -s stop       

3. Nginx的基础配置

3.1 nginx.conf

    主要关注
conf/nignx.conf

文件,它是Nginx的配置文件,大致结构如下:

[root@localhost ~]# tree /usr/local/nginx
/usr/local/nginx

├── client_body_temp                 # POST 大文件暂存目录
├── conf                             # Nginx所有配置文件的目录
│   ├── fastcgi.conf                 # fastcgi相关参数的配置文件
│   ├── fastcgi.conf.default         # fastcgi.conf的原始备份文件
│   ├── fastcgi_params               # fastcgi的参数文件
│   ├── fastcgi_params.default      
│   ├── koi-utf
│   ├── koi-win
│   ├── mime.types                   # 媒体类型
│   ├── mime.types.default
│   ├── nginx.conf                   #这是Nginx默认的主配置文件,日常使用和修改的文件
│   ├── nginx.conf.default
│   ├── scgi_params                 # scgi相关参数文件
│   ├── scgi_params.default  
│   ├── uwsgi_params                 # uwsgi相关参数文件
│   ├── uwsgi_params.default
│   └── win-utf
├── fastcgi_temp                     # fastcgi临时数据目录
├── html                             # Nginx默认站点目录
│   ├── 50x.html                     # 错误页面优雅替代显示文件,例如出现502错误时会调用此页面
│   └── index.html                   # 默认的首页文件
├── logs                             # Nginx日志目录
│   ├── access.log                   # 访问日志文件
│   ├── error.log                   # 错误日志文件
│   └── nginx.pid                   # pid文件,Nginx进程启动后,会把所有进程的ID号写到此文件
├── proxy_temp                       # 临时目录
├── sbin                             # Nginx 可执行文件目录
│   └── nginx                       # Nginx 二进制可执行程序
├── scgi_temp                       # 临时目录
└── uwsgi_temp                       # 临时目录
    其中,nginx.conf配置文件内容由一些指令和参数构成,并遵循Nginx一定的语法规则。

    其内容大概如下:
# nginx进程数,一般设置成和CPU个数一样
worker_processes  1;

events {
    # 每个进程允许最大并发数
    worker_connections  1024;
}

http {
    # 引入其他配置,mime.types文件存储的是文件扩展名与类型映射表
    include       mime.types;
    default_type  application/octet-stream;
    
    # 日志格式(使用了变量)
    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;

    keepalive_timeout  65;
    
    # 服务器配置
    server {
        listen       8003;
        server_name  localhost;
        # 设置根路径
        root   html/dist;
        # 设置默认首页
        index  index.html index.htm;
        
        # A. 匹配所有以斜杠(/)开头的请求URL
        #(1)即无论客户端请求哪个路径,只要它是从根域名开始,那么这个location指令就会被触发
        #(2)然而,最终触发的究竟是不是此location,还要看有没有其他优先级比它高的location
        location / {
            # root   html/dist;
            # index  index.html index.htm;
            try_files $uri $uri/ /index.html;
            add_header Cache-Control 'public,max-age=3600';
        }
        
        # B. 正则匹配/index.html:如访问:127.0.0.1:8083/index.html
        location ~* /index.html* {
            add_header Cache-Control 'no-cache, max-age=1'; 
            # 备注:
            # (1)若只加add_header,但本location内不配置root和index且server下也没配置root和index
            # 则add_header配置不生效,并且它也不如你所愿去找location /下的root路径
            # (location和location是独立的)
            # (2)目前看来:它会走到html目录下的index.html.
            # 这是因为root指令,它的默认值是Nginx安装目录下的html子目录
            # index指令,其中一个默认值就是index.html(当然,不止这一个)
        }
        
        # C. 精准匹配/vod/aa.html:如访问127.0.0.1:8083/vod/aa.html
        location = /vod/aa.html {
            add_header Cache-Control 'no-cache, no-store';
        }

        # D. 正则匹配/cc.html:如访问:127.0.0.1:8083/cc.html
        location ~* /cc.html { 
            # location内部的root优先级高于外部server的root
            root   html/dist/vod;
            # 以下index配置失效
            # 不管index配置了什么文件,Nginx只会直接去/html/dist/vod目录下找cc.html文件
            index  ee.html;  
            add_header Cache-Control 'public, max-age=3600';
            # always只是表明这个头部将在所有响应中发送,实际X-Frame-Options参数值是SAMEORIGIN
            add_header X-Frame-Options 'SAMEORIGIN' always;
        }
        
        # E. 正则匹配/ee.html:如访问:127.0.0.1:8083/ee.html. 
        # (1)该访问不会生效,因为在/html/dist目录下并没有ee.html文件
        # (2)但由于配置了try_files字段
        #    将会将(1)中访问不到的资源重定向到html/dist目录下的index.html文件
        location ~* /ee.html { 
            root   html/dist;
            try_files $uri $uri/ /index.html;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

}

3.2 html目录

html

目录通常是Nginx默认的网站根目录

   在没有指定其他文档作为根目录的情况下(例如用root指定),Nginx会将
html

目录作为HTTP请求时查找文件的根路径。

    以下介绍
html

目录下的

index.html

文件和

dist

目录。

3.2.1 index.html

html/index.html

是Ngix默认生成的文件,通常用作网站的默认首页。

例如:

    有一个
index.html

文件放在Nginx的

html

目录中,那么当用户访问网站的根路径(例如

http://yourdomain.com/

)时,Nginx会去

html

目录中寻找

index.html

文件。

    实际情况中,通常会在
nignx.conf

文件,通过配置root和index去指定需要默认展示的首页。

    如2.1中配置root和index,指定
html/
dist

目录下的

index.html

index.htm

文件作为首页。

root   html/dist;
index  index.html index.htm;

3.2.2 dist目录

dist

目录是通过前端打包生成的,将

dist

目录部署到Nginx服务器上前端写的页面才会生效。

dist

存放的位置没有特别限制,一般放在

html

目录下。

4. nginx指令

    实际上,这里只介绍一些常用的概念,其余的在需要的时候查Nginx文档即可。

    地址:Nginx中文文档

4.1. $uri

   $uri是一个内置变量,它代表请求的uri部分,但不包括查询字符串(即?及其后面的部分)。

    注意:这与$request_uri不同,$request_uri包含整个请求的URI,包括查询字符串。

例如

    请求的URI是/example/page?param=value,$uri变量的值将是/example/page。

    当Nginx处理一个请求时,它会根据请求的uri查找对应的location块,每个location块可以有不同的配置指令,用于指定如何处理请求。

   

4.2. location的root,alias,index

4.2.1. alias

     alias指替代的目录,替换了location的uri使用。

    按照如下配置,访问/img/目录里面的文件时,ningx会去/var/www/image/目录下找文件。
location /img/ {
   alias /var/www/image/;
}

4.2.2. root

    root指根目录,和uri拼接使用。   

    注意,alias配置的值后面必须要用“/”结束,root配置的值后面的“/”可有可无。    

    按照如下配置,访问/img/目录里面的文件时,nginx会去/var/www/image/img/目录下找文件。
location /img/ {
   root /var/www/image;
}

4.2.3. index

    如果 index.htm 文件存在,则直接发起“内部跳转”到 /index.htm 这个新的地址;

    如果 index.htm 文件不存在,则继续检查 index.html 是否存在;

    如果 index.html 存在,同样发起“内部跳转”到/index.html;

    如果 index.html 文件仍然不存在,则放弃处理权给 content 阶段的下一个模块。
 location / {
    root /var/www/;
    index index.htm index.html;
 }

4.3 lcoation的try_files

    语法:**格式1**:try_files file ... uri 

               **格式2**:try_files file ... = code

例如:

    try_files $uri $uri/ /index.html的查找过程如下:

    (1)首先在匹配到该location时会按照按【指定查找路径的顺序】查找存在的文件,并使用第一个找到的文件进行请求处理。注意查找路径都是按照root或alias参数指定的值作为根路径来查找的。

    (2)try_files的选项则定义了【查找路径的顺序】,详见下例。

    (3)如果按照顺序均未匹配到对应的文件,则try_files的最后一个参数开始生效,它会进行内部重定向到最后一个参数指定的uri,重新进行新的location匹配。

备注:

    只有最后一个参数可以引起一个内部重定向,之前的参数只设置内部uri的指向;

    最后一个参数是回退uri且必须存在,否则会出现内部500错误;

    如果是(格式2),若最后一个参数是 = 404 ,若给出的file都没有匹配到,则最后返回404的响应码。

实例:

location  /  {
    root   /home/nx/dist;
    try_files $uri $uri/ /index.php?$query_string
}
    (1)当用户请求 http://localhost/example 时,这里的 $uri 就是 /example,try_files会到root对应的目录下(在本例中指/home/nx/dist,以下用/$root代替)寻找这个文件。

    (2)如果/$root目录下存在example 文件,即/$root/example(其中 $root 是项目代码安装目录),则直接把这个文件的内容发送给用户。

    (3)如果/$root目录下没有叫 example 的文件,此时看try_files 的第二个选项$uri/,相比第一个选项$uri增加了一个/,也就是让你去看有没有名为 /$root/example/的目录,去/$root/example/目录下去寻找文件example。

    (4)如果仍然找不到,此时try_files 的最后一个选项 /index.php,发起一个内部“子请求”(可以理解为内部重定向),也就是相当于 nginx 发起一个HTTP请求到 http://localhost/index.php。

4.4. location匹配规则****

一文彻底读懂nginx中的location指令 - 知乎 (zhihu.com)

5. Nginx功能配置

5.1. 缓存配置

    前端经常有一些图片,还有其他静态资源文件是基本不会发生变化的。

    对于这类不会发生改动的静态资源,可以选择把他们缓存到本地,防止每次请求都要去服务器上拉取,耗费时间和服务器带宽。

    以下看如何使用nginx配置缓存。
server {
​
  ...

  location / {
    root  /root/www/website/dist;
    index   index.html      index.htm;
​    # 匹配静态资源的文件后缀
    location ~ .*.(?:jpg|jpeg|png|svg)$ { 
      # 7天后过期
      expires   7d; 
    }
  }
​
  ...
}
    上面的配置是对一些图片资源进行的缓存配置,缓存时间为7天。

    修改好重启后刷新页面,找到关于图片资源的请求,然后就会发现请求第二次的时候就会从本地缓存中获取,并且响应头显示缓存过期时间是7天后。

这是对图片的缓存,其他资源文件也是同理。

5.2. 跨域配置

    跨域是开发过程中或者面试过程中经常会碰到的问题,一般会回答jsonp或者服务端加响应头等方式,除此之外nginx也可以配置跨域。

    下面就是常见的跨域配置:
server {
​
  ...
​  # 表示允许所有域名域跨域调用
  add_header Access-Control-Allow-Origin *;
  # 表示允许所有请求方法跨域
  add_header Access-Control-Allow-Methods *; 
  # 检查请求的类型是不是预检命令
  if ($request_method = OPTIONS) { 
    return 200;
  }
​
  location / {
    root  /root/www/website/dist;
    index   index.html      index.htm;
​
  }
​
  ...
}

5.3. gzip压缩配置

    如果存在静态资源过大,可能会导致服务端响应过慢。

    尽管为静态资源配置了缓存,但是如果是第一次获取资源仍然是没有缓存的,只能从服务器上拿。

    这个时候可以考虑开启gzip压缩,节省服务器的带宽。
server {
​
  ...
​
  # 开启gzip压缩,同理,关闭为off
  gzip on;
  # 压缩的级别,一般取2-6,级别越高,压缩的越小,但越耗费服务器的cpu
  gzip_comp_level 6;
  # 超过1K的文件才进行压缩
  gzip_min_length 1k;
  # 文件类型
  gzip_types image/png image/jpeg image/gif image/svg+xml;
  # 在响应头中添加 Vary
  gzip_vary on;
​
  location / {
    root  /root/www/website/dist;
    index   index.html      index.htm;
  }
​
  ...
}

修改好后重启,打开页面,开启前这个logo的svg文件大小为1.9k:

开启gzip后,大小变为1.2k:

并且响应头上也有gzip的标识了:

5.4. 单页面应用刷新404问题

    通过如下配置,若刷新后页面消失则自动重定向到index.html(前面说过,这个一般首页)
location / {
   try_files $uri $uri/ /index.html;
}
标签: nginx 服务器 前端

本文转载自: https://blog.csdn.net/AM1n98/article/details/136655867
版权归原作者 Am1nnn 所有, 如有侵权,请联系我们删除。

“Nginx的指令及基础配置”的评论:

还没有评论