apache 的工作模式

Apache工作模式介绍

Apache作为现今web服务器用的最惯广泛也是最稳定的开源服务器软件

其工作模式有多种,源码包安装httpd时可查看httpd-mpm.conf文件,该文件位于extra/conf目录中

Apacher目前主要的工作模式

event模式:灵活控制长连接
prefork模式:一个进程包括有个线程
worker模式: 一个进程包括多个线程
查看apache当前工作模式
[root@apache1 bin]# ./httpd -l

2.1、event工作模式介绍

event是Apache最新的工作模式,它和worker模式很像,不同的是在于它解决了keep-alive长链接的时候占用线程资源被浪费的问题。
event工作模式在遇到某些不兼容的模块时,会失效,将会回退到worker模式
event工作模式需要linux系统(Linux 2.6+)对epoll的支持,才能启用。需要补充的是HTTPS的连接(SSL)

2.2、event工作方式

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

2.3、event参数

在httpd-mpm-conf配置文件中,以下是prefork模块的定义
<IfModule mpm-event-module>
  StartServers        3
  MinSpareThreads      75
  MaxSpareThreads      250
  ThreadsPerchild       25
  MaxRequestWorks    400
  MaxConnectionsPerChild    0
  </IfModule>
参数说明
参数说明
StartServers服务启动时初始的进程数,默认是3
MinSpareThreads最小的空闲子进程数,默认是75
MaxSpareThreads最大的空闲子进程数,默认是250
ThreadsPerchild每个子进程产生的线程数量,默认是25
MaxRequestWorks
MaxConnectionsPerChild每个子进程在其生命周期内允许最大的请求数量,如果请求总数已达到这个数值,子进程将会结束,如果设置为0,子进程将永远不会结束,将该值设为非0置,可以防止运行PHP导致的内存泄漏

2.4、event优化建议

可根据生产环境进行调试,以确定合适参数

优化参考

<IfModule mpm-event-module>
  Serverlimit       1000         //确认线程的最大数量
  StartServers        20
  MinSpareThreads      25
  MaxSpareThreads      1200
  ThreadsPerchild       50
  MaxRequestWorks    2000
  MaxConnectionsPerChild    1000
  </IfModule>

prefork工作模式介绍

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

prefork工作模方式

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

在httpd-mpm-conf配置文件中,以下是prefork模块的定义
<IfModule mpm-prefork-module>
  StartServers        20
  MinSpareServers    10
  MaxSpareServers     50
  MaxClients       150
  MaxRequestsPerChild     0
  </IfModule>
参数详解
参数说明
ServerLinit最大进程数
StartServers启动时创建的进程数量
MinSpareServers最少空闲进程
MaxSpareServers最多空闲进程
MaxClients最多创建多少个进程用来处理请求
MaxRequestsPerChild每个进程的最大请求数,达到请求数,进程即被销毁,如果设置为0,子进程永远不会结束
prefork优化建议

优化参考

<IfModule mpm-prefork-module>
   ServerLimit        1000
  StartServers        10
  MinSpareServers    10
  MaxSpareServers     30
  MaxClients       1000
  MaxRequestsPerChild     5000
  </IfModule>

worker工作模式介绍

(1)worker也是多路处理模块(MPM),使网络服务器支持混合的多线程多进程

(2)由于使用线程来处理请求,所以可以处理海量请求,而系统资源的开销小于基于进程的MPM

(3)但是也使用了多进程,每个进程又有多个线程,以获得基于进程的 MPM的稳定性

(4)控制该MPM的最重要的指令是:控制每个子进程允许建立的线程数ThreadsPerChild指令和控制允许建立的总线程数的MaxClients指令

worker工作方式

(1)每个进程能够拥有的线程数量是固定的, 服务器会根据负载情况增加或减少进程数量

(2)一个单独的控制进程(父进程)负责子进程的建 立。每个子进程能够建立ThreadsPerChild数量 的服务线程和一个监听线程,监听线程监听接入请求并将其传递给服务线程处理和应答

(3)Apache总是会维持一 个备用(spare)或是空闲的服务线程池, 客户端无须等待新线程或新进程的建立即可得到服务

(4)父进程一般都是以 root身份启动,以绑定80端口;随后, Apache以较低权限的用户建立子进 程和线程

(5)User和Group指令用于配置 Apache子进程的运行用户。子进程要对网页内容拥有读权限,但应该尽可能限制权限

在httpd-mpm-conf中worker的定义
<IfModule mpm-worker-module>
  StartServers        2
  MaxClients       150
  MinSpareThreads    25
  MaxSpareThreads     75
  ThreadsPerChild     25
  MaxRequestsPerChild     0
  </IfModule>
worker参数详解
参数说明
ServerLimit最大进程数,默认值是“16”
TheadLimit每个子进程的最大线程数,默认值是“46”
StartServers服务器启动时建立的子进程数,默认值是“3”
MaxClients允许同时接受的最大接入请求数量(最大线程数)
MinSpareThreads最小空闲线程数,默认值为“75”
MaxSpareThreads设置最大空线程数,默认值是“250”
ThreadsPerChild每个子进程建立的常驻的执行线程数,默认值是25
MaxRequestsPerChild设置为每个子进程在其生存期内允许伺服的最大请求数量,设置为“0”,子进程将永远不会结束

worker优化建议

<IfModule mpm-worker-module>
  ServerLimit         40
  ThreadLimit         200
  StartServers        20
  MaxClients         1000
  MinSpareThreads    25
  MaxSpareThreads    100
  ThreadsPerChild     200
  MaxRequestsPerChild    1000
  </IfModule>

Apache目录属性

目录的权限设置使用<Directory 目录路径>和这对语句为主目录或虚拟目录设置权限
它们是一对容器语句,必须成对出现,它们之间分装的是具体的设置目录权限语句,这些语句仅对被设置目录及其子目录其作用
目录属性参数
参数作用
Options设置在特定目录使用那些特性
AllowOverride允许存在于.htaccess文件中的指令类型
Require设置目录的访问控制
Apache目录属性
参数作用
Indexes当用户访问目录时,但没有指定要访问那个文件,而且目录下不存在默认网页时,返回目录中的文件和子目录列表
MultiViews内容协商的多重视图,Apache的一个智能特性。当访问目录中不存在的对象时
ExecCGl允许在该目录下执行CGI脚本
FollowSymlinks在该目录下允许文件系统使用符号连接
Incldues允许服务器端包含功能
IncludesNoExec允许服务器端包含功能,但禁止执行CGI脚本
All包含除了MultiViews之外的所有特性,如果没有Options语句,默认为All
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值