读书笔记:Web服务器内存管理

  近日读郭欣同学的《构建高性能的Web站点》。

  内存分配策略的设计,是Web服务器并发处理能力的重要保证。Web服务器每时每刻都要处理成千上万的http请求,内存堆栈的分配何复制次数变得异常频繁。我们可以改善数据结构和算法复杂度来适当减少数据复制时间,对于内存分配,很多Web服务器使用各自的策略来提高效率。

  Apache在运行时候使用的内存相当巨大,这主要归罪于它的多进程模型。Apache使用了基于内存池策略的内存管理方案,并将它抽象出来移入APR库中作为通用内存管理模块。这种方案使得Apache运行开始就一次性的申请大片内存空间作为内存池,这个避免了频繁的内存分配和释放,利于改善性能,另一方面,内存池的使用使得Apache的内存管理更加安全。但还即使是内存池,Apache就像脱着沉重身子的大个子,性能不够优越。

  单进程模型的lighttpd,内存使用量要少的多。同样是单进程模型的Nginx,内存使用量更少。Ngnix对于内存方面的优秀表现,得益于它的内存分配策略。它可以使用多线程来处理请求,多线程之间可以共享内存资源。它还采取分阶段的内存分配策略,按需分配,及时释放,使得内存使用量保持在很小的范围内。

 

 

转载于:https://www.cnblogs.com/rockics/archive/2010/10/19/1855963.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值