设为首页 收藏本站
查看: 1922|回复: 0

httpd三之源码编译http2.4.9、虚拟主机、基于用户认证

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-5-12 11:39:13 | 显示全部楼层 |阅读模式
本文主要讲解源码编译http2.4.9,并能实现基于虚拟主机、用户认证等实现网页访问。         
http2.4.9会依赖于更高版本的apr和apr-util,所有需要先对apr和apr-util进行编译
http2.4系列相对于http2.2系列新增的功能有
1) MPM支持在运行时装载
2)支持event
3)异步读写
4)在每模块及每目录上指定日志级别
5)每请求配置
6)增强版的表达式分析器
7)毫秒级的keepalive timeout
8)支持主机名的虚拟主机不在需要NameVirtualHost指令
9)支持使用自定义变量
  新增的模块由mod_proxy_fcgi,mod_ratelimit,mod_request,mod_remoteip
  对应IP的访问做了修改,不在使用order,allow deny这些机制,而是统一使用require进行
一、环境准备
安装好开发包组和pcre-devel工具,下载最新版的httpd、apr和apr-util,本文下载的都为最新的源码包


[iyunv@wangfeng7399 ~]# yum install -y pcre-devel
[iyunv@wangfeng7399 ~]# wget http://apache.fayea.com/apache-mirror//httpd/httpd-2.4.9.tar.bz2
[iyunv@wangfeng7399 ~]# wget http://mirrors.hust.edu.cn/apache//apr/apr-1.5.0.tar.gz
[iyunv@wangfeng7399 ~]# wget http://mirrors.hust.edu.cn/apache//apr/apr-util-1.5.3.tar.gz
二、安装apr  


[iyunv@wangfeng7399 ~]# tar xf apr-1.5.0.tar.gz
[iyunv@wangfeng7399 ~]# cd apr-1.5.0
[iyunv@wangfeng7399 apr-1.5.0]# ./configure --prefix=/usr/local/apr
[iyunv@wangfeng7399 apr-1.5.0]# make && make install
三、安装apr-util


[iyunv@wangfeng7399 ~]# tar xf apr-util-1.5.3.tar.gz
[iyunv@wangfeng7399 ~]# cd apr-util-1.5.3
[iyunv@wangfeng7399 apr-util-1.5.3]# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
[iyunv@wangfeng7399 apr-util-1.5.3]# make && make install
四、编译httpd


[iyunv@wangfeng7399 ~]# tar xf httpd-2.4.9.tar.bz2
[iyunv@wangfeng7399 ~]# cd httpd-2.4.9
[iyunv@wangfeng7399 httpd-2.4.9]# ./configure --prefix=/usr/local/httpd --sysconfdir=/etc/httpd --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-modeles=most --enable-mpms-shared=all --with-mpm=event
[iyunv@wangfeng7399 httpd-2.4.9]# make && make install
  enable-so enable--ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre 启动so、ssl、cgi、rewrite、zlib、pcre等功能
  --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util 指定apr和apr-util的地址
  --enable-modeles=most   编译常用的模块
  --enable-mpms-shared=all --with-mpm=event 编译所有的mpms,并以event作为默认
  1、导出头文件  
root@wangfeng7399 ~]# ln -sv /usr/local/httpd/include/ /usr/include/httpd
  2、导出帮助文件
  在/etc/man.conf中添加
  MANPATH /usr/local/httpd/man
  3.导出二进制文档


[iyunv@wangfeng7399 httpd]# vi /etc/profile.d/http.sh
export PATH=/usr/local/httpd/bin:$PATH
  测试
  可以通过 apachectl start启动
wKiom1MoiM7ijOn-AABXsdXGONA672.jpg
准备系统启动脚本


[iyunv@wangfeng7399 init.d]# cat httpd
#!/bin/bash
#
# httpd        Startup script for the Apache HTTP Server
#
# chkconfig: - 85 15
# description: The Apache HTTP Server is an efficient and extensible  \
#          server implementing the current HTTP standards.
# processname: httpd
# config: /etc/httpd/httpd.conf
# 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/httpd/bin/apachectl
httpd=/usr/local/httpd/bin/httpd
prog=httpd
pidfile=${PIDFILE-/var/run/httpd/httpd.pid}
lockfile=${LOCKFILE-/var/lock/subsys/httpd}
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() {
    echo -n $"Stopping $prog: "
    killproc httpd
    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
    echo
}
# 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 $@
    RETVAL=$?
    ;;
  *)
    echo $"Usage: $prog {start|stop|restart|condrestart|try-restart|force-reload|reload|status|fullstatus|graceful|help|configtest}"
    RETVAL=2
esac
exit $RETVAL
搭建基于主机名的虚拟主机
   编辑配置文件


[iyunv@wangfeng7399 extra]# vi httpd-vhosts.conf
<VirtualHost *:80>
    ServerAdmin www.wangfeng7399.com
    DocumentRoot "/www/html/wangfeng7399"
</VirtualHost>
<VirtualHost *:80>
    ServerAdmin www.wangfeng17399.com
    DocumentRoot "/www/html/wangfeng17399"
   修改主配置文件将主记录注释掉,将辅助http-vhosts启动起来


#DocumentRoot "/usr/local/httpd/htdocs"
# Virtual hosts
Include /etc/httpd/extra/httpd-vhosts.conf
   分别在/www/html/wangfeng7399和/www/html/wangfeng17399中提供网页文件,并修改其权限
   在window的hosts文件中添加对两个域名的解析
   测试
wKioL1MpaUbhil8iAABP20h3x9k831.jpg
wKiom1MpaW7ClibtAABX0bgjqXo756.jpg
基于用户验证
   我们假设在www.wangfeng17399.com中有一个2.html中的数据为敏感数据,我们要对其做基于用户的验证才能登陆。


<VirtualHost *:80>
    DocumentRoot "/www/html/wangfeng17399"
    ServerName www.wangfeng17399.com
    <Directory "/www/html/wangfeng17399/2.html">
      Options None
      AllowOverride AuthConfig    //文件需要认证
      AuthType Basic              //认证类型为基本认证
      AuthName "Private Area"     //显示的标题
      AuthBasicProvider file      //认证的提供者
      AuthUserFile /usr/local/apache/.userpasswd //认证的文件
      Require valid-user   //可以读取认证文件的用户,vaild-user 表示所有合法用户,也可以 user admin wangfeng7399来制定单个用户
    </Directory>
</VirtualHost>
生成认证文件  


[iyunv@wangfeng7399 extra]# htpasswd -c /usr/local/apache/.userpasswd wangfeng7399
New password:
Re-type new password:
Adding password for user wangfeng7399
验证  
要求用户输入用户名和密码

wKioL1MpcXHirHzCAACVHs_31JE736.jpg
输入用户名和密码后可以看到2.html的内容
wKiom1MpcZjA27JpAABeergOd4k992.jpg


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-19055-1-1.html 上篇帖子: httpd二之主配置文件详解、测试工具、压力测试ab 下篇帖子: LAMP系列之PHP编译过程中常见错误信息的解决方法 虚拟主机 认证 用户
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表