一、系统调用简介
1、进程的两种运行模式:Linux进程有用户态和内核态两种运行模式,进程可以在两种模式之间切换。这两种态的分离,动机主要在于提高系统底层安全性以及简化开发模型。减少不必要的系统调用,也是Web服务器性能优化的一个方面。
2、可以使用strace来跟踪进程,获得该进程的一系列系统调用。
二、内存分配
Apache的多进程模型,使用了基于内存池策略的内存管理方案;
Lighttpd的单进程模型,内存的使用量小很多;
Nginx的多线程模型,内存使用量也小。
内存分配策略的设计是Web服务器并发处理能力的重要保障。
三、持久连接
1、定义:持久连接(Keep-Alive),也叫长连接,是TCP通信的一种普通方式,即在一个TCP连接中持续发送多份数据而不断开连接。从性能角度看,建立TCP连接的操作本身便是一项不小的开销,连接次数越小,越有利于性能的提升。
2、实现的条件:浏览器和Web服务器的共同协作。
浏览器:在发出的HTTP请求数据头包含 Connection:Keep-Alive
Web服务器:目前主流Web服务器都支持长连接,比如在Apache中,长连接的支持默认为开启状态,可以通过KeepAlive off来关闭。
服务器的HTTP响应头:Keep-Alive:timeout = 5 , max = 100
3、参数设置
超时时间:
Apache中,通过httpd.conf中通过 KeepAliveTimeout 30 设置。
浏览器和Web服务器各自的超时时间设置不一定一致,以最短的超时时间为准。
4、持久连接的目的就是尽量减少连接次数,尽量重用连接通道。