centos7之httpd-2.4的新特性

一、常用httpd-2.4新特性

1) MPM支持在运行时装载;

编译时加上此,支持mpm:--enable-mpms-shared=all --with-mpm=event

2) 支持event

3) 异步读写

4) 在每模块及每目录上指定日志级别

5) 每请求配置

6) 增强版的表达式分析器

7) 毫秒级的keepalive timeout

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

9) 支持使用自定义变量

10)新增了一些模块:mod_proxy_fcgi, mod_ratelimit, mod_request, mod_remoteip

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

二、安装httpd-2-4 

注意:在centos6.x上默认的apr版本为apr-1.3.9,而httpd-2.4需apr1.4以上。

实验准备:

①平台:centos6.8

②软件:apr1.5.0.tar.gz apr-utils-1.5.2.tar.gz httpd-2.4.10.tar.gz

③安装开发环境:Development Tools,Server Platform Development

步骤如下:

1)安装开发包组及其pcre-devel、openssl-devel包

yum -y groupinstall "Development Tools" "Server Platform Development"

yum -y install pcre-devel openssl-devel

2)编译安装apr-1.5.0.tar.gz及其apr-utils-1.5.2.tar.gz

tar xf apr-1.50.tar.gz

cd apr-1.5.0

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

make && make install

编译安装apr-utils同理:./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr make && make install

3)编译httpd-2.4.10

tar xf httpd-2.4.10.tar.gz

cd httpd-2.4.10

./configure --prefix=/usr/local/httpd24 --sysconfigdir=/etc/httpd24 --enable-so --enable-cgi --enable-rewrite --with-zlib --with-pcre --with-apr=/usr/local/apr --with-apr-util --enable-modules=most --enable-mpms-shared=all --with-mpm=prefork

make && make install

如编译出错或想重新编译需执行,删除安装目录:make clean all

4)导出头文件

ln -sv /usr/local/httpd24/include /usr/include/httpd

5)导出库文件

echo "/usr/local/httpd24/lib" >/etc/ld.so.conf.d/httpd.conf

6)导入man手册

vi /etc/man.config 加入MANPATH /usr/local/httpd/man

7)导入环境变量

echo "PATH=/usr/local/httpd/bin/:$PATH" >/etc/init.d/httpd.sh

8)配置启动脚本

vi /etc/init.d/httpd24.sh

代码演示:



# config: /etc/sysconfig/httpd
# pidfile: /var/run/httpd/httpd.pid
#
### BEGIN INIT INFO
# Provides: httpd
# Required-Start: $local_fs $remote_fs $network $named
# Required-Stop: $local_fs $remote_fs $network
# Should-Start: distcache
# Short-Description: start and stop Apache HTTP Server
# Description: The Apache HTTP Server is an extensible server
#  implementing the current HTTP standards.
### END INIT INFO
# Source function library.
. /etc/rc.d/init.d/functions
#if [ -f /etc/sysconfig/httpd ]; then
#        . /etc/sysconfig/httpd
#fi
# Start httpd in the C locale by default.
HTTPD_LANG=${HTTPD_LANG-"C"}
# This will prevent initlog from swallowing up a pass-phrase prompt if
# mod_ssl needs a pass-phrase from the user.
INITLOG_ARGS=""
# Set HTTPD=/usr/sbin/httpd.worker in /etc/sysconfig/httpd to use a server
# with the thread-based "worker" MPM; BE WARNED that some modules may not
# work correctly with a thread-based MPM; notably PHP will refuse to start.
# Path to the apachectl script, server binary, and short-form for messages.
apachectl=/usr/local/httpd24/bin/apachectl
httpd=${HTTPD-/usr/local/httpd24/bin/httpd}
prog=httpd
pidfile=${PIDFILE-/usr/local/httpd24/logs/httpd.pid}
lockfile=${LOCKFILE-/var/lock/subsys/httppd24}
RETVAL=0
STOP_TIMEOUT=${STOP_TIMEOUT-10}
# The semantics of these two functions differ from the way apachectl does
# things -- attempting to start while running is a failure, and shutdown
# when not running is also a failure.  So we just do it the way init scripts
# are expected to behave here.
start() {
        echo -n $"Starting $prog: "
        LANG=$HTTPD_LANG daemon --pidfile=${pidfile} $httpd $OPTIONS
        RETVAL=$?
        echo
        [ $RETVAL = 0 ] && touch ${lockfile}
        return $RETVAL
}
# When stopping httpd, a delay (of default 10 second) is required
# before SIGKILLing the httpd parent; this gives enough time for the
# httpd parent to SIGKILL any errant children.
stop() {
        status -p ${pidfile} $httpd > /dev/null
        if [[ $? = 0 ]]; then
                echo -n $"Stopping $prog: "
                killproc -p ${pidfile} -d ${STOP_TIMEOUT} $httpd
        else
                echo -n $"Stopping $prog: "
                success
        fi
        RETVAL=$?
        echo
        [ $RETVAL = 0 ] && rm -f ${lockfile} ${pidfile}
}
reload() {
    echo -n $"Reloading $prog: "
    if ! LANG=$HTTPD_LANG $httpd $OPTIONS -t >&/dev/null; then
        RETVAL=6
        echo $"not reloading due to configuration syntax error"
        failure $"not reloading $httpd due to configuration syntax error"
    else
        # Force LSB behaviour from killproc
        LSB=1 killproc -p ${pidfile} $httpd -HUP
        RETVAL=$?
        if [ $RETVAL -eq 7 ]; then
            failure $"httpd shutdown"
        fi
    fi
# See how we were called.
case "$1" in
  start)
        start
        ;;
  stop)
        stop
        ;;
  status)
        status -p ${pidfile} $httpd
        RETVAL=$?
        ;;
  restart)
        stop
        start
        ;;
  condrestart|try-restart)
        if status -p ${pidfile} $httpd >&/dev/null; then
                stop
                start
        fi
        ;;
  force-reload|reload)
        reload
        ;;
  graceful|help|configtest|fullstatus)
        $apachectl [email protected]
        RETVAL=$?
        ;;
  *)
        echo $"Usage: $prog {start|stop|restart|condrestart|try-restart|force-reload|reload|status|fullstatus|graceful|help|configtest}"
        RETVAL=2
esac
exit $RETVAL

9)加入开机自启动,测试页面

chkconfig --add httpd24

chkconfig httpd 24 on

10)测试

echo "10.1.1.1 www.blog.com" >> /etc/hosts

curl -I www.blog.com

三、配置虚拟主机及其给文本站点提供ssl加密

1、开启httpd-vhosts,及其注释站点中心目录

Include /etc/httpd24/extra/httpd-vhosts.conf

2、配置/etc/httpd24/extra/httpd-vhots.conf

<VirtualHost *:80>

ServerAdmin [email protected]

DocumentRoot "/website/"

ServerName www.chen.com

ServerAlias chen.com

ErrorLog "logs/www.chen.com-error_log"

CustomLog "logs/www.chen.com-access_log" common

</VirtualHost>

3、ssl加密如下步骤:

生成密钥对儿:
# (umask 077; openssl genrsa -out private/cakey.pem 2048)
如果想查看公钥:
# openssl rsa -in private/cakey.pem -pubout -text -noout
生成自签证书:
# openssl req -new -x509 -key private/cakey.pem -out cacert.pem -days 3655
创建需要的文件:
# touch index.txt serial crlnumber
用openssl实现证书申请:
在主机上生成密钥,保存至应用此证书的服务的配置文件目录下, 例如:
# mkdir /etc/httpd/ssl
# cd /etc/httpd/ssl
# (umask 077; openssl genrsa -out httpd.key 1024)
生成证书签署请求:
# openssl req -new -key httpd.key -out httpd.csr 
将请求文件发往CA;
CA签署证书:
签署:
# openssl ca -in /path/to/somefile.csr -out /path/to/somefile.crt -days DAYS
时间: 2024-10-24 07:32:36

centos7之httpd-2.4的新特性的相关文章

web服务之httpd及其新特性

概述 http协议及httpd的一些特性,是学习web服务需要掌握的一些基础知识,接下来让我们进一步了解httpd相关功能的配置,本文讲解的web服务之httpd新特性及其虚拟主机,访问控制及https等功能的配置. httpd之基本特性 实验环境介绍 开始之前,先介绍一下httpd在CentOS6.8版本及文件: 版本:httpd-2.2.27(centos7默认为2.4以上的版本) 主配置文件: /etc/httpd/conf/httpd.conf 其他配置文件如虚拟主机及其ssl.虚拟主机

centos7/rhel7新特性详解(1)

RHEL7/CENTOS7新特性: 1.身份管理 kerberos的跨平台信任机制:kerberos将完全兼容微软活动目录,实现完全使用活动目录进行认证. REALMD:该功能简化了RHEL 加入微软活动目录的配置,支持自动发现域信息. RHEL 7增加了两个关键性的新特征改善了RHEL对AD的处理方式.现在,RHEL7和AD之间建立了跨域信任(Cross-realm trusts),因此AD用户可以在Linux端无需登录就能访问资源.RHEL 7增加的另外一个AD相关的功能是realmd,实现

centos7的新特性

 centos7 系统的新特性以及安装 (一)centos7的新特性 1:centos7的身份 管理: (1)使用kerberos的跨平台信任机制,可以喝windows的活动目录具有兼容性 (2)REALMD将centos或rhel加入windows活动目录,实现自动支持 2:性能管理: 提供个新架构,新图形界面来提供性能管理,可用来分析和收集系统信息 3:虚拟化支持: (1)可以兼容vmarevshpere虚拟化架构,另外自带3D驱动,open tools (2)虚拟I/O :每台虚拟机提供了

centos7新特性3

Centos7新特性: MBR 分区的前 446 个字节存放的是系统引导程序 grub,中间 64 字节是分区表,最后 2 个字 节表示结束. 系统开机都经历了什么? 1.BIOS 自检,检查硬件: 2.激活 MBR,MBR 上不存在文件系统,可以视作硬件一部分,因此可以被直接读取 3.grub 加载到内存,生成一个微系统,微系统内置了精简版的文件系统 4.通过这个微系统,他会去引导分区,比如默认一般是 sda1 上去找内核文件如 vmlinuz,然 后再调用 grub 的配置文件. grub

centos7新特性5

centos7新特性: ssm工具的使用 ssm(system-storage-manager)系统存储管理工具 首先安装ssm工具 挂载光盘 rpm安装工具 然后在系统中添加两块磁盘 使用ssm list查看磁盘状态,可查看此逻辑卷,卷组等磁盘状态 创建磁盘挂在目录 创建逻辑池,逻辑卷 查看一下 扩展逻辑池(前提:扩展的逻辑池必须是空磁盘) 扩展逻辑卷 扩展完成之后需要使用命令刷新一下 可用ssm list参看一下大小 逻辑卷快照 方法一: 先向/data目录下存放一点文件 创建快照 删除/d

centos7新特性6

centos7新特性 系统存储类型:1.块存储(san,dan),也就是直接通过硬盘等介质直接存储 2.文件存储(tcp/ip),通过TCP/IP等协议存储 3.对象存储(mfs,gfs)分布式文件存储 今天来一篇文件存储(iscsi):网络存储服务 iscsi实现网络存储,提供存储端叫做target,使用存储端叫做initiator,target上提供存储空间,initiator负责连接设备,在iscsi设备中创建文件系统,以及存储数据在initiator上看就像多了一块硬盘. 服务器端配置t

Linux7/Centos7新特性以及安装体验

一.RHEL7新特性: 1.身份管理 ?kerberos的跨平台信任机制:kerberos将完全兼容微软活动目录,实现完全使用活动目录进行认证. ?REALMD:该功能简化了RHEL 加入微软活动目录的配置,支持自动发现域信息. RHEL 7增加了两个关键性的新特征改善了RHEL对AD的处理方式.现在,RHEL7和AD之间建立了跨域信任(Cross-realm trusts),因此AD用户可以在Linux端无需登录就能访问资源.RHEL 7增加的另外一个AD相关的功能是realmd,实现自动化查

Httpd-2.4的新特性

Httpd-2.4的新特性 一.新特性 MPM支持运行运行DSO机制,以模块形式按需加载 Event MPM生产环境可用 异步读写机制 支持每模块及每目录的单独日志级别定义 每请求相关的专用配置 增强版的表达式分析式 毫秒级持久连接时长定义 基于FQDN的虚拟主机不再需要NameVirtualHost指令 新指令,AllowOverrideList 支持用户自定义变量 更低的内存消耗 二.Httpd 2.4新模块介绍 Httpd 2.4新模块介绍 mod_proxy_fcgi 支持PHP等动态语

apache2.4:apache的安装及其新特性

小生博客:http://xsboke.blog.51cto.com 小生 Q Q:1770058260 -------谢谢您的参考,如有疑问,欢迎交流 一. Apache2.4新特性 1. 新增模块 Mod_proxy_fcgi:提供fcgi代理 Mod_ratelimit:限制用户带宽 Mod_request:过滤客户机请求 Mod_remoteip:匹配客户端的IP 2. 新特性 Mpm(工作模式):支持工作模式在apache运行时更改 但是要开启这种特性,在编译安装要启用这三种功能:--e