Nginx配置优化参考                                                                                     
                    编辑词条

                               

 

摘要:本文档描述了Nginx性能测试过程中,发现的可优化性能的配置项。主要包含系统参数,以及Nginx本身配置。本文可以作为后续上线以及维护过程中的参考文档。 1、 nofile 系统打开的文件数约束。 Linux服务器必须修改这个值才能满足Nginx的要求。建议修改为102400或者更大。 修改文件 /etc/security/limits.conf 默认值 1024 参考配置 * soft nofile 102400 * hard nofile 102400 2、 net.ipv4.ip_local_port_range 本地端口使用范围,在Ng

本文档描述了Nginx性能测试过程中,发现的可优化性能的配置项。主要包含系统参数,以及Nginx本身配置。本文可以作为后续上线以及维护过程中的参考文档。

                                                                    [ 编辑本段 ]                                                 [ 回目录 ]1、      nofile   

系统打开的文件数约束。 Linux服务器必须修改这个值才能满足Nginx的要求。建议修改为102400或者更大。

修改文件

/etc/security/limits.conf

默认值

1024

参考配置

* soft nofile 102400

* hard nofile 102400

                                                                    [ 编辑本段 ]                                                 [ 回目录 ]2、      net.ipv4.ip_local_port_range   

本地端口使用范围,在Nginx作为web服务器时这个参数可以忽略,但作为反向代理服务器必须修改为更大范围,高并发时可以大幅度提升Nginx性能。

修改文件

/etc/sysctl.conf

默认值

32768 61000

参考配置

net.ipv4.ip_local_port_range   = 1024 65000

                                                                    [ 编辑本段 ]                                                 [ 回目录 ]3、      其它sysctl.conf配置   

修改文件

/etc/sysctl.conf

参考配置

net.core.somaxconn = 2048

net.ipv4.tcp_syncookies = 1

net.ipv4.tcp_tw_reuse = 1

net.ipv4.tcp_tw_recycle = 1

net.ipv4.tcp_timestamps = 0

net.ipv4.tcp_fin_timeout =   15

net.ipv4.tcp_max_tw_buckets   = 10000

net.ipv4.ip_local_port_range   = 1024 65000

fs.file-max = 102400 #与nofile保持一致

net.ipv4.tcp_mem =   1048576  1310720 1572864

net.ipv4.tcp_rmem =  4096 87380 16777216

net.ipv4.tcp_wmem =  4096 87380 16777216

net.core.rmem_max = 16777216

net.core.wmem_max =   16777216

net.ipv4.tcp_synack_retries   = 3

net.ipv4.tcp_syn_retries =   3

net.ipv4.tcp_max_syn_backlog=8192

   使用/sbin/sysctl -p来做配置刷新
                                                                    [ 编辑本段 ]                                                 [ 回目录 ]4、      worker_processes   

Nginx工作进程数,经过测试以及官方的建议最好配置为与CPU核数目相等,或者auto。

修改文件

nginx.conf

官方说明

http://nginx.org/en/docs/ngx_core_module.html#worker_processes

参考配置

worker_processes 8;

                                                                    [ 编辑本段 ]                                                 [ 回目录 ]5、      worker_cpu_affinity   

绑定Nginx工作进程到CPU核,可以使CPU负载更加均衡稳定。配置值与worker_processes以及CPU核数目有关。配置1对应绑定的核。

修改文件

nginx.conf

官方说明

http://nginx.org/en/docs/ngx_core_module.html#worker_cpu_affinity

参考配置

worker_cpu_affinity   00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;

                                                                    [ 编辑本段 ]                                                 [ 回目录 ]6、      worker_rlimit_nofile   

Nginx工作进程能打开的文件句柄数目,建议与nofile一致。

修改文件

nginx.conf

官方说明

http://nginx.org/en/docs/ngx_core_module.html#worker_rlimit_nofile

参考配置

worker_rlimit_nofile 102400;

                                                                    [ 编辑本段 ]                                                 [ 回目录 ]7、      worker_connections   

Nginx工作进程能同时打开的链接数目,建议与worker_rlimit_nofile一致。

修改文件

nginx.conf

官方说明

http://nginx.org/en/docs/ngx_core_module.html#worker_connections

参考配置

worker_connections 102400;

                                                                    [ 编辑本段 ]                                                 [ 回目录 ]8、      access_log   

Nginx访问日志,一般情况下建议关闭,如果不能关闭就配置缓存可以大幅度提升IO性能。

修改文件

nginx.conf

官方说明

http://nginx.org/en/docs/http/ngx_http_log_module.html#access_log

参考配置

  1. access_log off;
  2. access_log   /pathto/access.log main buffer=128k flush=2m;
                                                                    [ 编辑本段 ]                                                 [ 回目录 ]9、      keepalive   

Nginx作为反向代理服务器时,upstream设置keepalive可以大幅度提升代理性能。如果是HTTP服务需要同时配置upstream和location。

修改文件

nginx.conf

官方说明

http://nginx.org/en/docs/http/ngx_http_upstream_module.html#keepalive

参考配置

upstream http_backend {

server 127.0.0.1:8080;

keepalive 32;

}

server {

...

location /http/ {

proxy_pass http://http_backend;

proxy_http_version 1.1;

proxy_set_header Connection   "";

...

}

}

                                                                    [ 编辑本段 ]                                                 [ 回目录 ]10、 hash consistent   

Nginx反向代理的服务需要会话保持功能,在real-server个数变化的时候影响尽可能小,可以配置一致性哈希。

修改文件

nginx.conf

官方说明

http://nginx.org/en/docs/http/ngx_http_upstream_module.html#hash

参考配置

upstream ngx-backend-normal   {

server 10.151.161.130:8080;

server 10.151.161.131:8080;

keepalive 32;

hash $remote_addr consistent;

}

Nginx配置优化参考的更多相关文章

  1. nginx 配置优化的几个参数

    nginx 配置优化的几个参数 2011-04-22 本文地址: http://blog.phpbean.com/a.cn/7/ --水平有限欢迎指正-- -- 最近在服务器上搞了一些nginx 研究 ...

  2. Nginx性能优化参考

    nginx性能优化参考 1)调整配置文件中的配置项的值(配置文件:nginx.conf) worker_processes auto;开启的进程数,一般配置为跟逻辑CPU核数一样worker_rlim ...

  3. Nginx配置优化详解

    如果你已经安装过Nginx并在生产环境中使用,那么Nginx配置优化你一定也要做,这样才能看到Nginx性能,本文就从基本配置优化开始到高层配置教你如何优化Nginx 大多数的Nginx安装指南告诉你 ...

  4. nginx配置优化提高并发量

    1 nginx配置优化提高并发量 worker_processes 2; 这个按照CPU的核数来决定 2 worker_connections 65535; 这个一般设置65535即可 每个进程允许的 ...

  5. Nginx配置优化及深入讲解,大家可以听一下

    随着访问量的不断增加,需要对Nginx和内核做相应的优化来满足高并发用户的访问,那下面在单台Nginx服务器来优化相关参数. 1)       Nginx.conf配置优化: worker_proce ...

  6. nginx配置优化 第二章

    一:常用功能优化: 1:网络连接的优化: 只能在events模块设置,用于防止在同一一个时刻只有一个请求的情况下,出现多个睡眠进程会被唤醒但只能有一个进程可获得请求的尴尬,如果不优化,在多进程的ngi ...

  7. Nginx配置优化

    Nginx优化: 并发优化 KeepAlive长连接 压缩优化 配置缓存 两个监控工具: nginx_status:并发统计 Ngxtop:请求统计 Nginx配置并发.长连接.压缩.状态监控: 关闭 ...

  8. nginx配置优化+负载均衡+动静分离详解

    nginx配置如下: #指定nginx进程运行用户以及用户组user www www;#nginx要开启的进程数为8worker_processes 8;#全局错误日志文件#debug输出日志最为详细 ...

  9. nginx 配置优化的几个参数(转)

    nginx配置文件里面需要注意的一些参数 worker_processes 8  nginx要开启的进程数 一般等于cpu的总核数 其实一般情况下开4个或8个就可 我开2个 以了 多了没有太多用每个n ...

随机推荐

  1. C# 7 out variables, tuples & other new features

    C# 7 out variables, tuples & other new features C# 7 is available on new Visual Studio 2017 and ...

  2. C++中的class (1)

    1.public:public表明该数据成员.成员函数是对全部用户开放的,全部用户都能够直接进行调用 2.private:private表示私有,私有的意思就是除了class自己之外,不论什么人都不能 ...

  3. php使用wkhtmltopdf导出pdf

    参考:史上最强php生成pdf文件,html转pdf文件方法 http://biostall.com/wkhtmltopdf-add-header-footer-to-only-first-last- ...

  4. unknown log format "main" in /nginx/conf/nginx.conf

    vi /nginx/conf/nginx.conf找到http{ }模块中的 log_format去掉注释,或是log_format写到了别处. 解决方法: 将log_format 写到http开头 ...

  5. linux下网络配置小节[from 老男孩的linux运维笔记]

    对于linux高手看似简单的网络配置问题,也许要说出所以然来也并不轻松,因此仍然有太多的初学者徘徊在门外就不奇怪了, 这里,老男孩老师花了一些时间总结了这个文档小结,也还不够完善,欢迎大家补充,交流. ...

  6. C语言lseek()函数:移动文件的读写位置

    相关函数:dup, open, fseek 头文件:#include <sys/types.h>    #include <unistd.h> 定义函数:off_t lseek ...

  7. 【java】详解JDK的安装和配置

    目录结构: contents structure [+] 什么是JDK JDK的三个版本 JDK包含的主要内容 JDK的安装 JDK的配置 配置JAVA_HOME 配置PATH 到底自己需不需要配置C ...

  8. Charles 网络抓包工具

    1.Charles 简介 Charles 是在 Mac.Linux 或 Windows 下常用的 http 协议网络包截取工具,在平常的测试与调式过程中,掌握此工具就基本可以不用其他抓包工具了.Cha ...

  9. 【Android开发】之Fragment生命周期

    上一篇博客我们讲到了,Fragment的基本使用,相信大家都已经了解怎么去使用了.如果还有不懂得同学可以去看一下,传送门.现在我们来讲解一下Fragment的生命周期. 一.Fragment的事务 再 ...

  10. 关于 os模块的常用用法

    作为常用模块中的os模块,需要掌握的用法是非常重要的,今天就在这里把它归纳总结总结,以便自己日后的使用 一.os模块 含义:提供程序与操作系统直接操作的各个功能 二.常用的几个用法 os.getcwd ...