点击在线浏览,体验更好链接
古代JavaScript高级小册链接
深入浅出Dart链接
古代TypeScript高级小册链接
linwu的算法笔记链接

nginx.conf配置

找到Nginx的装置目录下的nginx.conf文件,该文件负责Nginx的根底性能配置。

配置文件概述

Nginx的主配置文件(conf/nginx.conf)按以下构造组织:

配置块性能形容
全局块与Nginx运行相干的全局设置
events块与网络连接无关的设置
http块代理、缓存、日志、虚拟主机等的配置
server块虚拟主机的参数设置(一个http块可蕴含多个server块)
location块定义申请路由及页面解决形式

配置文件示例

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

# 全局段配置# ------------------------------# 指定运行nginx的用户或用户组,默认为nobody。#user administrator administrators;# 设置工作过程数,通常设置为等于CPU外围数。#worker_processes 2;# 指定nginx过程的PID文件寄存地位。#pid /nginx/pid/nginx.pid;# 指定谬误日志的寄存门路和日志级别。error_log log/error.log debug;# events段配置信息# ------------------------------events {    # 设置网络连接序列化,用于避免多个过程同时承受到新连贯的状况,这种状况称为"惊群"。    accept_mutex on;    # 设置一个过程是否能够同时承受多个新连贯。    multi_accept on;    # 设置工作过程的最大连接数。    worker_connections  1024;}# http配置段,用于配置HTTP服务器的参数。# ------------------------------http {    # 蕴含文件扩展名与MIME类型的映射。    include       mime.types;    # 设置默认的MIME类型。    default_type  application/octet-stream;    # 定义日志格局。    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;    # 容许应用sendfile形式传输文件。    sendfile on;    # 限度每次调用sendfile传输的数据量。    sendfile_max_chunk 100k;    # 设置连贯的放弃工夫。    keepalive_timeout 65;    # 定义一个上游服务器组。    upstream mysvr {         server 127.0.0.1:7878;      server 192.168.10.121:3333 backup;  #此服务器为备份服务器。    }    # 定义谬误页面的重定向地址。    error_page 404 https://www.baidu.com;    # 定义一个虚拟主机。    server {        # 设置单个连贯上的最大申请次数。        keepalive_requests 120;        # 设置监听的端口和地址。        listen       4545;        server_name  127.0.0.1;        # 定义location块,用于匹配特定的申请URI。        location  ~*^.+$ {           # 设置申请的根目录。           #root path;           # 设置默认页面。           #index vv.txt;           # 将申请转发到上游服务器组。           proxy_pass  http://mysvr;           # 定义访问控制规定。           deny 127.0.0.1;           allow 172.18.5.54;                  }     }}

location 门路映射详解

格局:

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

各标识解释:

  • =:准确匹配。如果匹配胜利,立刻进行搜寻并解决此申请。
  • ~:执行正则匹配,辨别大小写。
  • ~*:执行正则匹配,不辨别大小写。
  • !~:正则匹配,辨别大小写不匹配。
  • !~*:正则匹配,不辨别大小写不匹配。
  • ^~:前缀匹配。如果匹配胜利,不再匹配其余location,且不查问正则表达式。
  • @:指定命名的location,次要用于外部重定向申请,如 error_pagetry_files
  • uri:待匹配的申请字符串。能够是一般字符串或蕴含正则表达式。

优先级及示例

优先级程序:无特定标识 < ^~ < = < 正则匹配 (~, ~*, !~, !~*)

示例:

location = / {    # 准确匹配 /,主机名前面不能带任何字符串    # 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 [匹配胜利]}

反向代理

反向代理是Nginx的外围性能之一,容许Nginx将来自客户端的申请转发到后端服务器,并将后端服务器的响应返回给客户端,使客户端感觉就像是间接与后端服务器通信一样。

根本配置

要配置Nginx作为反向代理,您须要应用location块中的proxy_pass指令:

location /some/path/ {    proxy_pass http://your_backend_address;}

罕用指令

  • proxy_pass:定义后端服务器的地址。
  • proxy_set_header:批改从客户端传递到代理服务器的申请头。
  • proxy_hide_header:暗藏从代理服务器返回的响应头。
  • proxy_redirect:批改从代理服务器返回的响应头中的LocationRefresh头字段。

示例配置

server {    listen 80;    server_name example.com;    location / {        proxy_pass http://localhost:8080;        proxy_set_header Host $host;        proxy_set_header X-Real-IP $remote_addr;        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;    }}

在此配置中,所有发送到example.com的申请都会被代理到localhost:8080

注意事项

  1. 当应用proxy_pass指令时,确保后端服务器是可用的,否则Nginx将返回谬误。
  2. 应用proxy_set_header确保后端服务器接管到正确的申请头。
  3. 如果后端服务器和Nginx在不同的机器上,确保网络连接是稳固的。

反向代理不仅能够进步网站的性能和可靠性,还能够用于负载平衡、缓存动态内容、保护和平安等多种用处。

负载平衡

当有多台服务器时,代理服务器依据规定将申请散发到指定的服务器上解决。

策略名称形容示例
RR (round robin)默认的负载平衡办法,按工夫程序逐个调配到不同的后端服务器upstream web_servers { server localhost:8081; server localhost:8082; }
热备当主服务器产生故障时,才将流量转发到备用服务器upstream web_servers { server 127.0.0.1:7878; server 192.168.10.121:3333 backup; }
权重依据预设权重调配申请,权重越高的服务器接管的申请越多upstream web_servers { server localhost:8081 weight=1; server localhost:8082 weight=2; }
ip_hash依据客户端IP地址的hash后果调配申请,确保特定客户端IP的申请总是发给同一个后端服务器upstream test { ip_hash; server localhost:8080; server localhost:8081; }
fair (第三方)依据后端服务器的响应工夫调配申请,响应工夫短的优先调配upstream backend { fair; server localhost:8080; server localhost:8081; }
url_hash (第三方)依据申请的URL的hash后果调配申请,确保同一个URL的申请总是发给同一个后端服务器upstream backend { hash_method crc32; hash $request_uri; server localhost:8080; server localhost:8081; }

这些负载平衡策略能够依据理论利用场景和需要进行抉择和组合应用。

配置动静拆散

动静拆散是一种常见的Web服务器优化策略,次要是为了进步服务器的响应速度和加重服务器的压力。在Nginx中,动静拆散非常容易实现。

动静拆散的基本概念:

动静拆散是指将动静内容和动态内容离开解决。动态内容通常包含:图片、CSS、JavaScript、HTML文件等,这些内容不须要常常更改。而动静内容则是常常变动的,如:PHP、ASP、JSP、Servlet等生成的内容。

Nginx配置动静拆散

  1. 间接为动态内容设置一个别名或根目录
location ~* .(jpg|jpeg|png|gif|ico|css|js)$ {    root /path/to/static/files;    expires 30d;  # 设置缓存工夫}

在上述配置中,所有的动态文件都被寄存在/path/to/static/files目录下。expires指令设置了动态文件的缓存工夫。

  1. 应用alias别名

如果你的动态文件不在我的项目的主目录下,你能够应用alias来指定动态文件的理论门路。

location /static/ {    alias /path/to/static/files/;}

在这个配置中,URL中的/static/会映射到文件系统的/path/to/static/files/

  1. 代理动静内容

对于动静内容,你可能须要将申请代理到后端的应用服务器,如Tomcat、uWSGI等。

location / {    proxy_pass http://backend_server_address;    proxy_set_header Host $host;    proxy_set_header X-Real-IP $remote_addr;}

注意事项

  • 确保你的动态文件门路配置正确,防止404谬误。
  • 应用expires指令为动态内容设置缓存,这能够缩小服务器的负载并进步页面加载速度。
  • 动静拆散不仅能够进步服务器的响应速度,还能够缩小后端服务器的压力,因为动态文件通常由Nginx间接解决,而不须要代理到后端服务器。

动态资源优化

为了进步动态资源的传输效率,Nginx提供了以下三个次要的优化指令:

  • sendfile
  • tcp_nopush
  • tcp_nodelay

sendfile 指令

sendfile 用于开启高效的文件传输模式。它通过调用零碎内核的 sendfile 函数来实现,从而防止了文件的屡次拷贝,同时缩小了用户态和内核态之间的切换,从而进步了动态文件的传输效率。

传统的动态资源申请过程:

  1. 客户端通过网络接口向服务端发送申请。
  2. 操作系统将这些申请传递给服务器端应用程序。
  3. 服务器应用程序解决申请。
  4. 解决实现后,操作系统将解决失去的后果通过网络适配器传递给客户端。

我的项目形容
语法`sendfile onoff`
默认值sendfile off
配置地位http块server块location块

tcp_nopush 和 tcp_nodelay指令

tcp_nopush

sendfile 开启时,tcp_nopush 也能够被启用。它的次要目标是进步网络数据包的传输效率。

我的项目形容
语法`tcp_nopush onoff`
默认值tcp_nopush off
配置地位http块server块location块

tcp_nodelay

只有在 keep-alive 连贯开启时,tcp_nodelay 能力失效。它的目标是进步网络数据包的实时性。

我的项目形容
语法`tcp_nodelay onoff`
默认值tcp_nodelay on
配置地位http块server块location块

tcp_nopush 的工作原理是设置一个缓冲区,当缓冲区满时才进行数据发送,这样能够大大减少网络开销。

动态资源压缩

在数据的传输过程中,为了进一步优化,Nginx引入了gzip模块,用于对传输的资源进行压缩,从而缩小数据的传输体积,进步传输效率。

Nginx中的动态资源压缩能够在http块、server块、location块中配置。波及的次要模块有:

  • ngx_http_gzip_module模块 (内置)
  • ngx_http_gzip_static_module模块
  • ngx_http_gunzip_module模块

Gzip模块配置指令

  1. gzip:开启或敞开gzip性能。

    • 语法:gzip on | off
    • 默认值:gzip off
    • 配置地位:http块,server块,location块
  2. gzip_types:依据响应的MIME类型选择性地开启gzip压缩。

    • 语法:gzip_types mime-type
    • 默认值:gzip_types text/html
    • 配置地位:http块,server块,location块
    • 示例:gzip_types application/javascript
  3. gzip_comp_level:设置Gzip压缩的水平,级别从1-9。

    • 语法:gzip_comp_level level
    • 默认值:gzip_comp_level 1
    • 配置地位:http块,server块,location块
  4. gzip_vary:设置是否携带"Vary:Accept-Encoding"的响应头部。

    • 语法:gzip_vary on|off
    • 默认值:gzip_vary off
    • 配置地位:http块,server块,location块
  5. gzip_buffers:解决申请压缩的缓冲区数量和大小。

    • 语法:gzip buffers number size
    • 默认值:gzip_buffer 32 4k | 16 8K
    • 配置地位:http块,server块,location块
  6. gzip_disable:选择性地开启和敞开gzip性能,基于客户端的浏览器标记。

    • 语法:gzip_disable regex
    • 默认值:gzip_disable -
    • 配置地位:http块,server块,location块
    • 示例:gzip_disable "MSIE [1-6]."
  7. gzip_http_version:针对不同的http协定版本,选择性地开启和敞开gzip性能。

    • 语法:gzip_http_version 1.0 | 1.1
    • 默认值:gzip_http_version 1.1
    • 配置地位:http块,server块,location块
  8. gzip_min_length:依据响应内容的大小决定是否应用gzip性能。

    • 语法:gzip_min_length length
    • 默认值:gzip_min_length 20
    • 配置地位:http块,server块, location块
  9. gzip_proxied:设置是否对nginx服务器对后盾服务器返回的后果进行gzip压缩。

    • 语法:gzip_proxied off | expired | no-cache | no-store | private | no_last_modified | no_etag | auth | any
    • 默认值:gzip_proxied off
    • 配置地位:http块,server块, location块

Gzip与sendfile共存问题

Gzip在应用程序中进行压缩,而sendfile能够间接通过零碎的网络设备发送动态资源文件,绕过应用程序的用户过程。为了解决这两者之间的抵触,Nginx提供了ngx_http_gzip_static_module模块的gzip_static指令。

  • gzip_static:对动态文件进行提前压缩。

    • 语法:gzip_static on|off|always
    • 默认值:gzip_static off
    • 配置地位:http块,server块, location块

通过上述配置,Nginx能够无效地对动态资源进行压缩,进步数据传输效率,同时与sendfile性能共存,确保高效的资源传输。

跨域

跨域资源共享(CORS)是一种安全策略,用于管制哪些网站能够拜访您的资源。当您的前端应用程序和后端API位于不同的域上时,通常会遇到跨域问题。Nginx能够通过设置响应头来帮忙解决这个问题。

location / {    # 其余配置...    # 设置容许来自所有域名申请。如果须要指定域名,将'*'替换为您的域名。    add_header 'Access-Control-Allow-Origin' '*';    # 容许的申请办法。    add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';    # 容许的申请头。    add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range';    # 容许浏览器缓存预检申请的后果,单位为秒。    add_header 'Access-Control-Max-Age' 1728000;    # 容许浏览器在理论申请中携带用户凭证。    add_header 'Access-Control-Allow-Credentials' 'true';    # 设置响应类型为JSON。    add_header 'Content-Type' 'application/json charset=UTF-8';    # 针对OPTIONS申请独自解决,因为预检申请应用OPTIONS办法。    if ($request_method = 'OPTIONS') {        return 204;    }}

留神:在生产环境中,出于平安思考,倡议不要应用 'Access-Control-Allow-Origin' '*',而是指定确切的域名。

防盗链

防盗链是指避免其余网站间接链接到你的网站资源(如图片、视频等),从而耗费你的服务器带宽。Nginx提供了一个十分不便的模块——ngx_http_referer_module,用于实现防盗链性能。

根本的防盗链配置:

location ~ .*.(gif|jpg|jpeg|png|bmp|swf)$ {    valid_referers none blocked www.example.com example.com *.example.net;        if ($invalid_referer) {        return 403;    }}

在上述配置中:

  • valid_referers定义了非法的起源页面。none示意间接拜访,blocked示意没有Referer头的拜访,www.example.comexample.com是非法的起源域名,*.example.net示意example.net的所有子域名都是非法的起源。
  • $invalid_referer变量会在起源不在valid_referers列表中时变为"true"。
  • 如果起源不非法,服务器将返回403禁止拜访的状态码。

应用谬误图片代替原图片:

如果你不想显示403谬误,而是想显示一个谬误图片(例如:“禁止外链”的图片),你能够这样配置:

location ~ .*.(gif|jpg|jpeg|png|bmp|swf)$ {    valid_referers none blocked www.example.com example.com *.example.net;        if ($invalid_referer) {        rewrite ^/.*$ /path/to/error/image.jpg;    }}

在上述配置中,当检测到盗链时,Nginx会重写申请的URL,将其指向一个谬误图片。

注意事项

  • 防盗链配置可能会影响搜索引擎的爬虫,因而在施行防盗链策略时要小心。
  • 如果你的网站应用了CDN,确保CDN的服务器也在valid_referers列表中,否则CDN可能无奈失常工作。
  • 为了确保防盗链配置正确,你应该在生产环境之前在测试环境中进行充沛的测试。

内置变量

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

变量名形容
$args申请行中的参数,同$query_string
$content_length申请头中的Content-length字段
$content_type申请头中的Content-Type字段
$document_root以后申请在root指令中指定的值
$host申请行的主机名,或申请头字段 Host 中的主机名
$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以后申请的文件门路
$schemeHTTP办法(如http,https)
$server_protocol申请应用的协定,如HTTP/1.0或HTTP/1.1
$server_addr服务器地址
$server_name服务器名称
$server_port申请达到服务器的端口号
$request_uri蕴含申请参数的原始URI
$uri不带申请参数的以后URI
$document_uri$uri雷同

这些内置变量为nginx配置提供了极大的灵活性,使得nginx可能依据申请的各种属性进行决策和解决。

小册

整顿两本小册,一本是前端面试小册,一本是图解算法,浏览体验都很好,欢送增加我微信linwu-hi获取