前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Nginx配置文件的理解

Nginx配置文件的理解

作者头像
小俊丶Eternally
发布2018-06-27 10:48:38
8520
发布2018-06-27 10:48:38
举报
文章被收录于专栏:Eternally运维Eternally运维
user www www;               #定义Nginx运行的用户和用户组

worker_processes  auto;     #nginx进程数,建议设置为等于CPU总核心数,这里auto为自动调整的意思

worker_cpu_affinity auto;   #对于具有多颗CPU的服务器,Nginx通过设置worker_cpu_affinity参数,即可轻松实现控制进程平均分配到多颗CPU上

error_log  logs/error.log;  #全局错误日志定义类型,[ debug | info | notice | warn | error | crit ]

google_perftools_profiles /tmp/tcmalloc;   #gperftools优化nginx

worker_rlimit_nofile 102400;      #每个nginx进程打开文件描述符最大数目 配置要和系统的单进程打开文件数一致,linux 2.6内核下开启文件打开数为65535,worker_rlimit_nofile就相应应该填写65535,nginx调度时分配请求到进程并不是那么的均衡,假如超过会返回502错误。可以把数值写大一点。

pid        /usr/local/nginx/nginx.pid; #
events {
use epoll;
worker_connections  102400;
}
http {
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"';
server_names_hash_bucket_size 128;    #服务器名字的哈希(hash)表大小
client_header_buffer_size 32k;   #上传文件大小限制
large_client_header_buffers 4 32k;    #设定请求缓
client_max_body_size 300m;   #设定请求缓
sendfile        on;  #开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件,对于普通应用设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络I/O处理速度,降低系统的负载。注意:如果图片显示不正常把这个改成off。
proxy_ignore_client_abort on;   # 告诉nginx不要主动关闭连接
tcp_nopush     on;              #启用后数据包不会马上传送出去,等到数据包最大时,一次性的传输出去,这样有助于解决网络堵塞
proxy_connect_timeout 500;      #nginx跟后端服务器连接超时时间(代理连接超时)
proxy_send_timeout 600;         #后端服务器数据回传时间(代理发送超时)
proxy_read_timeout 500;         #连接成功后,后端服务器响应时间(代理接收超时)
proxy_buffer_size 16k;          #设置代理服务器(nginx)保存用户头信息的缓冲区大小
proxy_buffers 4 64k;            #proxy_buffers缓冲区,网页平均在32k以下的设置
proxy_busy_buffers_size 128k;   #高负荷下缓冲大小(proxy_buffers*2)
proxy_temp_file_write_size 128k;    #设定缓存文件夹大小,大于这个值,将从upstream服务器传
keepalive_timeout  10;          #设置客户端连接保存活动的超时时间 设置为多少,要看网站的流量、服务器的配置而定。 因为设置太短,就会频繁的连接,消耗过多的资源,如果连接时间过长,就会有很多没用连接来占用服务器资源。
client_header_timeout 10;       #用于设置客户端请求读取超时时间 
client_body_timeout 10;         #用于设置客户端请求主体读取超时时间 
send_timeout 10;                #用于设置相应客户端的超时时间 
tcp_nodelay on;
server_tag off;                 #隐藏server头部
server_info off;                #错误信息
server_tokens off;              #隐藏nginx的版本号
gzip  on;                        #开启gzip压缩 
gzip_min_length  1k;             #设置允许压缩的页面最小字节数 
gzip_buffers     4 16k;          #申请4个单位为16K的内存作为压缩结果流缓存 
gzip_http_version 1.1;           #设置识别http协议的版本,默认是1.1 
gzip_comp_level 2;               #指定gzip压缩比,1-9 数字越小,压缩比越小,速度越快.
gzip_types       text/plain application/x-javascript text/css application/xml application/json;          #指定压缩的类型 
gzip_vary on;                      #让前端的缓存服务器存经过gzip压缩的页面
gzip_disable "MSIE [1-6].";        #意思就是在ie1-ie6环境下禁用gzip
server {
    listen 84;
    server_name _;
    location / {
      stub_status on;
      access_log off;
    }
}
       upstream tomcat {
    server 127.0.0.1:8080;
    check interval=3000 rise=2 fall=5 timeout=1000 type=http;
    check_http_send "GET /favicon.ico HTTP/1.0\r\n\r\n";
    check_http_expect_alive http_2xx http_3xx;
    }
    include  vhost/*.conf;
    }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-03-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档