一、httpd-2.4:依赖于更高版本的apr和apr-util,需要1.4以及以上版本。

apr:apache portable runtime 是apache实现跨平台的工具。

 

1、 httpd-2.4的新特性:

(1)、 MPM支持在运行时装载。

   如:--enable-mpms-shared=all --with-mpm=event

(2)、支持event mpm

(3)、支持异步读写

(4)、在每模块以及每个目录上指定日志级别。

(5)、每请求配置<If>,<Elseif>

(6)、增强的表达式分析器

(7)、毫秒级的keepalive timeout,如100ms

(8)、基于FQDN的虚拟主机不再需要NameVirtualHost命令

(9)、支持使用自定义变量。

(10)、新增了一些特性模块:mod_proxy_fcgi,mod_ratelimit,mod_request,mod_remoteip

(11)、对于基于IP的访问控制做了修改,不再支持使用order ,allow,deny这些配置,而统一使用require进行

httpd2.4_httpd-2.4


2、编译安装httpd-2.4步骤(相关软件已上传51cto down中):

注意httpd-2.4.9要使用apr-1.5.0以及以上版本。

(1)、解决依赖关系,需要安装:

   #yum -y install pcre-devel

   #yum -y groupinstall  "Server Platform Development"

   #yum -y groupinstall "Development tools"


(2)、编译安装apr(http://apr.apache.org下载apr):

   #tar xf apr-1.5.0.tar.bz2

   #cd apr-1.5.0

   #./configure --prefix=/usr/local/apr

   #make && make install


(3)、编译安装apr-util,因apr-util依赖于apr,所以编译时要指定--with-apr的位置:

   #tar xf apr-util-1.5.3.tar.bz2

   #cd apr-util-1.5.3

   #./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr

   #make && make install


(4)、编译安装httpd-2.4:

   #tar xf httpd-2.4.9.tar.bz2

   #cd httpd-2.4.9

   #./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd24 --enable-so 

    --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre 

    --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util 

    --enable-modules=most --enable-mpms-shared=all --with-mpm=event

    --enable-proxy --enable-proxy-http --enable-proxy-ajp

   #make && make install

注意:在编译安装httpd2.4时,构建MPM模块,有两种选择,一种是把MPM编译成静态模块,另一种是把MPM编译成动态模块。如果把MPM编译成了静态模块,那么要改变MPM,只能通过重新编译安装httpd修改,比较麻烦。如果在编译安装httpd时,把MPM编译成了动态模块,那么改变MPM,可以在/etc/httpd/httpd.conf配置文件中编辑LoadModule指令选择不同的MPM重新载入即可。这里就是采用的动态模块 --enable-so 


3、httpd-2.4:编译安装后的后续配置:

(1)、导出头文件,目的是要基于apache进行二次开发或者后续编译php要用到:

#ln -sv /usr/local/apache/include /usr/include/httpd

(2)、导出库文件:没有库文件,如果有#vi /etc/ld.so.conf.d/httpd.conf


(3)、导出帮助手册:

  #vi /etc/man.config中加MANPATH /usr/local/apache/man


(4)、输出二进制程序,即安装服务:

  A、#vi /etc/profile.d/httpd.sh

  内容为:export PATH=/usr/local/apache/bin:$PATH

  重读配置文件:#source httpd.sh

  B、启动Apache2.4.9 :#apachectl start

  C、运行httpd -V 查看安装的apache版本。

httpd2.4_httpd-2.4_02

D、启动后访问页面:

httpd2.4_httpd-2.4_03


4、MPM模块:

(1)、httpd2.2只支持prefork和worker两种MPM模块,默认为prefork。两种模块的具体配置信息在/etc/httpd/conf/httpd.conf中。如果要使用worker要修改#vi /etc/sysconfig/httpd中的#HTTPD=/usr/sbin/httpd.worker,将#注释去掉即可。

(2)httpd2.4支持prefork、worke和event三种MPM模块。具体参数配置信息在/etc/httpd24/extra/httpd-mpm.conf中。上面编译默认使用event,那么将event修改为prefork,动态修改/etc/httpd24/httpd.conf中的LoadModule即可,见下图:

httpd2.4_httpd-2.4_04

(3)、httpd2.4中event参数说明如下:

<IfModule mpm_event_module>

    StartServers             默认进程数

   ThreadsPerChild          每个子进程可以生成的线程数

    MinSpareThreads          最小空闲线程数

    MaxSpareThreads          最大空闲线程数

    MaxRequestWorkers        最大线程数量

    MaxConnectionsPerChild   子进程的最大连接数,当达到设置值以后,APACHE就会结束当前的子进程

</IfModule>

5、httpd2.4基于IP的访问控制:

(1)、httpd2.2使用order allow,deny而httpd2.4使用Require。

(2)、允许所有主机访问:Require all granted

拒绝所有主机访问:Require all deny

限定特定IP主机访问:Require ip IPADDR

限定特定IP主机不可访问:Require not ip IPADDR

注:IPADDR 可以为192.168.1.110;

         192.168.1.110/255.255.255.0;

       192.168.1.110/24

       192.168

(3)、限定特定主机名访问:Require host HOSTNAME

限定特定主机名不可访问:Require host HOSTNAME

注:HOSTNAME 可以为具体主机: www.a.com

          DOMAIN域名: .a.com

6、配置虚拟主机:

(1)、关闭中心主机:注释掉DocumentRoot "/usr/local/apache/htdocs"

(2)、启用httpd-vhosts.conf:去掉注释Include /etc/httpd24/extra/httpd-vhosts.conf

(3)、在httpd-vhosts.conf配置虚拟主机即可。


二、I/O模型:

1、阻塞/非阻塞:从调用者的角度看调用者怎么被处理的。

(1)、阻塞:当一个进程发起I/O调用时,被调用的I/O不能立即返回结果,

    那么当前进程未完成之前,当前进程会被挂起。

(2)、非阻塞:当一个进程发起I/O调用时,被调用的I/O完成前不会阻塞当前进程而是立即返回一个结果(结果无论成功与否),发起者需要自己不断的监听结果是否完成。

2、同步/异步:从被调用者的角度看被调用者怎么响应的。

(1)、同步:进程发起一个过程调用(功能、函数)调用后,在没得到结果前,该调用将不会返回。

(2)、异步:进程发起一个过程调用(功能、函数)调用后,即使调用者不会理解得到结果,

         该调用却会返回,返回的是未完成状态,当调用完成后,内核会自行通知调用者。

3、I/O模型:

(1)、等待数据:数据从磁盘经内核处理后到内核内存;

等待复制完成:然后将数据从内核内存Copy到进程内存。


 A、同步阻塞:一个进程只能响应一个请求,很少用。

 B、同步非阻塞:先非阻塞,在阻塞,效率比同步阻塞还低,很少用。

 C、I/O复用:多个同步阻塞。

   简单解释就是,能一下看到所有请求的进展,但需要不停的查看。

   常用实现方式有select(),poll()。perfork就是使用I/O复用的select()方式实现的。

 D、event事件驱动:先异步非阻塞,在阻塞。

   简单解释就是,不用查看所有请求的进展,好了会自动通知,可见效率提高。

    边缘触发:只通知一次。

    水平触发:如果一次没通知到,就通知多次。

 E、AIO:真正的异步非阻塞。


(2)、mmap:数据经内核处理后到内核内存,用户进程直接访问内核内存中的数据。

   注:Nginx:支持异步IO,边缘触发,MMap。