0

0

Apache的性能优化(六)

黄舟

黄舟

发布时间:2016-12-21 11:28:37

|

1767人浏览过

|

来源于php中文网

原创

估算参数的例子(作个参考,不一定适合我们的情况):
apache缺省的最大用户数是256个:这个配置对于服务器内存还是256m左右的时代是一个非常好的缺省设置,但随着内存成本的急剧下降,现在大型站点的服务器内存配置一般比当时要高一个数量级不止。所以256个进程的硬限制对于一台1g内存的机器来说是太浪费了,而且apache的软上限 max_client是受限于hard_server_limit的,因此如果web服务器内存大于256m,都应该调高apache的 hard_server_limit。根据个人的经验:2560已经可以满足大部分小于2g内存的服务器的容量规划了
 
一个apache + mod_php的服务器:一个apache进程一般需要4m内存
因此在一个1g内存的机器上:apache_max_process_with_good_perfermance < (1g / 4m) * 2 = 500
apache_max_process = 500 * 1.5 = 750
所以规划你的应用让服务尽量跑在500个进程以下以保持比较高的效率,并设置apache的软上限在800个。
例子2:
一个apache + mod_resin的服务器: 一个apache进程一般需要2m内存
在一个2g内存的机器上: 
apache_max_process_with_good_perfermance < (2g / 2m ) * 2 = 2000
apache_max_process = 2000 * 1.5 = 3000
--prefix=/another_driver/apache/:建议将apache服务安装在另外一个驱动设备上的目的在于硬盘往往是一个系统使用寿命最低的设备,因此:将服务数据和操作系统完全分开,不仅能提高了数据的访问速度,更重要的,大大方便系统升级,应用备份和恢复过程。
--shared-module=max:使用这种动态加载方式载入子模块会带来5%的性能下降.但给标准化安装和维护带来的好处也远比这多。我们的应用比较固定建议使用静态的。
grep -v "#" httpd.conf.default >httpd.conf
#最大服务进程数:根据服务容量预测设置
maxclients 256 => 800
其他apache性能优化配置:
hostnamelookups off
on会带来延迟,因为对每一个请求都需要作一次dns查询。
options followsymlinks
为了得到最佳性能,并放弃对符号连接的保护,可以在需要的地方都设置followsymlinks, 而放弃使用symlinksifownermatch.
allowoverride none
如果url空间允许覆盖(通常是用.htaccess文件), 则apache会试图对每一个文件名组成部分打开.htaccess. 
directoryindex index.cgi  index.pl  index.shtml  index.html
其中最常用的应该放在前面. 不要用通配符而使用完整的列表.
enablemmap off
在apache 2.0需要搜索被发送文件的内容时,比如处理服务器端包含时, 如果os支持某种形式的mmap(2),则会对此文件执行内存映射。
在某些平台上,内存映射可以提高性能,但是在某些情况下, 内存映射会降低性能甚至影响到httpd的稳定性.我们这个应用则关闭对发送文件的内存映射比较合适。
mod_status 和 extendedstatus off
如果apache在编译时包含了mod_status, 而且在运行时设置了extendedstatus on,则, 对每个请求apache都会调用两次gettimeofday(2) (或者根据操作系统的不同,调用times(2)), 以及(pre-1.3)几个额外的time(2)调用,使状态记录带有时间标志。 为了得到最佳性能,可以设置extendedstatus off (这也是默认的).
调整 tcp 连接切断参数
   在 /etc/sysctl.conf 中加入:
   net.inet.tcp.msl=2000
   net.inet.tcp.always_keepalive=0
   
   上述设置将防止tcp连接默认以keep alive方式建立,并避免大量的空闲连接消耗os
资源;此外,tcp time_wait的等待时间也从60秒减少到4秒。
 调整 ufs dirhash 允许的内存用量
   vfs.ufs.dirhash_maxmem=67108864 (此设置在5.3p14中已经自动包括)
   
   这一设置将os默认值提高32倍。
 在 apache 配置中禁用 keepalive:
   编辑 /usr/local/etc/apache2/httpd.conf,将
      keepalive on
   改为
      keepalive off
在负载较大的服务器上,上述设置将把同时联到 httpd 上的连接从大约2200降低到400
以下。并有效改善响应时间。此前(大约3周)已经在部分机器上应用了上述设置,目前
为止基本可以确认这些设置不会造成可以为用户所感知的不良影响,同时会改善服务的
响应时间,因此建议在线的全部系统均应用上述设置。
具体技术细节
目前在线上的 freebsd 5.3 版本(无论patchlevel)的sinamail内核中均联入了
accf_http,其作用是在来自客户的http请求完成之后再将其发给应用程序,从而降低
由于客户端网络较慢导致httpd过早开始等待连接所造成的资源消耗。
禁用keepalive之后,客户端在请求多个资源时,将有更大机会发出并发的请求。从
而,由于链路发生丢包等问题而发生的延迟对于下载其他资源的影响将会削弱。缩短
tcp分片超时之后,等待连接关闭的时间将缩短,并使建立的连接更趋稳定。
默认的dirhash最大内存为2mb。目前在生产系统上获得的实际用量通常在16-20mb左
右。将其扩大将改善同一目录下的文件的访问性能。
 
简单性能测试:(建议对配置各种参数分别测试,找出最佳优化参数)
用apache自己带的ab,进行测试的方法,如需要自己测试下就可以了。
[yangbin1@vhost-rh9 apache]$ ./bin/ab -n 10000 -c 100  http://10.210.128.189:7981/
this is apachebench, version 2.0.40-dev <$revision: 1.121.2.8 $> apache-2.0
copyright (c) 1996 adam twiss, zeus technology ltd, http://www.zeustech.net/
copyright (c) 1998-2002 the apache software foundation, http://www.apache.org/
benchmarking 10.210.128.189 (be patient)
completed 1000 requests
completed 2000 requests
completed 3000 requests
completed 4000 requests
completed 5000 requests
completed 6000 requests
completed 7000 requests
completed 8000 requests
completed 9000 requests
finished 10000 requests

Server Software:        Apache/2.0.49
Server Hostname:        10.210.128.189
Server Port:            7981
Document Path:          /
Document Length:        1456 bytes
Concurrency Level:      100
Time taken for tests:   20.756253 seconds
Complete requests:      10000
Failed requests:        0
Write errors:           0
Total transferred:      19192048 bytes
HTML transferred:       14653184 bytes
Requests per second:    481.78 [#/sec] (mean)
Time per request:       207.563 [ms] (mean)
Time per request:       2.076 [ms] (mean, across all concurrent requests)
Transfer rate:          902.96 [Kbytes/sec] received
Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0   78  60.7     99     554
Processing:    20  125  57.8    114    1149
Waiting:        5  111  53.2    104     869
Total:         47  204  84.4    214    1303
Percentage of the requests served within a certain time (ms)
  50%    214
  66%    218
  75%    220
  80%    223
  90%    264
  95%    302
  98%    447
  99%    530
 100%   1303 (longest request)
测试结果分析:暂时没有。

 以上就是Apache的性能优化(六)的内容,更多相关内容请关注PHP中文网(www.php.cn)! 

Fotor
Fotor

Fotor 在线照片编辑器

下载
数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

76

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

117

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

350

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

63

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

109

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

108

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

243

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

684

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

179

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
RunnerGo从入门到精通
RunnerGo从入门到精通

共22课时 | 1.8万人学习

尚学堂Mahout视频教程
尚学堂Mahout视频教程

共18课时 | 3.3万人学习

Linux优化视频教程
Linux优化视频教程

共14课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号