Aapache mode of depth optimization, ab stress test, apache directory attributes

Aapache mode of depth optimization, ab stress test, apache directory attributes

ab stress test

Apache自带压力测试工具ab,简单易用,且可以模拟各种条件对web服务器发起测是请求
ab工具可以直接在web服务器本地发起测是请求,这对于需要了解服务器的处理性能至关重要,因为它不包括数据的网络传输时间以及用户pc本地的计算时间,从而可以通过观测各种时间指标判断web服务器的性能,以便进行参数的优化调整

Ab role of stress testing tool

优化前先使用ab进行压力测试
优化后,重启服务,再使用ab进行压力测试
对比两次测试的结果,看优化效果是否明显
为了能更客观的评价web服务的性能,一般优化前后都要进行多次测试,取测试的平均值进行对比

Ab use of stress testing tools, Parameters

ab[options]  网站网址

-n,-c,-t,-v

Examples


#Apac/usr/local/httpd/bin/ab -n5000 -c900 www.kgc.com/index.html

The key test tools test results illustrate ab

Aapache mode of depth optimization, ab stress test, apache directory attributes

Apache mode of presentation

When tested according to the situation and adjust the total number of concurrent users seeking work mode he introduced

Apache作为先今web服务器用的最为广泛也是最稳定的开源服务器软件。
其工作模式有许多中,源码包安装HTTPD时可查看httpd-mpm.cong文件,该文件位于extra/conf目录中
目前主要有两种模式:
event模式
preork模式
worker模式
工作模式怎么区分
prefork:一个进程中包含一个线程
worker/event:一个进程中包含多个进程

event mode of presentation

event是Apache最新的工作模式,他和worker模式很像,不同的是在于它解决了keep-alive长连接的时候占用线程资源被浪费的问题
event工作模式在遇到某写不兼容的模块时,会失效,将会回退到worker模式
event工作模式需要Linux系统(Linux 2.6+)对epoll的支持,才能启用,需要补充的是HTTPS的连接(SSL)
event建立连接,保持连接,就像打电话说一会儿挂段,再说一会儿挂段,我可以设置超时时间,超过就断开,随时可以断开会话功能。

event work

在event工作模式中,会有一些专门的线程用来管理这些keep-alive类型的线程
当有真实请求过来的时候,将请求传递给服务器的线程,执行完毕后,又允许它释放,这样,一个线程就能处理几个请求了,实现了异步非阻塞。这增强了在高并发场景下的请求处理
灵活控制,多个请求时,可以把之前的进程释放,能处理高并发

event arguments detailed

<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 mode of presentation

prefork是一个多路处理模块(MPM),实现了一个进程型的,预排生的web服务器,适合于没有线程安全库,需要避免线程兼容性问题的系统
再要求每个请求相互独立的情况下具有很好的特性。若一个请求出现问题不会影响到其他请求
具有很强的自我调节能力,只需要很少的配置指令进行调整就可以适合于企业应用要求
最重要的是将MaxClients设置为一个足够大的数值已处理潜在的请求高峰,同时又不能太大,以避免所需的内存超出物理内存的大小

prefork mode of operation mode

一个单独的控制进程(父进程)负责产生子进程,子进程用于监听请求并作出应答,因此在内存中会一直存在一些备用的(spare)或是空闲的子进程,用于响应新的请求,可加快响应速度
父进程通常以root身份 运行,以便绑定80端口,子进程通常以一个低特权的用户运行,可通过配置项的User和Group配置
运行子进程的用户必须要对网站内容有读取权限,但是对其他资源必须拥有尽可能少的权限,以保证系统安全
编译安装时没有指定工作模式,默认会使用prefork模式,可用httpd -l查看

prefork parameters to explain

<ifModule mpm_prefork_module>
StartServers  20  最大进程数
MinSpareServers  10  最少空闲进程
MaxSpareServers  50  最多空闲进程
MaxClients  150  最多创建多少个子进程用来处理请求
MaxRequestPerChild  0  每个进程处理的最大请求数,到请求数,进程即被销毁,如果设置为0,子进程永远不会结束

prefork optimization

可根据生产环境进行调试,以确定合适参数
##优化参考
<IfModule mpm prefork module>
    ServerLimit         1000
    StartServers        10
    MinSpareServers     10
    MaxSpareServers     30
    MaxClients      1000
    MaxRequestsPerChild 5000
</IfModule>

worker mode of presentation

worker也是多路处理模块(MPM),使网路服务支持混合的多线程进程
由于使用线程来处理请求,所有可以处理海量请求,而系统资源的开销小于基于进程的MPM
但是也使用了多进程,每个进程又有多个线程,以获得基于进程的MPM的稳定性
控制该MPM的最重要的指令是:控制每个子进程允许建立的线程数ThreadsPerChild指令和控制允许建立的总线程数的MaxClients指令

worker works

每个进程能够拥有的线程数量是固定的,服务器会根据负载情况增加或减少进程数量
一个单独的控制进程(父进程)负责子进程的建立,每个子进程能够建立ThreadsPerChild数量的服务线程和一个监听线程,监听线程监听接入请求并将其传递给服务器进程处理和应答
Apache总是会维持一个备用(spare)或是空闲的服务器线程池,客户端无需等待新线程或新进程的建立即可得到服务
父进程一般都是以root身份启动,以绑定80端口;随后,Apache以较低权限的用户建立子进程和线程
User和Group指令用于配置Apache子进程的运行用户。子进程要对网页内容拥有读取权限,但应该尽可能限制权限

Parameter Description worker

参数
说明
ServerLimit
最大进程数,默认值16“”
ThreadL imit
每个子进程的最大线程数,默认值是"64”
StartServers
服务器启动时建立的子进程数,默认值是"3"
MaxClients
允许同时接受的最大接入请求数量(最大线程数量)
MinSpare Threads
最小空闲线程数,,默认值是"75"
MaxSpare Threads
设置最大空闲线程数。默认值是"250"
ThreadsPerChild
每个子进程建立的常驻的执行线程数。默认值是25
MaxRequestsPerChild
设置每个子进程在其生存期内允许伺服的最大请求数量。设置为"0",子进程将永远不会结束

(The prefork solid columns)

[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个

Apache directory properties

目录的权限设置使用<Directory 目录路径>和</Directory>这对语句为主目录或虚拟目录设置权限
它们是一对容器语句,必须成对出现,它们之间封装的是具体的设置目录权限语句,这些语句仅对被设置目录及其子目录起作用

Directory attribute parameters

参数
作用
Options
设置在特定目录使用哪些特性
AllowOverride
允许存在于.htaccess文件中的指令类型
Require
设置目录的访问控制
Indexes
当用户访问该目录时,但没有指定要访问哪个文件,而且目录下不存在默认网页时,返回目录中的文件和子目录列表
MultiViews
内容协商的多重视图,Apache的一个智能特性。 当访问目录中不存在的对象时
ExecCGI
允许在该目录下执行CGI脚本
FollowSymLinks
在该目录下允许文件系统使用符号连接
Includes
允许服务器端包含功能
IncludesNoExec
允许服务器端包含功能,但禁止执行CGI脚本
All
包含除了MultiViews之外所有特性,如果没有Options语句,默认为All

Configuration directory attribute (solid columns)

[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
//此时会以文件列表的形式展现,从另一个角度我们可以利用这点来做文件下载资源的提供,此时就不需要首页识别

Aapache mode of depth optimization, ab stress test, apache directory attributes

Connection file into the site

[root@localhost htdocs]# ln -s /usr/share/man/ ./       
//把man手册放入这个文件夹,看他能不能识别这个链接文件
[root@localhost htdocs]# ls
a.html  b.html  c.html  d.html  man

Aapache mode of depth optimization, ab stress test, apache directory attributes

Guess you like

Origin blog.51cto.com/14449524/2447892