nginx服务器调优措施总结:
1、选择合适的网络IO模型 epoll select poll
2、配置合适的启动进程数和每个进程处理请求的工作线程数
3、启用gzip压缩以减小通信量以减少网络IO
4、降低日志级别或关闭日志
5、使用长连接,配置合适的超时时间,keep_alive keepalive-timeout
6、控制浏览器缓存
7、提高操作系统打开文件数,或配置合适的worker_rlimit_nofile来申明你期望的值
8、减少磁盘IO
9、配置nginx自带的proxy_store、proxy_cache、memcached缓存模块或应用第三方缓存模块Ncache、Varnish
 
减少磁盘IO
Nginx在CPU的利用方面是非常高效的, 所以我会坦白的告诉你这不会成为瓶颈。 同样nginx在使用内存方面也是很高效的,这也不会成为瓶颈。 现在只剩下IO这个服务器瓶颈的罪魁祸首了。为了避免IO瓶颈, 我们需要大量的减少nginx对硬盘驱动器的读写。要做到这一点,我们可以通过修改Nginx的行为,以减少磁盘写操作:
1)Access Logs
可以直接关闭它,如果你需要访问日志,可以考虑保存日志到内存中。这将会比直接写到磁盘上快很多,并且明显减少IO的使用。

2)Error Logs
可以直接关闭它,如果你需要错误日志,错误日志的等级参数你是可以指定的, 如果你指定的太低了他会记录404错误甚至是debug信息。 在实际的应用中可以将它设置为warn级别,将会是绰绰有余的并且能降低IO。

3)Open File Cache
缓存打开文件的描述符,由open_file_cache指令指定。

4)Buffers
配置Nginx缓存的大小是一个非常重要的事情。如果缓存大小设置的太小,Nginx将不得不把上游的相应结果存放到临时的缓存文件里面,这将会同时增加IO的读写操作,而且流量越大问题越多。
client_body_buffer_size指令用来指定处理客户端请求的缓冲区大小,如果你需要处理很多大的POST请求的,你必须确保缓存区要设置的足够大。
fastcgi_buffers和proxy_buffers 指令用来处理上流的响应结果。Nginx将这个buffer数据同步的传输给客户端之前,有一个缓存上限,保存到磁盘也同样受限。这个上限是通过fastcgi_max_temp_file_size和proxy_max_temp_file_size来设置的。

5)彻底移除磁盘IO
可以将数据都放入内存,这样就可以彻底不用考虑磁盘IO的阻塞了。意味着你可以通过增加内存来解决IO的瓶颈。 数据量越多,需要的内存越大。

 

nginx服务器调优的更多相关文章

  1. Nginx性能调优

    [调优]Nginx性能调优   一.Nginx优化配置 1.主配置文件优化:# vi /usr/local/nginx/conf/nginx.conf------------------------- ...

  2. Nginx 性能调优

    原文地址:http://nginx.com/blog/tuning-nginx/ Tuning NGINX for Performance Nginx 性能调优 NGINX is well known ...

  3. 【Nginx】Nginx服务器配置调优

    1.Nginx服务器配置调优 .设置nginx全局参数 vi /usr/local/nginx/conf/nginx.conf #编辑 worker_processes ; # 工作进程数,为CPU的 ...

  4. Nginx下载服务生产服务器调优

    一.内存调优 内核关于内存的选项都在/proc/sys/vm目录下.   1.pdflush,用于回写内存中的脏数据到硬盘.可以通过 /proc/sys/vm/vm.dirty_background_ ...

  5. Nginx参数调优

    (1)nginx运行工作进程个数,一般设置cpu的核心或者核心数x2 如果不了解cpu的核数,可以top命令之后按1看出来,也可以查看/proc/cpuinfo文件 grep ^processor / ...

  6. Nginx+Mysql调优

    使用nginx实现反向代理作用,具备负载均衡的功能.     接受客户端的请求 | nginx(宿主机) | |-------------------| web1 web2 (客户机)   原理: 与 ...

  7. Hadoop企业开发场景案例,虚拟机服务器调优

    Hadoop企业开发场景案例 1 案例需求 ​ (1)需求:从1G数据中,统计每个单词出现次数.服务器3台,每台配置4G内存,4核CPU,4线程. ​ (2)需求分析: ​ 1G/128m = 8个M ...

  8. 浅谈Nginx性能调优

    点击上方"开源Linux",选择"设为星标" 回复"学习"获取独家整理的学习资料! Linux系统参数优化 下文中提到的一些配置,需要较新的 ...

  9. 【调优】Nginx性能调优

    一.Nginx优化配置 1.主配置文件优化:# vi /usr/local/nginx/conf/nginx.conf----------------------------------------- ...

随机推荐

  1. javascript中window.open()与window.location.href的区别

    window.open("www.baidu.com"); 只是表示打开这个页面,并不是打开并刷新baidu.com window.location.href="www. ...

  2. 2-SAT问题及其算法

    原文地址:http://www.cppblog.com/MatoNo1/archive/2011/07/13/150766.aspx [2-SAT问题]现有一个由N个布尔值组成的序列A,给出一些限制关 ...

  3. Java反编译利器-Jad, Jode, Java Decompiler等及其IDE插件

    转自:http://blog.csdn.net/superbeck/article/details/5189231 对于长年使用Java的程序员,大部分应该都会或多或少的使用到反编译软件.毕竟,不可能 ...

  4. org.apache.log4j与org.apache.commons.logging这两个包有什么区别

    apache common logging是一种log的框架接口,它本身并不实现log记录的功能,而是在运行时动态查找目前存在的日志库,调用相关的日志函数,从而隐藏具体的日志实现log4j是具体的日志 ...

  5. 安卓通过putExtra传递数据的几种方式

    通过intent传递数据时,使用以下代码报错: hMap<string, object=""> map=(Map<string, object="&qu ...

  6. oracle和mssql中复制表的比较

    库内数据复制MS SQL Server: Insert into 复制表名称 select 语句 (复制表已经存在)select 字段列表 into 复制表名称 from 表 (复制表不存在) Ora ...

  7. Buy the Ticket

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission( ...

  8. 寒假 D3 D Modular Inverse

    Modular Inverse Time Limit: 2 Seconds                                     Memory Limit: 65536 KB     ...

  9. 数学+高精度 ZOJ 2313 Chinese Girls' Amusement

    题目传送门 /* 杭电一题(ACM_steps 2.2.4)的升级版,使用到高精度: 这次不是简单的猜出来的了,求的是GCD (n, k) == 1 最大的k(1, n/2): 1. 若n是奇数,则k ...

  10. C#:代表(delegate)和事件(event)

    代表(delegate): 它是C#语言里面的函数指针,代表可以指向某一个函数,在运行的时候调用这个函数的实现.下面来看看它的实现步骤: 声明一个delegate对象. 实现和delegate具有相同 ...