Apache自带压力测试工具ab,简单易用,且能够模拟各类条件对web服务器发起测是请求 ab工具能够直接在web服务器本地发起测是请求,这对于须要了解服务器的处理性能相当重要,由于它不包括数据的网络传输时间以及用户pc本地的计算时间,从而能够经过观测各类时间指标判断web服务器的性能,以便进行参数的优化调整
优化前先使用ab进行压力测试 优化后,重启服务,再使用ab进行压力测试 对比两次测试的结果,看优化效果是否明显 为了能更客观的评价web服务的性能,通常优化先后都要进行屡次测试,取测试的平均值进行对比
ab[options] 网站网址 -n,-c,-t,-v
#Apac/usr/local/httpd/bin/ab -n5000 -c900 www.kgc.com/index.html
在测试时要根据状况调整求总数与并发用户数he工做模式介绍html
Apache做为先今web服务器用的最为普遍也是最稳定的开源服务器软件。 其工做模式有许多中,源码包安装HTTPD时可查看httpd-mpm.cong文件,该文件位于extra/conf目录中 目前主要有两种模式: event模式 preork模式 worker模式 工做模式怎么区分 prefork:一个进程中包含一个线程 worker/event:一个进程中包含多个进程
event是Apache最新的工做模式,他和worker模式很像,不一样的是在于它解决了keep-alive长链接的时候占用线程资源被浪费的问题 event工做模式在遇到某写不兼容的模块时,会失效,将会回退到worker模式 event工做模式须要Linux系统(Linux 2.6+)对epoll的支持,才能启用,须要补充的是HTTPS的链接(SSL) event创建链接,保持链接,就像打电话说一下子挂段,再说一下子挂段,我能够设置超时时间,超过就断开,随时能够断开会话功能。
在event工做模式中,会有一些专门的线程用来管理这些keep-alive类型的线程 当有真实请求过来的时候,将请求传递给服务器的线程,执行完毕后,又容许它释放,这样,一个线程就能处理几个请求了,实现了异步非阻塞。这加强了在高并发场景下的请求处理 灵活控制,多个请求时,能够把以前的进程释放,能处理高并发
<ifMoudle mpm_event_module> StartServers 3 配置文件中,启动3个进程 MinSpare Threads 75 最少空闲的线程数量 75 MaxSpare Threads 250 最大空闲的线程数量 250 ThreadsPerChild 25 每一个进程中默认开启25个线程 MaxRequestWorkers 400 并发最大请求数量400个 MaxConnectionsPerChild 0 若是设置为0.子进程将永远不会结束,若是设置成非0值,能够防止运行PHP致使的内存泄露
prefork是一个多路处理模块(MPM),实现了一个进程型的,预排生的web服务器,适合于没有线程安全库,须要避免线程兼容性问题的系统 再要求每一个请求相互独立的状况下具备很好的特性。若一个请求出现问题不会影响到其余请求 具备很强的自我调节能力,只须要不多的配置指令进行调整就能够适合于企业应用要求 最重要的是将MaxClients设置为一个足够大的数值已处理潜在的请求高峰,同时又不能太大,以免所需的内存超出物理内存的大小
一个单独的控制进程(父进程)负责产生子进程,子进程用于监听请求并做出应答,所以在内存中会一直存在一些备用的(spare)或是空闲的子进程,用于响应新的请求,可加快响应速度 父进程一般以root身份 运行,以便绑定80端口,子进程一般以一个低特权的用户运行,可经过配置项的User和Group配置 运行子进程的用户必需要对网站内容有读取权限,可是对其余资源必须拥有尽量少的权限,以保证系统安全 编译安装时没有指定工做模式,默认会使用prefork模式,可用httpd -l查看
<ifModule mpm_prefork_module> StartServers 20 最大进程数 MinSpareServers 10 最少空闲进程 MaxSpareServers 50 最多空闲进程 MaxClients 150 最多建立多少个子进程用来处理请求 MaxRequestPerChild 0 每一个进程处理的最大请求数,到请求数,进程即被销毁,若是设置为0,子进程永远不会结束
可根据生产环境进行调试,以肯定合适参数 ##优化参考 <IfModule mpm prefork module> ServerLimit 1000 StartServers 10 MinSpareServers 10 MaxSpareServers 30 MaxClients 1000 MaxRequestsPerChild 5000 </IfModule>
worker也是多路处理模块(MPM),使网路服务支持混合的多线程进程 因为使用线程来处理请求,全部能够处理海量请求,而系统资源的开销小于基于进程的MPM 可是也使用了多进程,每一个进程又有多个线程,以得到基于进程的MPM的稳定性 控制该MPM的最重要的指令是:控制每一个子进程容许创建的线程数ThreadsPerChild指令和控制容许创建的总线程数的MaxClients指令
每一个进程可以拥有的线程数量是固定的,服务器会根据负载状况增长或减小进程数量 一个单独的控制进程(父进程)负责子进程的创建,每一个子进程可以创建ThreadsPerChild数量的服务线程和一个监听线程,监听线程监听接入请求并将其传递给服务器进程处理和应答 Apache老是会维持一个备用(spare)或是空闲的服务器线程池,客户端无需等待新线程或新进程的创建便可获得服务 父进程通常都是以root身份启动,以绑定80端口;随后,Apache以较低权限的用户创建子进程和线程 User和Group指令用于配置Apache子进程的运行用户。子进程要对网页内容拥有读取权限,但应该尽量限制权限
参数 说明 ServerLimit 最大进程数,默认值16“” ThreadL imit 每一个子进程的最大线程数,默认值是"64” StartServers 服务器启动时创建的子进程数,默认值是"3" MaxClients 容许同时接受的最大接入请求数量(最大线程数量) MinSpare Threads 最小空闲线程数,,默认值是"75" MaxSpare Threads 设置最大空闲线程数。默认值是"250" ThreadsPerChild 每一个子进程创建的常驻的执行线程数。默认值是25 MaxRequestsPerChild 设置每一个子进程在其生存期内容许伺服的最大请求数量。设置为"0",子进程将永远不会结束
[root@localhost httpd-2.4.29]#./configure \ --with-mpm=prefork \ ##添加工做模式此配置项 [root@localhost httpd-2.4.29]# vim /etc/httpd.conf 输入/mpm查找此关键词,将前面的#注释删除 Include conf/extra/httpd-mpm.conf ##定位到这行将注释删除,启用功能 [root@localhost ~]# cd /usr/local/httpd/conf/extra/ [root@localhost extra]# vim httpd-mpm.conf <IfModule mpm_prefork_module> StartServers 10 ##启动的时候建立的进程数量改成10 MinSpareServers 10 ##空闲最小改成10 MaxSpareServers 20 ##最大设为20 MaxRequestWorkers 200 ##访问设量为200 MaxConnectionsPerChild 0 </IfModule> ##修改完成按Esc退出插入模式,输入:wq保存退出 [root@localhost extra]# cd ../../bin/ [root@localhost bin]# ./apachectl stop [root@localhost bin]# ./apachectl start ##从新关闭开启服务 [root@localhost bin]# lsof -i :80 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME httpd 58933 root 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN) httpd 58937 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN) httpd 58938 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN) httpd 58939 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN) httpd 58940 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN) httpd 58941 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN) httpd 58942 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN) httpd 58943 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN) httpd 58944 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN) httpd 58945 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN) httpd 58946 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN) ##除去一个主进程,其余的子进程变为10个
目录的权限设置使用<Directory 目录路径>和</Directory>这对语句为主目录或虚拟目录设置权限 它们是一对容器语句,必须成对出现,它们之间封装的是具体的设置目录权限语句,这些语句仅对被设置目录及其子目录起做用
参数 做用 Options 设置在特定目录使用哪些特性 AllowOverride 容许存在于.htaccess文件中的指令类型 Require 设置目录的访问控制 Indexes 当用户访问该目录时,但没有指定要访问哪一个文件,并且目录下不存在默认网页时,返回目录中的文件和子目录列表 MultiViews 内容协商的多重视图,Apache的一个智能特性。 当访问目录中不存在的对象时 ExecCGI 容许在该目录下执行CGI脚本 FollowSymLinks 在该目录下容许文件系统使用符号链接 Includes 容许服务器端包含功能 IncludesNoExec 容许服务器端包含功能,但禁止执行CGI脚本 All 包含除了MultiViews以外全部特性,若是没有Options语句,默认为All
[root@localhost bin]# vim /etc/httpd.conf //输入/htdocs查找此关键词,找到以下字段,其中有两个功能起到支持做用: DocumentRoot "/usr/local/httpd/htdocs" <Directory "/usr/local/httpd/htdocs"> # # Possible values for the Options directive are "None", "All", # or any combination of: # Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews # # Note that "MultiViews" must be named *explicitly* --- "Options All" # doesn't give it to you. # # The Options directive is both complicated and important. Please see # http://httpd.apache.org/docs/2.4/mod/core.html#options # for more information. # Options Indexes FollowSymLinks //1.Index:以列表形式展示 //2.FollowSymLinks而且支持连接性的文件 # # AllowOverride controls what directives may be placed in .htaccess files. # It can be "All", "None", or any combination of the keywords: # AllowOverride FileInfo AuthConfig Limit # AllowOverride None # # Controls who can get stuff from this server. # Require all granted //黑白名单 </Directory> #咱们能够先关闭防火墙,使用宿主机的浏览器进行验证 [root@localhost bin]# systemctl stop firewalld.service [root@localhost bin]# setenforce 0 [root@localhost bin]# cd /usr/local/httpd/htdocs/ [root@localhost htdocs]# ls index.html [root@localhost htdocs]# cat index.html <html><body><h1>It works!</h1></body></html> [root@localhost htdocs]# ls index.html [root@localhost htdocs]# mv index.html a.html [root@localhost htdocs]# ls a.html [root@localhost htdocs]# touch b.html c.html d.html [root@localhost htdocs]# ls a.html b.html c.html d.html //此时会以文件列表的形式展示,从另外一个角度咱们能够利用这点来作文件下载资源的提供,此时就不须要首页识别
[root@localhost htdocs]# ln -s /usr/share/man/ ./ //把man手册放入这个文件夹,看他能不能识别这个连接文件 [root@localhost htdocs]# ls a.html b.html c.html d.html man