Apache网页深入优化之ab压力测试、工作模式与目录属性优化
ab压力测试工具
Apache自带压力测试工具ab,简单易用,且可以模拟各种条件对Web服务器发起测试请求。ab工具可以直接在Web服务器本地发起测试请求,这对于需要了解服务器的处理性能至关重要,因为它不包括数据的网络传输时间以及用户PC本地的计算时间,从而可以通过观测各种时间指标判断Web服务器的性能,以便进行参数的优化调整。
在进行性能调整优化过程中,可用ab压力测是工具进行优化效果的测试:
1.优化前先使用ab进行压力测试
2.优化后,重启服务,再使用ab进行压力测试
3.对比两次测试的结果,看优化效果是否明显
4.为了能更客观的评价web服务的性能,一般优化前后都要进行多次测试,取测试结果的平均值进行对比
ab工具使用
命令格式
ab [options] 网站网址
相关参数
-n 发送的请求量-c 并发量-t 测试所进行的最大秒数-v 设置显示信息的详细程度
示例
/usr/local/httpd/bin/ab -n5000 -c900 www.kgc.com/index.html
//在测试时要根据情况调整求总数与并发用户数
ab测试结果关键参数说明
参数 | 描述 |
---|---|
Server Software | http响应数据的头信息 |
Server Hostname | 请求的url中的主机名称 |
Server Port | web服务器软件的监听端口 |
Document Path | 请求的url根的绝对路径 |
Document Length | http响应数据的正文长度 |
Concurrency Level | 并发的用户数 |
Time taken for tests | 所有这些请求被处理完成所花费的时间总和 |
Complete requests | 表示总请求数 |
Failed requests | 失败的请求总数 |
Total transferred | 请求的响应数据长度总和 |
Requests per second | 服务器的吞吐率,每秒处理的请求数 |
Time per request | 用户平均请求等待时间 |
Time per request | 每个请求实际运行时间的平均值 |
Percentage of the requests served within a certain time (ms) | 描述每个请求处理时间的分布情况 |
Apache工作模式概述
Apache作为现今web服务器用的最广泛也是最稳定的开源服务器软件。其工作模式有许多种,源码包安装httpd时可查看httpd-mpm.conf文件,该文件位于extra/conf目录中。
主要有两种模式
名称 | 特点 |
---|---|
event模式/worker模式 | 一个进程中包含多个线程 |
prefork模式 | 一个进程中只包含一个线程 |
event工作模式
(1)event是Apache最新的工作模式,它和worker模式很像,不同的是在于它解决了keep-alive长连接的时候占用线程资源被浪费的问题。event工作模式在遇到某些不兼容的模块时,会失效,将会回退到worker模式。event工作模式需要Linux系统(Linux 2.6+)对epoll的支持,才能启用。需要补充的是HTTPS的连接(SSL)
(2)在event工作模式中,会有一些专门的线程用来管理这些keep-alive类型的线程。当有真实请求过来的时候,将请求传递给服务器的线程执行完毕后,又允许它释放。这样, 一个线程就能处理几个请求了 ,实现了 异步非阻塞。这增强了在高并发场景下的请求处理。
event参数
在httpd-mpm.conf配置文件中,以下是event模块的定义
<IfModule mpm_event_module>StartServers 3MinSpareThreads 75MaxSpareThreads 250ThreadsPerChild 25MaxRequestWorkers 400MaxConnectionsPerChild 0
</IfModule>
参数 | 说明 |
---|---|
StartServers | 服务启动时初始的进程数,默认3 |
MinSpareThreads | 最小的空闲子进程数,默认75 |
MaxSpareThreads | 最大的空闲子进程数,默认250 |
ThreadsPerChild | 每个子进程产生的线程数量,默认是25 |
MaxRequestWorkers | 限定同一时间内客户端最大接入的请求数量,默认是400 |
MaxConnectionsPerChild | 每个子进程在其生命周期内允许最大的请求数量, 如果请求总数已经达到这个数值,子进程将会结束,如果设置为0,子进程将永远不会结束。将该值设置为非0值,可以防止运行PHP导致的内存泄露 |
优化建议:可根据生产环境进行调试,以确定合适参数
优化参考:
<IfModule mpm event module>ServerLimit 1000StartServers 20MinSpareThreads 25MaxSpareThreads 1200ThreadsPerChild 50MaxRequestWorkers 2000MaxC onnectionsPerChild 1000
</IfModule>
prefork工作模式
(1)prefork是一个多路处理模块(MPM),实现了一个进程型的、预派生的web服务器,适合于没有线程安全库、需要避免线程兼容性问题的系统。在要求每个请求相互独立的情况下具有很好的特性,若一个请求出现问题不会影响到其他请求。具有很强的自我调节能力,只需要很少的配置指令进行调整就可以适合于企业应用要求。最重要的是将MaxClients设置为一个足够大的数值以处理潜在的请求高峰,同时又不能太大,以避免所需的内存超出物理内存的大小
(2)一个单独的控制进程(父进程)负责产生子进程,子进程用于监听请求并作出应答,因此在内存中会- -直存在一-些备用的(spare)或是空闲的子进程用于响应新的请求,可加快响应速度。父进程通常以root身份运行,以便绑定80端口,子进程通常以一个低特权的用户运行,可通过配置项的User和Group配置。运行子进程的用户必须要对网站内容有读取权限,但是对其他资源必须拥有尽可能少的权限,以保证系统安全。编译安装时没有指定工作模式,默认会使用prefork模式,可用httpd-l查看
prefork参数
在httpd-mpm.conf配置文件中,以下是prefork模块的定义
<IfModule mpm_ prefork module>StartServers 20MinSpareServers 10MaxSpareServers 50MaxClients 150MaxRequestsPerChild 0
</IfModule>
参数 | 说明 |
---|---|
ServerLimit | 最大进程数 |
StartServers | 启动的时候创建的进程数量 |
MinSpareServers | 最少空闲进程 |
MaxSpareServers | 最多空闲进程 |
MaxClients | 最多创建多少个子进程用来处理请求 |
MaxRequestsPerChild | 每个进程处理的最大请求数,达到请求数,进程即被销毁,如果设置为0,子进程永远不会结束 |
优化建议:可根据生产环境进行调试,以确定合适参数
优化参考:
<IfModule mpm prefork module>ServerLimit 1000StartServers 10MinSpareServers 10MaxSpareServers 30MaxClients 1000MaxRequestsPerChild 5000
</IfModule>
worker工作方式
每个进程能够拥有的线程数量 是固定的,服务器会根据负载情况增加或减少进程数量。一个单独的控制进程(父进程)负责子进程的建立。每个子进程能够建立ThreadsPerChild数量的服务线程和一个监听线程,监听线程监听接入请求并将其传递给服务线程处理和应答。Apache总是会维持一个备用(spare)或是空闲的服务线程池, 客户端无须等待新线程或新进程的建立即可得到服务。父进程一般都是以root身份启动,以绑定80端口;随后,Apache以较低权限的用户建立子进程和线程。User和Group指令用于配置Apache子进程的运行用户。 子进程要对网页内容拥有读权限,但应该尽可能限制权限。
worker参数
参数 | 说明 |
---|---|
ServerLimit | 最大进程数,默认值是"16" |
ThreadLimit | 每个子进程的最大线程数,默认值是“64” |
StartServers | 服务器启动时建立的子进程数,默认值是"3" |
MaxClients | 允许同时接受的最大接入请求数量(最大线程数量) |
MinSpare Threads | 最小空闲线程数,默认值是"75" |
MaxSpareThreads | 设置最大空闲线程数。默认值是"250" |
ThreadsPerChild | 每个子进程建立的常驻的执行线程数。默认值是25 |
MaxRequestsPerChild | 设置每个子进程在其生存期内允许伺服的最大请求数量。设置为"0",子进程将永远不会结束 |
Apache目录属性
目录的权限设置使用<Directory 目录路径>和< /Directory > 这对语句为主目录或虚拟目录设置权限。它们是一-对容器语句,必须成对出现,它们之间封装的是具体的设置目录权限语句,这些语句仅对被设置目录及其子目录起作用。
目录属性参数
参数 | 作用 |
---|---|
Options | 设置在特定目录使用哪些特性 |
AllowOverride | 允许存在于htaccess文件中的指令类型 |
Require | 设置目录的访问控制 |
Indexes | 当用户访问该目录时,但没有指定要访问哪个文件,而且目录下不存在默认网页时,返回目录中的文件和子目录列表 |
MultiViews | 内容协商的多重视图,Apache的一 个智能特性。当访问目录中不存在的对象时 |
ExecCGI | 允许在该目录下执行CGI脚本 |
FollowSymLinks | 在该目录下允许文件系统使用符号连接 |
Includes | 允许服务器端包含功能 |
IncludesNoExec | 允许服务器端包含功能,但禁止执行CG |
All | 包含除了MultiViews之外所有特性,如果没有Options语句,默认为All |
实例演示
Apache工作模式之prefork工作模式
一、共享资源包,并编译安装Apache服务
[root@localhost ~]# smbclient -L //192.168.10.37
Enter SAMBA\root's password: Sharename Type Comment--------- ---- -------LNMP Disk [root@localhost ~]# mount.cifs //192.168.10.37/LNMP /abc
Password for root@//192.168.10.37/LAMP:
[root@localhost ~]# cd /abc
[root@localhost abc]# ls
apr-1.6.2.tar.gz game.jpg
apr-util-1.6.0.tar.gz httpd-2.4.29.tar.bz2
awstats-7.6.tar.gz install_lamp.sh
cronolog-1.6.2-14.el7.x86_64.rpm mysql-5.6.26.tar.gz
Discuz_X2.5_SC_UTF8.zip nginx-1.12.0.tar.gz
error.png php-5.6.11.tar.bz2[root@localhost abc]# tar jxvf httpd-2.4.29.tar.bz2 -C /opt
[root@localhost abc]# tar zxvf apr-1.6.2.tar.gz -C /opt
[root@localhost abc]# tar zxvf apr-util-1.6.0.tar.gz -C /opt
[root@localhost abc]# ls /opt
apr-1.6.2 apr-util-1.6.0 httpd-2.4.29 rh
[root@localhost opt]# mv apr-1.6.2/ httpd-2.4.29/srclib/apr
[root@localhost opt]# mv apr-util-1.6.0/ httpd-2.4.29/srclib/apr-util
[root@localhost opt]# cd httpd-2.4.29/
[root@localhost httpd-2.4.29]# yum install -y gcc gcc-c++ pcre-devel zlib-devel expat-devel
[root@localhost httpd-2.4.29]# ./configure \
> --prefix=/usr/local/httpd \
> --enable-deflate \
> --with-mpm=prefork \
> --enable-expires \
> --enable-so \
> --enable-rewrite \
> --enable-charset-lite \
> --enable-cgi[root@localhost httpd-2.4.29]# make && make install[root@localhost httpd-2.4.29]# ln -s /usr/local/httpd/conf/httpd.conf /etc/httpd.conf
二、编辑Apache服务的相关配置文件
1.修改httpd.conf主配置文件
[root@localhost httpd-2.4.29]# vim /etc/httpd.conf
458 Include conf/extra/httpd-mpm.conf
//检索到第458 行的的mpm模块,删除注释符#以启用功能51 Listen 192.168.235.137:80 //检索到地51行的IPv4监听,取消注释并修改地址为本地Linux服务器的地址52 #Listen 80
//注释第52行的IPv6监听193 ServerName www.accp.com:80
//检索到第193行,取消注释并自行编辑域名,此处仅供参考
2.查看httpd-mpm.conf配置文件,确认prefork工作模式默认参数
[root@localhost httpd-2.4.29]# cd /usr/local/httpd/conf/extra/ //进入扩展目录
[root@localhost extra]# ls //可见httpd-mpm.conf配置文件
httpd-autoindex.conf httpd-mpm.conf
httpd-dav.conf httpd-multilang-errordoc.conf
httpd-default.conf httpd-ssl.conf
httpd-info.conf httpd-userdir.conf
httpd-languages.conf httpd-vhosts.conf
httpd-manual.conf proxy-html.conf[root@localhost extra]# vim httpd-mpm.conf 28 <IfModule mpm_prefork_module>29 StartServers 5 //启动时进程数为5个30 MinSpareServers 5 //最小空闲进程数为5个31 MaxSpareServers 10 //最大空闲进程数为10个32 MaxRequestWorkers 250 //最大并发进程数为250个33 MaxConnectionsPerChild 0 //最大连接数限制为034 </IfModule>
//查看prefork工作模式参数信息[root@localhost bin]# cd /usr/local/httpd/bin
//切换到Apache服务的/bin目录
[root@localhost bin]# ls
ab checkgid htcacheclean httxt2dbm
apachectl dbmmanage htdbm logresolve
apr-1-config envvars htdigest rotatelogs
apu-1-config envvars-std htpasswd
apxs fcgistarter httpd
[root@localhost bin]# ./apachectl start
//使用Apache服务的自带脚本开启服务[root@localhost bin]# netstat -ntap |grep 80 //查看服务的80端口是否启用
tcp 0 0 192.168.235.137:80 0.0.0.0:* LISTEN 35722/httpd [root@localhost bin]# lsof -i :80 //查看系统的80端口进程信息,其中user为root的是主进程,余下的5个都是子进程
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
httpd 35722 root 3u IPv4 43621 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 35723 daemon 3u IPv4 43621 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 35724 daemon 3u IPv4 43621 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 35725 daemon 3u IPv4 43621 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 35726 daemon 3u IPv4 43621 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 35727 daemon 3u IPv4 43621 0t0 TCP 192.168.235.137:http (LISTEN)
3.编辑httpd-mpm.conf配置文件,修改prefork工作模式参数
[root@localhost bin]# vim /usr/local/httpd/conf/extra/httpd-mpm.conf 28 <IfModule mpm_prefork_module>29 StartServers 10 //启动时进程数改为10个30 MinSpareServers 10 //最小空闲进程数改为10个31 MaxSpareServers 50 //最大空闲进程数改为50个32 MaxRequestWorkers 150 //最大并发进程数为15033 MaxConnectionsPerChild 0 34 </IfModule>
4.重新开启服务
[root@localhost bin]# ./apachectl stop
[root@localhost bin]# ./apachectl start
5.查看prefork工作模式的进程信息
//使用./httpd -l命令可查看工作模式,当前为prefork工作模式
[root@localhost bin]# ./httpd -l
Compiled in modules:core.cmod_so.chttp_core.cprefork.c//查看进程信息,相较之前的默认模式多了5个子进程
[root@localhost bin]# lsof -i :80
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
httpd 36071 root 3u IPv4 51494 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 36072 daemon 3u IPv4 51494 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 36073 daemon 3u IPv4 51494 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 36074 daemon 3u IPv4 51494 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 36075 daemon 3u IPv4 51494 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 36076 daemon 3u IPv4 51494 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 36077 daemon 3u IPv4 51494 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 36078 daemon 3u IPv4 51494 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 36079 daemon 3u IPv4 51494 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 36080 daemon 3u IPv4 51494 0t0 TCP 192.168.235.137:http (LISTEN)
httpd 36081 daemon 3u IPv4 51494 0t0 TCP 192.168.235.137:http (LISTEN)
—谢谢阅读—
Apache网页深入优化之ab压力测试、工作模式与目录属性优化相关推荐
- Apache ab压力测试工具
查看apache是否安装 # rpm -qa httpd httpd-2.2.3-63.el5.centos (在apache 版本2以后,apache全部改名为httpd) ab压力测试工具是apa ...
- Apache ab压力测试说明
转自: http://leepiao.blog.163.com/blog/static/485031302010234352282/ 压力测试是一种基本的质量保证行为,它是每个重要软件测试工 作的一部 ...
- apache ab压力测试报错apr_socket_recv
apache ab压力测试报错(apr_socket_recv: Connection reset by peer (104)) apache 自带的ab工具测试,当并发量达到1000多的时候报错如下 ...
- Apache AB 压力测试
2019独角兽企业重金招聘Python工程师标准>>> Apache AB 压力测试 安装 // 安装工具 yum install httpd-tools 使用 // URL 是网 ...
- ab压力测试是使用以及介绍
在运维工作中,压力测试是一项非常重要的工作.比如在一个网站上线之前,能承受多大访问量.在大访问量情况下性能怎样,这些数据指标好坏将会直接影响用户体验. 但是,在压力测试中存在一个共性,那就是压力测试的 ...
- ab压力测试工具linux,【Linux】ApacheBench(ab)压力测试工具
AB的简介 ab是apachebench命令的缩写. ab是apache自带的压力测试工具.ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对或其它类型的服务器进行压力测试.比 ...
- Web性能测试篇:AB 压力测试
目录 1. 压力测试的概念\定义 2. AB的起源 3. 运行平台区分(Windows\Linux|Mac) 4. 你的第一个AB GET请求脚本 5. AB发起POST.PUT请求 6. AB附带有 ...
- linux下安装ab压力测试工具及ab命令详解
yum -y install httpd-tools ab -v 查看ab版本 ab --help ab -n1000 -c 10 http://www.buruyouni.com/ http://w ...
- AB压力测试开源WAF性能分析
AB压力测试简介 ab -n 10000 -c 100 http://172.28.13.40/myzoo/index.php ab -n 10000 -c 100 http://172.27.20. ...
最新文章
- 《MongoDB权威指南》读书笔记 第一章 简介
- html 倒计时 插件,JavaScript使用小插件实现倒计时的方法讲解
- 嵌入式C语言基础(二)
- 光纤收发器常见的一些问题和检测方法
- freeCodeCamp:Diff Two Arrays
- C# 中 Struct 与 Class 的区别,以及两者的适用场合
- MySQLBackup 8.0.26 备份与恢复
- tika提取pdf信息异常
- 使用vim遇到的问题
- 郑大网教育计算机2017,2017郑大计算机操作系统(计算机).docx
- 用FL Studio制作反向人声音效(Vocal Chops)
- Javascript:FormDate和FileReader
- 苹果手机截图的两种方法
- codeblocks解决网络方面错误undefined reference to `inet_ntoa@4'|
- 数字图像处理与Python实现-图像降噪-指数型低通滤波
- oracle apex 日志,Oracle Apex 调试技巧
- crout分解计算例题_如何计算有理函数的不定积分
- pytorch 移植到Android平台(一)
- Word课程笔记(秋叶系列课程)
- 手机锁屏后有时收不到微信通知,有时又能收到是怎么回事?
热门文章
- 服务器主板能插几块硬盘,请问一块主板上可以插多少个硬盘?
- DFS_HDU_5222
- HUE中Oozie执行Sqoop
- java截取字符串的一部分_java中如何截取字符串中的指定一部分
- Opengl ES 1.x NDK实例开发之七:旋转的纹理立方体
- 闲鱼副业怎么做?闲鱼怎么搞副业?闲鱼能干啥副业?
- 计算机远程桌面在什么地方查找,远程桌面连接在哪里 来看看小编是怎么讲解的...
- php tuxedo 0 4 1,Tuxedo杂记
- 随便听听 Day 3:VOA 2021-2-15
- 你适合做程序员吗?一篇文章告诉你如何判断自己是否适合做程序员