nginx配置优化

 
 

#定义Nginx运行的用户和用户组user  www  www;  

#启动工作进程,通常设置成和cpu的数量相等
worker_processes  8;   最多开启8个,8个以上性能就不会再提升了。

#为每个工作进程分配cpu。
worker_cpu_affinity 00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;

关于cpu的设置,可以查看这个链接:http://blog.csdn.net/u011957758/article/details/50959823

#该指令是当一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数(ulimit -n)与nginx进程数相除,
#但是nginx分配请求并不是那么均匀,所以最好与ulimit -n的值保持一致。
worker_rlimit_nofile  102400;

#全局错误日志及PID文件
error_log  /usr/local/nginx/logs/error.log; 
#错误日志定义等级,[ debug | info | notice | warn | error | crit ]加在后面即可。

#定义pid文件
pid        /usr/local/nginx/nginx.pid;

events {
use   epoll;                
#epoll是多路复用IO(I/O Multiplexing)中的一种方式,可以大大提高nginx的性能。
worker_connections  10240;    
#单个后台worker process进程的最大并发链接数 (最大连接数=连接数*进程数)
multi_accept  on; 
#尽可能多的接受请求.
}
#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
#设定mime类型,类型由mime.type文件定义
include       mime.types;
#定义默认的MIME类型;default_type  application/octet-stream;
#定义日志格式
log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                  '$status $body_bytes_sent "$http_referer" '
                  '"$http_user_agent" "$request_time"';

$request_time的单位是秒。

实战:

103.233.128.154 - - [10/Nov/2017:11:03:05 +0800] "GET /data/questionnaire?callback=jQuery111105610104849438594_1510282984659&pid=cnu&u=b&mode=c&_id=5a0516c71b0aebcecc985469&_=1510282984660 HTTP/1.1" 200 187 "http://csproduct.cmr.net.cn/nwb/webdata/pxbz/m/dcwjwt?pid=cnu&productId=028&paperid=5a0516c71b0aebcecc985469&firstBlockId=59bb8ca238d2116827ea9cdb&firstIndex=2&blockId=5a0516c7e7c4e1b8a0058ad2&secIndex=11&status=1" "Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:56.0) Gecko/20100101 Firefox/56.0"  "0.014"

103.233.128.154   $remote_addr   远程客户端地址

-        -

-   $remote_user          远程客户端用户名称

[10/Nov/2017:11:03:05 +0800]     [$time_local]    访问时间和时区

GET /data/questionnaire?callback=jQuery111105610104849438594_1510282984659&pid=cnu&u=b&mode=c&_id=5a0516c71b0aebcecc985469&_=1510282984660 HTTP/1.1     $request    请求信息

200    $status    状态码

187    $body_bytes_sent   字节为单位    发送字节大小

http://csproduct.cmr.net.cn/nwb/webdata/pxbz/m/dcwjwt?pid=cnu&productId=028&paperid=5a0516c71b0aebcecc985469&firstBlockId=59bb8ca238d2116827ea9cdb&firstIndex=2&blockId=5a0516c7e7c4e1b8a0058ad2&secIndex=11&status=1 $http_referer          从哪个页面访问过来的,可以防盗链在这里设置

Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:56.0) Gecko/20100101 Firefox/56.0      $http_user_agent   用户所使用的浏览器信息.

$request_time   请求时间单位为秒

$http_x_fordwarded_for   此nginx当做web的时候,当前端有代理服务器时,记录客户端的地址,前提是代理服务器上设置了proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for

#设定访问日志路径
access_log    /usr/local/nginx/log/nginx/access.log;
sendfile      on;
#sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用必须设为on
#如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络I/O处理速度,降低系统的uptime。
#autoindex  on;  
#开启目录列表访问,适合下载服务器,默认关闭。
tcp_nopush on;   
#防止网络阻塞,只有在sendfile被使用时才会激活。
keepalive_timeout  120;
#keepalive超时时间,客户端到服务器端的连接持续有效时间,当出现对服务器的后继请求时,
#keepalive-timeout功能可避免建立或重新建立连接。(节省服务器资源、CPU、内存、网卡)
tcp_nodelay   on; 
#提高数据的实时响应性,仅在将连接转变为长连接的时候才被启用(在upstream发送响应到客户端时也会启用)
#开启gzip压缩
gzip on;
#设置允许压缩的页面最小字节数。
gzip_min_length  1k;
#设置系统获取几个单位的缓存用于存储gzip的压缩结果数据流。 
#4 16k代表以16k为单位,按照原始数据大小以16k为单位的4倍申请内存。
gzip_buffers     4 16k;
#设置支持http协议的最小压缩版本。现在大多浏览器都支持。
gzip_http_version 1.1;
#压缩级别大小,最大为9,值越小,压缩后比例越小,CPU处理更快。
#值越大,消耗CPU比较高。
gzip_comp_level  6; 
#支持压缩的类型。
gzip_types       text/plain application/x-javascript text/css application/xml;
#在http头文件中加个“Vary: Accept-Encoding”,给代理服务器用的,有的浏览器支持压缩,有的不支持
#所以避免浪费不支持的也压缩,所以根据客户端的HTTP头来判断,是否需要压缩
gzip_vary on;
#对IE6进行压缩,不过IE6目前已经淘汰。
#gzip_disable "MSIE [1-6]."
client_max_body_size 10m;      
#允许客户端请求的最大单文件字节数
client_body_buffer_size 128k; 
#缓冲区代理缓冲用户端请求的最大字节数.
proxy_connect_timeout 90;      
#nginx跟后端服务器连接超时时间(代理连接超时)
proxy_send_timeout 90;         
#后端服务器数据回传时间(代理发送超时)
proxy_read_timeout 90;         
#连接成功后,后端服务器响应时间(代理接收超时)
proxy_buffer_size 4k;          
#设置代理服务器(nginx)保存用户头信息的缓冲区大小
proxy_buffers 4 32k;           
#proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
proxy_busy_buffers_size 64k;   
#高负荷下缓冲大小(proxy_buffers*2)
large_client_header_buffers  4 4k;
#设置读取客户端请求超大请求的缓冲最大number(数量)和每块缓冲的size(容量)。 
#HTTP请求行的长度不能超过一块缓冲的容量,否则nginx返回错误414 (Request-URI Too Large)到客户端。 
#每个请求头的长度也不能超过一块缓冲的容量,否则nginx返回错误400 (Bad Request)到客户端。
client_header_buffer_size 4k;
#客户端请求头部的缓冲区大小,这个可以根据你的系统分页大小来设置,一般一个请求的头部大小不会超过1k
#不过由于一般系统分页都要大于1k,所以这里设置为分页大小。分页大小可以用命令getconf PAGESIZE取得。
open_file_cache max=102400 inactive=20s;
#这个将为打开文件指定缓存,默认是没有启用的,max指定缓存数量,建议和打开文件数一致,inactive是指经过多长时间文件没被请求后删除缓存。
open_file_cache_valid 30s;
#这个是指多长时间检查一次缓存的有效信息。open_file_cache_min_uses 1;
#open_file_cache指令中的inactive参数时间内文件的最少使用次数,如果超过这个数字,文件描述符一直是在缓存中打开的,如上例,如果有一个文件在inactive
#包含其它配置文件,如自定义的虚拟主机
include vhosts.conf;

虚拟主机配置文件的优化

  upstream backend {        
        #配置后端服务器的权重。如果在30秒内请求失败两次自动剔除
        server   127.0.0.1:8080 weight=1 max_fails=2 fail_timeout=30s;
        server   127.0.0.1:8081 weight=1 max_fails=2 fail_timeout=30s;
        server   127.0.0.1:8082 weight=1 max_fails=2 fail_timeout=30s;
        server   127.0.0.1:8083 weight=1 max_fails=2 fail_timeout=30s;
    }   
    #虚拟主机配置
    server {       #侦听80端口
        listen       80;        #定义使用www.abc.com访问
        server_name  www.abc.com;        #设定本虚拟主机的访问日志
        access_log  logs/access.log  main;
            root   /data/webapps/www;  #定义服务器的默认网站根目录位置
        index index.php index.html index.htm;   #定义首页索引文件的名称
        #默认请求
        location ~ /{
          root   /data/webapps/www;      #定义服务器的默认网站根目录位置
          index index.php index.html index.htm;   #定义首页索引文件的名称

#以下是一些反向代理的配置.
          proxy_next_upstream http_502 http_504 error timeout invalid_header;         
      #如果后端的服务器返回502、504、执行超时等错误,自动将请求转发到upstream负载均衡池中的另一台服务器,实现故障转移。
          proxy_redirect off;        
           #允许重新定义或者添加发往后端服务器的请求头
          proxy_set_header Host $host;          
          #把真实客户端IP写入到请求头X-Real-IP,在NginxBackend输出$http_x_real_ip获取到了真实客户端IP
          #而Nginx Backend的“$remote_addr”输出为最后一个反向代理的IP;
          proxy_set_header X-Real-IP $remote_addr;          
          #把请求头中的X-Forwarded-For与$remote_addr用逗号合起来,
          #如果请求头中没有X-Forwarded-For则$proxy_add_x_forwarded_for为$remote_addr。
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;          
          #设置代理使用的HTTP协议版本。默认使用的版本是1.0
          proxy_http_version 1.1;
          proxy_set_header Connection "";         
           #设置允许客户端请求正文的最大长度。
          client_max_body_size    100m;          
          #请求转向后端定义的均衡模块,和前面的指定对应。
           proxy_pass  http://backend;   
        # 定义错误提示页面
            error_page   500 502 503 504 /50x.html;  
            location = /50x.html {
            root   html;
        }       #配置Nginx动静分离,定义的静态页面直接从Nginx发布目录读取。
        location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$
        {
            root /data/webapps/www;            
            #expires定义用户浏览器缓存的时间为3天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力,在浏览器保存该类型文件的天数。
            expires      3d;
        }       
        #PHP脚本请求全部转发到 FastCGI处理. 使用FastCGI默认配置.
        location ~ \.php$ {
            root /root;
            FastCGI_pass 127.0.0.1:9000;
            FastCGI_index index.php;
            FastCGI_param SCRIPT_FILENAME /data/webapps/www$FastCGI_script_name;
            include FastCGI_params;
        }        
        #设定查看Nginx状态的地址
        location /NginxStatus {
            stub_status  on;
        }
     }
}

主要涉及开启的线程数量,绑定CPU,启动压缩,如果有代理还涉及到后后端服务器的交互时间等优化

nginx配置文件优化的更多相关文章

  1. (转)[Nginx] – 配置文件优化 [一 ,二]

    [Nginx] – 安全优化 – 配置文件优化 [二] 原文:https://www.abcdocker.com/abcdocker/586 [Nginx] – 性能优化 – 配置文件优化 [一] 原 ...

  2. NGINX配置文件优化示例

    Nginx主配置文件 upstream.conf配置文件 # server nginx配置文件最好分开写,不要把所有的逻辑都放在一个文件里面,会看着很麻烦,,之前我的配置文件都放一起了,,导致现在维护 ...

  3. [NGINX] - 配置文件优化 - NGINX.CONF

    Nginx 本文主要针对公司的Nginx负载均衡配置进行解释,配置文件在最下方.因为公司没有使用PHP,所以NGINX里面并没有太多facgi模块相关优化    NGINX.CONF user   语 ...

  4. Nginx 配置文件优化

    user www www; #用户&组 worker_processes auto; #通常是CPU核的数量存储数据的硬盘数量及负载模式,不确定时将其设置为可用的CPU内核数(设置为“auto ...

  5. Nginx高性能优化

    #Nginx配置文件优化 worker_processes ; # nginx进程数,建议按照cpu数目来指定,一般为它的倍数. worker_cpu_affinity ; # 为每个进程分配CPU的 ...

  6. [Nginx] – 性能优化 – 配置文件优化

    Nginx基本安全优化 1.调整参数隐藏Nginx版本号信息     一般来说,软件的漏洞都和版本有关,因此我们应尽量隐藏或清除Web服务队访问的用户显示各类敏感信息(例如:Web软件名称及版本号等信 ...

  7. nginx配置文件企业优化

    1.1 企业规范优化Nginx配置文件 第一个里程碑:创建扩展目录,生成虚拟主机配置文件 mkdir extra sed -n '10,15p' nginx.conf >extra/www.co ...

  8. Nginx配置文件、优化详解

    上篇<编译安装nginx>已将nginx安装好,这篇写nginx配置文件和部分优化参数. 查看nginx的配置文件路径,可以使用nginx配置文件检查命令nginx -t: [root@n ...

  9. nginx的优化

    Nginx 优化 Nginx是俄罗斯人编写的十分轻量级的HTTP服务器,Nginx,它的发音为"engine X",是一个高性能的HTTP和反向代理服务器,同时也是一个IMAP/P ...

随机推荐

  1. saltstack---自动化运维平台

    https://github.com/ixrjog/adminset[自动化运维平台:CMDB.CD.DevOps.资产管理.任务编排.持续交付.系统监控.运维管理.配置管理 ] https://ww ...

  2. JDBC---Mysql(2)

    SQL注入攻击: 用户可以提交一段数据库查询代码,根据程序返回的结果,获得某些他想知道的数据,这就是所谓的SQL注入攻击, 例如:判断username='a' or 'a'='a';  true从而为 ...

  3. 使用Dom4j的xPath解析xml文件------xpath语法

    官方语法地址:http//www.w3school.com.cn/xpath/index.asp xpath使用路径表达式来选取xml文档中的节点或节点集.节点是通过沿着路径(path)或者步(ste ...

  4. day2_python基础

    1.变量: 用来存东西的,左边是名字,右边是值 2.python中的单引号.双信号.三引号 单引号和双引号和三引号没什么区别,用哪个都可以,如果定义字符串里面如果有单引号,则外面用双引号;如果字符串里 ...

  5. 内部排序->插入排序->其它插入排序->2-路插入排序

    文字描述 在折半插入排序的基础上进行改进, 另设一个和待排序序列L相同的数组D, 首先将L[1]赋值给D[0], 数组D中数据是已经排好序的, first指向最小值下标,final指向最大值下标.初始 ...

  6. SQL DATE_FORMAT() 函数

    参照原文:https://blog.csdn.net/moakun/article/details/82290387 DATE_FORMAT() 函数用于以不同的格式显示日期/时间数据 MySQL 使 ...

  7. jQuery -- 监听input、textarea输入框值变化

    $('textarea').bind('input propertychange', function(){ if($(".textareachange").val() != &q ...

  8. Python中的下划线(转)

    译文原文:https://segmentfault.com/a/1190000002611411 原文地址这篇文章讨论Python中下划线_的使用.跟Python中很多用法类似,下划线_的不同用法绝大 ...

  9. 【雅思】【写作】【大作文】Report

    •Report •主要分类 •两个问题 • •1. 原因,解决办法 • •2. 原因,积极还是消极 • •3. Freestyle •报告型 •In cities and towns all over ...

  10. pycharm快捷键帮助文档Keymap Reference

    前面我们已经安装了pycharm,为了提升效率,我们一般会用到快捷键操作,pycharm有哪些快捷键呢?Pycharm中打开Help->Keymap Reference可查看默认快捷键帮助文档, ...