zoukankan      html  css  js  c++  java
  • Nginx 大并发 调优设置

    为了性能测试,放弃部分功能,保证绝对性能。 注意可能不能用于生产环境。

    下面开始简单讲解。 

    1. worker_processes 工作线程数. 发现不用太多 一定不能多于操作系统的CPU核数.

    2. events 建议使用 epoll, 现在最佳的io模型

    3. http 里面 sendfile on 可以使用 zero copy  提高性能. 

    4. gzip on 使用压缩,提高性能. 

    5. client等配置,提高缓存应用效果.

    6. proxy 相关配置, 避免出现因为后端访问超时出现各种异常问题. 

    7. upstream server 注意可以使用weight以及max_fails 参数. 避免服务器FGC时因为STW造成响应不及时出现异常错误提示. 

    8. ip_hash 因为只使用前面三段ip地址容易出现负载不均衡的现象, 性能测试建议去掉, 功能测试可以使用外加sticky模式.

    9. server段里面 listen 没什么说的保证正常使用即可. 

    10. 如下内容保证可以传递给后端服务正确的客户端信息 以及不知道是不是重复的设置

    注意 如果使用 $host 变量,必须添加端口, 并且与listen的端口一致, 应该也可以使用 http_host 内部变量,可以不添加端口信息. 

             proxy_buffer_size 128k;
             proxy_buffers 4 256k;
             proxy_busy_buffers_size 256k;
             proxy_set_header Host $host:5200;
             proxy_set_header X-Real-IP $remote_addr;
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

    11. access_log off 破釜沉舟, 提高性能. 发现不关闭log 一小时能够产生十几G的日志, 估计会拖慢nginx的相应时间, 没办法这些内容暂时就放弃了. 

    12. 其他内容一切从简 . 

    如下就是自己的一个简单的例子 可能还需要继续完善. 短暂进行学习mark一下. 希望高手指正. 

    worker_processes  44;
    worker_rlimit_nofile 65535;
    events {
            use epoll;
            worker_connections 65535;
    }
    http {
        default_type  application/octet-stream;
        sendfile        on;
        gzip on;
    
    client_header_buffer_size 64k;
    large_client_header_buffers 4 64k;
    client_body_buffer_size 20m;
    gzip_buffers 16 8k;
    proxy_buffer_size 64k;
    proxy_buffers 4 128k;
    proxy_busy_buffers_size 256k;
    keepalive_timeout 240;
    proxy_connect_timeout 600s;
    proxy_send_timeout 1200;
    proxy_read_timeout 1200;
    
        upstream webservers {
            #ip_hash;
            server 127.0.0.1:5201 weight=10 max_fails=10;
            server 127.0.0.1:5202 weight=10 max_fails=10;
            server 127.0.0.1:5203 weight=10 max_fails=10;
    
        }
    
        server {

             listen 5200;
             server_name localhost;
             root /usr/share/nginx/html;
             proxy_buffer_size 128k;
             proxy_buffers 4 256k;
             proxy_busy_buffers_size 256k;
             proxy_set_header Host $host:5200;
             proxy_set_header X-Real-IP $remote_addr;
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
             location /
              {
                access_log off;
                add_header 'Access-Control-Allow-Origin' "$http_origin";
                add_header 'Access-Control-Allow-Credentials' "true";
                proxy_pass http://webservers;
               }
           error_page 500 502 503 504 /50x.html;
            location = /50x.html {
            root html;
           }
        }   
    }

     
  • 相关阅读:
    软件命名的几种常见方式
    软件过程与项目管理第一周作业
    DOS命令大全 系统管理员专用
    数据库事务的作用
    利用C#事务处理对数据库进行多重操作
    JSP标签分页实现
    使用自定义端口连接sql server2008
    Solr4.4.0的安装与配置
    Android中如何使用ViewPager实现类似laucher左右拖动效果
    Android中Timer使用方法
  • 原文地址:https://www.cnblogs.com/jinanxiaolaohu/p/14629728.html
Copyright © 2011-2022 走看看