nginx配置详解以及常用配置示例

Nginx配置文件结构

默认的 nginx 配置文件 nginx.conf 内容如下:

...              #全局块

events {
    
             #events块
   ...
}

http      #http块
{
    
    
    ...   #http全局块
    server        #server块
    {
    
     
        ...       #server全局块
        location [PATTERN]   #location块
        {
    
    
            ...
        }
        location [PATTERN] 
        {
    
    
            ...
        }
    }
    server
    {
    
    
      ...
    }
    
    upstream
    {
    
    
      ...
    }
    ...     #http全局块
}
  • 全局块:配置影响nginx全局的指令。一般有运行nginx服务器的用户组,nginx进程pid存放路径,日志存放路径,配置文件引入,允许生成worker process数等。
    • events块:配置影响nginx服务器或与用户的网络连接。有每个进程的最大连接数,选取哪种事件驱动模型处理连接请求,是否允许同时接受多个网路连接,开启多个网络连接序列化等。
    • http块:可以嵌套多个server,配置代理,缓存,日志定义等绝大多数功能和第三方模块的配置。如文件引入,mime-type定义,日志自定义,是否使用sendfile传输文件,连接超时时间,单连接请求数等。
      • server块:配置虚拟主机的相关参数,一个http中可以有多个server。
      • location块:配置请求的路由,以及各种页面的处理情况。
      • upstream块:配置负载均衡

常用配置详解

常用命令

重启Nginx

./nginx -s reload;

测试 Nginx 配置是否有误

 ./nginx -t;

常用方案配置

反向代理

server {
    
    
    listen 80;
    server_name www.nginx.cn nginx.cn;
 
    location /app {
    
    
       proxy_pass http://127.0.0.1:8080;
    }
}

负载均衡

#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
    
    

    #设定mime类型,类型由mime.type文件定义
    include             /etc/nginx/mime.types;
    default_type    application/octet-stream;

    #设定日志格式
    access_log        /var/log/nginx/access.log;

    #省略上文有的一些配置节点
    #。。。。。。。。。。

    #设定负载均衡的服务器列表
    upstream mysvr {
    
    
        #weigth参数表示权值,权值越高被分配到的几率越大
        server 192.168.8.1x:3128 weight=5;
        #本机上的Squid开启3128端口,不是必须要squid
        server 192.168.8.2x:80    weight=1;
        server 192.168.8.3x:80    weight=6;
    }
        
    upstream mysvr2 {
    
    
        #weigth参数表示权值,权值越高被分配到的几率越大
        server 192.168.8.x:80    weight=1;
        server 192.168.8.x:80    weight=6;
    }

    #第一个虚拟服务器
    server {
    
    
        #侦听192.168.8.x的80端口
        listen             80;
        server_name    192.168.8.x;

        #对aspx后缀的进行负载均衡请求
        location ~ .*.aspx$ {
    
    
            #定义服务器的默认网站根目录位置
            root     /root; 
            #定义首页索引文件的名称
            index index.php index.html index.htm;
            
            #请求转向mysvr 定义的服务器列表
            proxy_pass    http://mysvr ;

            #以下是一些反向代理的配置可删除.

            proxy_redirect off;

            #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

            #允许客户端请求的最大单文件字节数
            client_max_body_size 10m; 

            #缓冲区代理缓冲用户端请求的最大字节数,
            client_body_buffer_size 128k;

            #nginx跟后端服务器连接超时时间(代理连接超时)
            proxy_connect_timeout 90;

            #连接成功后,后端服务器响应时间(代理接收超时)
            proxy_read_timeout 90;

            #设置代理服务器(nginx)保存用户头信息的缓冲区大小
            proxy_buffer_size 4k;

            #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
            proxy_buffers 4 32k;

            #高负荷下缓冲大小(proxy_buffers*2)
            proxy_busy_buffers_size 64k; 

            #设定缓存文件夹大小,大于这个值,将从upstream服务器传
            proxy_temp_file_write_size 64k;    

        }
    }
}

常见问题

1.文件上传,413 Request Entity Too Large

  • 原因:上传默认支持1M文件最大的大小
  • 解决方案:配置client_max_body_size
client_max_body_size 20M;#上传大小最大值

2.文件下载,upstream sent invalid chunked response while reading upstream 错误

  • 原因:没设置proxy_http_version默认是http1.0版本,不支持长连接和分块传输导致的
  • 解决方案:配置proxy_http_version 1.1
proxy_http_version 1.1

猜你喜欢

转载自blog.csdn.net/abu935009066/article/details/112463873
今日推荐