0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Nginx常用的配置和基本功能讲解

OSC开源社区 来源:OSCHINA 社区 2023-05-04 10:25 次阅读

1 核心配置

找到 Nginx 安装目录下的 conf 目录下 nginx.conf 文件,Nginx 的基本功能配置是由它提供的。 Nginx 的配置文件 (conf/nginx.conf) 整体上分为如下几个部分::

全局块 配置和 Nginx 运行相关的全局配置
events 块 配置和网络链接相关的配置
http 块 配置代理、缓存、日志记录、虚拟主机等配置
server 块 配置虚拟主机的相关参数,一个 http 快中可以有多个 server 块
location 块 配置请求的路由,以及各种页面的处理情况
区域 职责

1.2 配置文件示例

一个比较全的配置文件示例如下。

# 以下是全局段配置
#user administrator administrators;  #配置用户或者组,默认为nobody nobody。
#worker_processes 2;  #设置进程数,默认为1
#pid /nginx/pid/nginx.pid; #指定nginx进程运行文件存放地址
error_log log/error.log debug;  #制定日志路径,级别:debug|info|notice|warn|error|crit|alert|emerg
# events段配置信息
events {
    accept_mutex on;   #设置网路连接序列化,防止惊群现象发生,默认为on
    multi_accept on;  #设置一个进程是否同时接受多个网络连接,默认为off
    #use epoll;      #事件驱动模型,select|poll|kqueue|epoll|resig|/dev/poll|eventport
    worker_connections  1024;    #最大连接数,默认为512
}
# http、配置请求信息
http {
    include       mime.types;   #文件扩展名与文件类型映射表
    default_type  application/octet-stream; #默认文件类型,默认为text/plain
    #access_log off; #取消服务日志    
    log_format myFormat '$remote_addr–$remote_user [$time_local] $request $status $body_bytes_sent $http_referer $http_user_agent $http_x_forwarded_for'; #自定义格式
    access_log log/access.log myFormat;  #combined为日志格式的默认值
    sendfile on;   #允许sendfile方式传输文件,默认为off,可以在http块,server块,location块。
    sendfile_max_chunk 100k;  #每个进程每次调用传输数量不能大于设定的值,默认为0,即不设上限。
    keepalive_timeout 65;  #连接超时时间,默认为75s,可以在http,server,location块。


    upstream mysvr {   
      server 127.0.0.1:7878;
      server 192.168.10.121:3333 backup;  #热备
    }
    error_page 404 https://www.baidu.com; #错误页
    # 第一个Server区块开始,表示一个独立的虚拟主机站点
    server {
        keepalive_requests 120; #单连接请求上限次数。
        listen       4545;   #监听端口
        server_name  127.0.0.1;   #监听地址       
        location  ~*^.+$ {       #请求的url过滤,正则匹配,~为区分大小写,~*为不区分大小写。
           #root path;  #根目录
           #index vv.txt;  #设置默认页
           proxy_pass  http://mysvr;  #请求转向mysvr 定义的服务器列表
           deny 127.0.0.1;  #拒绝的ip
           allow 172.18.5.54; #允许的ip           
        } 
    }
}

1.3 locat 路径映射讲解

1.3.1 格式:

location [ = | ~ | ~* | !~ | !~* | @ ] uri {...}

1.3.2 解释:

= 表示精确匹配,如果找到,立即停止搜索并立即处理此请求。 ~ 表示执行一个正则匹配,区分大小写匹配 ~* 表示执行一个正则匹配,不区分大小写匹配 !~ 区分大小写不匹配 !~* 不区分大小写不匹配 ^~ 即表示只匹配普通字符(空格)。使用前缀匹配,^ 表示 “非”,即不查询正则表达式。如果匹配成功,则不再匹配其他 location。 @ 指定一个命名的 location,一般只用于内部重定向请求。例如 error_page, try_files uri 是待匹配的请求字符串,可以不包含正则表达式,也可以包含正则表达式;

1.3.3 优先级和示例:

[不加] < [~/~*] < [^~] < [=]

示例如下:

location = / {
    # 精确匹配/,主机名后面不能带任何字符串 /
    # 只匹配http://abc.com
    # http://abc.com [匹配成功]
    # http://abc.com/index [匹配失败]
}
location ^~ /img/ {
      #以 /img/ 开头的请求,都会匹配上
    #http://abc.com/img/a.jpg   [成功]
    #http://abc.com/img/b.mp4  [成功]
    }
location ~* /Example/ {
  # 则会忽略 uri 部分的大小写
  #http://abc.com/test/Example/ [匹配成功]
  #http://abc.com/example/ [匹配成功]
}
location /documents {
    # 如果有正则表达式可以匹配,则优先匹配正则表达式。
    #http://abc.com/documentsabc [匹配成功]
}
location / {
    #http://abc.com/abc [匹配成功]
}

2 反向代理

2.1 反向代理概念:

反向代理 (Reverse Proxy) 是指以代理服务器来接受 internet 上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给 internet 上请求连接的客户端。真实的服务器不能直接被外部网络访问,所以需要一台代理服务器,而代理服务器能被外部网络访问的同时又跟真实服务器在同一个网络环境,当然也可能是同一台服务器,端口不同而已。 反向代理通过 proxy_pass 指令来实现。

2.2 反向代理示例:

server {
    listen       80;
    server_name  localhost;


    location / {
         proxy_pass http://localhost:8081;
         proxy_set_header Host $host:$server_port;#为请求头添加Host字段,用于指定请求服务器的域名/IP地址和端口号。


         # 设置用户ip地址
         proxy_set_header X-Forwarded-For $remote_addr;#为请求头添加XFF字段,值为客户端的IP地址。
         # 当请求服务器出错去寻找其他服务器
         proxy_next_upstream error timeout invalid_header http_500 http_502 http_503;
    

当我们访问 localhost 的时候,ngnix 就将我们的请求转到 localhost:8081 了

3 负载均衡

3.1 负载均衡概念:

当有 2 台或以上服务器时,代理服务器根据规则将请求分发到指定的服务器上处理。

3.2 负载均衡策略及示例:

Nginx 目前支持多种负载均衡策略,这里讲解常用的 6 种。

3.2.1RR (round robin : 轮询 默认):

每个请求按时间顺序逐一分配到不同的后端服务器,也就是说第一次请求分配到第一台服务器上,第二次请求分配到第二台服务器上,如果只有两台服务器,第三次请求继续分配到第一台上,这样循环轮询下去,也就是服务器接收请求的比例是 1:1, 如果后端服务器 down 掉,能自动剔除。轮询是默认配置,不需要太多的配置

同一个项目分别使用 8081 和 8082 端口启动项目

upstream web_servers {
   server localhost:8081;
   server localhost:8082;
}




server {
    listen       80;
    server_name  localhost;
    #access_log  logs/host.access.log  main;
    location / {
        proxy_pass http://web_servers;
        proxy_set_header Host $host:$server_port;
    }
 

3.2.2 热备:

假设有 2 台服务器,当一台服务器发生事故时,才启用第二台服务器给提供服务。服务器处理请求的顺序:AAAAAA 突然 A 挂了,服务器处理请求的顺序:BBBBBBBBBBBBBB.....

upstream web_servers {
      server 127.0.0.1:7878; 
      server 192.168.10.121:3333 backup;  #热备     
    }

3.2.3 权重

跟据配置的权重的大小而分发给不同服务器不同数量的请求。如果不设置,则默认为 1。下面服务器的请求顺序为:ABBABBABBABBABB....。

upstream web_servers {
    server localhost:8081 weight=1;
    server localhost:8082 weight=2;
}

3.2.4 ip_hash

这样每个 ip 地址固定访问一个后端服务器,可以解决 session 的问题。

upstream test {
    ip_hash;
    server localhost:8080;
    server localhost:8081;
}

3.2.5 fair (第三方)

按后端服务器的响应时间来分配请求,响应时间短的优先分配。这个配置是为了更快的给用户响应。

upstream backend {
    fair;
    server localhost:8080;
    server localhost:8081;
}

3.2.6 url_hash (第三方)

按访问 url 的 hash 结果来分配请求,使每个 url 定向到同一个后端服务器,后端服务器为缓存时比较有效。在 upstream 中加入 hash 语句,hash_method 是使用的 hash 算法

upstream backend {
    hash_method crc32;
    hash $request_uri;
    server localhost:8080;
    server localhost:8081;
}

以上 6 种负载均衡各自适用不同情况下单独或者混合使用,可以根据实际情况选择使用,fair 和 url_hash 需要安装第三方模块才能使用。

4 动静分离

4.1 动静分离概念:

动静分离是指在 web 服务器架构中,将静态页面与动态页面或者静态内容接口和动态内容接口分开不同系统访问的架构设计方法,进而提升整个服务访问性能和可维护性。

4.2 动静分离示例:

upstream web_servers {
       server localhost:8081;
       server localhost:8082;
}
server {
    listen       80;
    server_name  localhost;
    set $doc_root /usr/local/var/www;


    location ~* .(gif|jpg|jpeg|png|bmp|ico|swf|css|js)$ {
       root $doc_root/img;
    }
    location / {
        proxy_pass http://web_servers;
        proxy_set_header Host $host:$server_port;
    }
    error_page 500 502 503 504  /50x.html;  #出现 500 502 503 504错误时走内部跳转
    location = /50x.html { 
        root $doc_root;
    }
 }

结果:访问 http://localhost/test.jpg 时直接返回 /usr/local/var/www/img 路径下的图片. 访问 http://localhost/index.html 就会访问后端服务器 (tomcat 等)

5 其他常用的指令:

5.1.return 指令

返回 http 状态码和可选的第二个参数可以是重定向的 URL

return code [text];
return code URL;
return URL;
例如:
location / {
 return 404; # 直接返回状态码
}
location / {
 return 404 "pages not found"; # 返回状态码 + 一段文本
}
location / {
 return 302 /bbs ; # 返回状态码 + 重定向地址
}
location / {
 return https://www.baidu.com ; # 返回重定向地址
}

5.2 rewrite 指令

重写 URI 请求 rewrite,通过使用 rewrite 指令在请求处理期间多次修改请求 URI,该指令具有一个可选参数和两个必需参数。 第一个 (必需) 参数是请求 URI 必须匹配的正则表达式。 第二个参数是用于替换匹配 URI 的 URI。 可选的第三个参数重写策略

last 重写后的 URL 发起新请求,再次进入 server 段,重试 location 的中的匹配;

break 直接使用重写后的 URL ,不再匹配其它 location 中语句;

redirect 返回 302 临时重定向;

permanent 返回 301 永久重定向;

location /users/ {
    rewrite ^/users/(.*)$ /show?user=$1 break;
}

5.3 error_page 指令

使用 error_page 指令,您可以配置 NGINX 返回自定义页面以及错误代码,替换响应中的其他错误代码,或将浏览器重定向到其他 URI。在以下示例中,error_page 指令指定要返回 404 页面错误代码的页面 (/404.html)。

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

5.4 日志

访问日志:需要开启压缩 gzip on; 否则不生成日志文件,打开 log_format、access_log 注释

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  /usr/local/etc/nginx/logs/host.access.log  main;




gzip 

5.5 deny 、allow 指令

#禁止访问某个目录
location / {
    allow 192.168.0.0;
    allow 127.0.0.1;
    deny all;
#这段配置值允许192.168.0./24网段和127.0.0.1的请求,其他来源IP全部拒绝。
}



5.6 内置变量

nginx 的配置文件中可以使用的内置变量以美元符 $ 开始。其中,大部分预定义的变量的值由客户端发送携带。

$args :# 这个变量等于请求行中的参数,同 $query_string

$content_length :请求头中的 Content-length 字段。

$content_type :请求头中的 Content-Type 字段。

$document_root :当前请求在 root 指令中指定的值。

$host :请求行的主机名,为空则为请求头字段 Host 中的主机名,再为空则与请求匹配的 server_name

$http_user_agent :客户端 agent 信息

$http_cookie :客户端 cookie 信息

$limit_rate :这个变量可以限制连接速率。

$request_method :客户端请求的动作,通常为 GET 或 POST。

$remote_addr :客户端的 IP 地址。

$remote_port :客户端的端口。

$remote_user :已经经过 Auth Basic Module 验证的用户名。

$request_filename :当前请求的文件路径,由 root 或 alias 指令与 URI 请求生成。

$scheme :HTTP 方法(如 http,https)。

$server_protocol :请求使用的协议,通常是 HTTP/1.0 或 HTTP/1.1。

$server_addr :服务器地址,在完成一次系统调用后可以确定这个值。

$server_name :服务器名称。

$server_port :请求到达服务器的端口号。

$request_uri :包含请求参数的原始 URI,不包含主机名,如:”/foo/bar.php?arg=baz”。

$uri :不带请求参数的当前 URI,$uri 不包含主机名,如”/foo/bar.html”。

$document_uri :与 $uri 相同

6 总结

Ngnix 是一款高性能反向代理服务器,学习它非常有必要,本文讲解了 Ngnix 核心配置,介绍了反向代理,负载均衡,动静分离三大功能,最后扩展了一些常用的指令。本文介绍了 Ngnix 的基础用法,后续的 Ngnix 内核以及原理部分有待研究。




审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • HTTP协议
    +关注

    关注

    0

    文章

    54

    浏览量

    9638
  • Hash算法
    +关注

    关注

    0

    文章

    43

    浏览量

    7362
  • nginx
    +关注

    关注

    0

    文章

    135

    浏览量

    11986

原文标题:Nginx常用配置及和基本功能讲解

文章出处:【微信号:OSC开源社区,微信公众号:OSC开源社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    MGMF292L1G8-MINAS A6NL系列 (RTEX) 技术资料 -基本功能规格篇- 松下

    电子发烧友网为你提供Panasonic(Panasonic)MGMF292L1G8-MINAS A6NL系列 (RTEX) 技术资料 -基本功能规格篇-相关产品参数、数据手册,更有
    发表于 04-26 19:01
    MGMF292L1G8-MINAS A6NL系列 (RTEX) 技术资料 -<b class='flag-5'>基本功能</b>规格篇- 松下

    MGMF292L1G8-MINAS A6S 系列 技术资料 -基本功能规格篇- 松下

    电子发烧友网为你提供Panasonic(Panasonic)MGMF292L1G8-MINAS A6S 系列 技术资料 -基本功能规格篇-相关产品参数、数据手册,更有
    发表于 04-26 18:56
    MGMF292L1G8-MINAS A6S 系列 技术资料 -<b class='flag-5'>基本功能</b>规格篇- 松下

    MGMF292L1G6M-MINAS A6B 系列 (EtherCAT) 技术资料 -基本功能规格篇- 松下

    电子发烧友网为你提供Panasonic(Panasonic)MGMF292L1G6M-MINAS A6B 系列 (EtherCAT) 技术资料 -基本功能规格篇-相关产品参数、数据手册,更有
    发表于 04-26 18:31
    MGMF292L1G6M-MINAS A6B 系列 (EtherCAT)  技术资料 -<b class='flag-5'>基本功能</b>规格篇- 松下

    MGMF292L1G6-MINAS A6BU 系列 技术资料 -基本功能规格篇- 松下

    电子发烧友网为你提供Panasonic(Panasonic)MGMF292L1G6-MINAS A6BU 系列 技术资料 -基本功能规格篇-相关产品参数、数据手册,更有
    发表于 04-25 19:17
    MGMF292L1G6-MINAS A6BU 系列 技术资料 -<b class='flag-5'>基本功能</b>规格篇- 松下

    MGMF292L1G5-MINAS A6B 系列 (EtherCAT) 技术资料 -基本功能规格篇- 松下

    电子发烧友网为你提供Panasonic(Panasonic)MGMF292L1G5-MINAS A6B 系列 (EtherCAT) 技术资料 -基本功能规格篇-相关产品参数、数据手册,更有
    发表于 04-25 18:55
    MGMF292L1G5-MINAS A6B 系列 (EtherCAT)  技术资料 -<b class='flag-5'>基本功能</b>规格篇- 松下

    简述GDB调试器提供的基本功能

    GDB是一个功能强大的源代码级调试工具,它提供了多种基本功能,帮助程序员** **更好地理解程序的运行机制和定位问题** **。
    的头像 发表于 01-28 17:44 748次阅读

    钽电容器的基本功能与结构

    钽电容器的基本功能与结构
    的头像 发表于 12-08 17:28 373次阅读
    钽电容器的<b class='flag-5'>基本功能</b>与结构

    JavaScript的语法和基本功能

    的语法和基本功能。JavaScript可以在网页中实现交互和动态效果,为用户提供更好的使用体验。 JavaScript最早由网景公司(Netscape)的布兰登·艾奇(Brendan Eich
    的头像 发表于 12-03 11:15 290次阅读

    直流稳压稳流电源基本功能 电源使用注意事项

    直流稳压稳流电源基本功能 电源使用注意事项  直流稳压稳流电源是一种常用的电源设备,用于提供直流电能以满足各种电子设备的供电需求。它具有稳定输出电压和电流的特点,能够保证电子设备稳定、安全地工作
    的头像 发表于 11-16 14:27 832次阅读

    Nginx常用配置与命令

    对于前端来说 Node.js 并不陌生, Nginx 和 Node.js 的很多理念类似, HTTP 服务器、事件驱动、异步非阻塞等,且 Nginx 的大部分功能使用 Node.js 也可以实现,但
    发表于 10-18 10:04 161次阅读
    <b class='flag-5'>Nginx</b><b class='flag-5'>常用</b><b class='flag-5'>配置</b>与命令

    IC元器件的基本功能

    IC元器件(集成电路元器件)是一种将多个电子元件(如晶体管、二极管、电阻、电容等)集成在一块半导体芯片上的电子元件。它具有多种基本功能
    的头像 发表于 10-16 14:30 531次阅读

    混合器的基本功能和应用领域

    混合器作为一种电子器件,主要具备以下几个基本功能
    的头像 发表于 10-16 14:25 422次阅读

    视频矩阵切换器的基本功能和要求是什么

    视频矩阵切换器是一种用于管理和切换多个视频信号源的设备。它的基本功能是允许用户选择并切换不同的视频源,将其发送到一个或多个显示设备上。以下是视频矩阵切换器的基本功能和要求。
    发表于 09-14 15:37 651次阅读

    Nginx的特点和作用 Nginx常用命令和核心配置

    热更新。性能是 Nginx 最重要的考量,其占用内存少、并发能力强、能支持高达 5w 个并发连接数,最重要的是, Nginx 是免费的并可以商业化,配置使用也比较简单。
    的头像 发表于 09-01 09:53 362次阅读
    <b class='flag-5'>Nginx</b>的特点和作用 <b class='flag-5'>Nginx</b><b class='flag-5'>常用</b>命令和核心<b class='flag-5'>配置</b>

    机器视觉的基本功能包括哪些?

    机器视觉的基本功能包括哪些? 机器视觉是一种计算机技术,它主要以数字图像处理技术为基础,利用摄像机等设备获取图像,然后通过图像处理算法对图像进行分析和处理,以实现对图像中信息的检测、识别、分类、跟踪
    的头像 发表于 08-09 16:48 1061次阅读