最大文件描述符限制对高性能Web架构的影响
2014-04-17 13:50
351 查看
[转载] http://blog.sina.com.cn/s/blog_a577ca62010100qa.html
在不同于Windows平台的高效的线程机制, Linux/Unix系统早期通过多进程来解决Web大规模并发访问量的问题.而随着Linux内核的改进, 单纯增加进程数量的方式也慢慢被弃用, 转而使用单进程异步IO接口, 比如epoll(Linux),kqueue(BSD).
单进程异步IO接口可以简单理解为, 进程把大量的socket连接交给内核管理, 一旦连接中有数据需要处理, 则激活进程进行处理.这样, 一个进程同时打开的socket(也即文件描述符)就有成千上万个.
Linux系统默认的单个进程所能打开的最大文件描述符一般是1024(可通过ulimit -n命令查询),这就导致了文件描述符被用完的情况出现. 所以, 要开发能处理高并发请求的Web系统, 必须修改操作系统的最大文件描述符.
即使使用的是Apache这样的多进程Web服务器, 也有可能被最大文件描述符限制给绊倒, 因为后端可能使用的是fastcgi,memcached这些应用. 比如memcached, 一般使用的就是单进程异步IO接口, fastcgi的PHP脚本与其连接时,将保持TCP长连接, 也是会消耗大量的文件描述符.
所以, 运行在Linux之上的高性能Web系统, 一定要扩大进程的最大文件描述符限制, 这是有很惨痛经验教训的.
在不同于Windows平台的高效的线程机制, Linux/Unix系统早期通过多进程来解决Web大规模并发访问量的问题.而随着Linux内核的改进, 单纯增加进程数量的方式也慢慢被弃用, 转而使用单进程异步IO接口, 比如epoll(Linux),kqueue(BSD).
单进程异步IO接口可以简单理解为, 进程把大量的socket连接交给内核管理, 一旦连接中有数据需要处理, 则激活进程进行处理.这样, 一个进程同时打开的socket(也即文件描述符)就有成千上万个.
Linux系统默认的单个进程所能打开的最大文件描述符一般是1024(可通过ulimit -n命令查询),这就导致了文件描述符被用完的情况出现. 所以, 要开发能处理高并发请求的Web系统, 必须修改操作系统的最大文件描述符.
即使使用的是Apache这样的多进程Web服务器, 也有可能被最大文件描述符限制给绊倒, 因为后端可能使用的是fastcgi,memcached这些应用. 比如memcached, 一般使用的就是单进程异步IO接口, fastcgi的PHP脚本与其连接时,将保持TCP长连接, 也是会消耗大量的文件描述符.
所以, 运行在Linux之上的高性能Web系统, 一定要扩大进程的最大文件描述符限制, 这是有很惨痛经验教训的.
相关文章推荐
- 最大文件描述符限制对高性能Web架构的影响
- 修改Linux系统下的最大文件描述符限制
- 基于linux&unix高性能web服务器架构思路分析
- 列举web开发中,为满足高性能的架构技术实现
- 高性能web系统的架构和系统优化
- 高性能Web架构
- 从架构差异看Web高性能开发
- 提高linux对最大进程数和最大打开文件描述符数的限制
- 网站的高性能架构---Web前端性能优化
- 修改Linux系统下的最大文件描述符限制
- .NET 需要处理的高性能WEB架构 - .NET架构
- 高性能web系统的架构和系统优化
- 高性能web系统的架构和系统优化
- 一张图讲清楚高可用、高性能、可扩展的WEB系统架构
- 资料收集:高并发 高性能 高扩展性 Web 2.0 站点架构设计及优化策略
- 高性能web系统的架构和系统优化
- 高性能Web服务之lnmp架构应用
- 高性能Web架构
- 高性能web中各存储的角色应用和千万pv站点架构
- 高性能Web架构