Nginx常用配置及和基本功能讲解
作者:京东物流 殷世杰
Nginx已经广泛应用于J-one和Jdos的用配环境部署上 ,本文对Nginx的置及常用的配置和基本功能进行讲解,适合Ngnix入门学习。和基
1 核心配置
找到Nginx安装目录下的本功conf目录下nginx.conf文件 ,Nginx的用配基本功能配置是由它提供的。
1.1 配置文件结构
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.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.32.33.34.35.36.37.38.39.40.41.42.43.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 [匹配成功] }1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.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;1.2.3.4.5.6.7.8.9.10.11.12.13.14.当我们访问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; }1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.3.2.2 热备