centos6.5源码编译http2.4.9、虚拟主机、基于用户认证

2014-04-23 07:45 
作者: 51linux 
来源: 本站 
浏览: 0 views 
我要评论 
字号:   

摘要: 本文主要讲解源码编译http2.4.9,并能实现基于虚拟主机、用户认证等实现网页访问。           http2.4.9会依赖于更高版本的apr和apr-util,所有需要先对apr和apr-util...

本文主要讲解源码编译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,本文下载的都为最新的源码包

1
2
3
4
[root@wangfeng7399 ~]
# yum install -y pcre-devel
[root@wangfeng7399 ~]
# wget http://apache.fayea.com/apache-mirror//httpd/httpd-2.4.9.tar.bz2
[root@wangfeng7399 ~]
# wget http://mirrors.hust.edu.cn/apache//apr/apr-1.5.0.tar.gz
[root@wangfeng7399 ~]
# wget http://mirrors.hust.edu.cn/apache//apr/apr-util-1.5.3.tar.gz

二、安装apr

1
2
3
4
[root@wangfeng7399 ~]
# tar xf apr-1.5.0.tar.gz
[root@wangfeng7399 ~]
# cd apr-1.5.0
[root@wangfeng7399 apr-1.5.0]
# ./configure --prefix=/usr/local/apr
[root@wangfeng7399 apr-1.5.0]
# make && make install

三、安装apr-util

1
2
3
4
[root@wangfeng7399 ~]
# tar xf apr-util-1.5.3.tar.gz
[root@wangfeng7399 ~]
# cd apr-util-1.5.3
[root@wangfeng7399 apr-util-1.5.3]
# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
[root@wangfeng7399 apr-util-1.5.3]
# make && make install

四、编译httpd

1
2
3
4
[root@wangfeng7399 ~]
# tar xf httpd-2.4.9.tar.bz2
[root@wangfeng7399 ~]
# cd httpd-2.4.9
[root@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
[root@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、导出头文件

1
root@wangfeng7399 ~]
# ln -sv /usr/local/httpd/include/ /usr/include/httpd

2、导出帮助文件

在/etc/man.conf中添加

1
  
MANPATH 
/usr/local/httpd/man

3.导出二进制文档

1
2
[root@wangfeng7399 httpd]
# vi /etc/profile.d/http.sh
export 
PATH=
/usr/local/httpd/bin
:$PATH

测试

可以通过 apachectl start启动

准备系统启动脚本

[root@wangfeng7399 init.d]# cat httpd

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#!/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

搭建基于主机名的虚拟主机

编辑配置文件

1
2
3
4
5
6
7
8
[root@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启动起来

1
2
3
#DocumentRoot "/usr/local/httpd/htdocs"
# Virtual hosts
Include 
/etc/httpd/extra/httpd-vhosts
.conf

分别在/www/html/wangfeng7399和/www/html/wangfeng17399中提供网页文件,并修改其权限

在window的hosts文件中添加对两个域名的解析

测试

基于用户验证

我们假设在www.wangfeng17399.com中有一个2.html中的数据为敏感数据,我们要对其做基于用户的验证才能登陆。

1
2
3
4
5
6
7
8
9
10
11
12
13
<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
>

生成认证文件

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

centos6.5源码编译http2.4.9、虚拟主机、基于用户认证的更多相关文章

  1. CentOS6.6源码编译升级GCC至4.8.2

    升级前提 源码编译需要至少要有一个可用的gcc编译器. 可以用过yum自动安装或者手动下载rpm包安装. 通过yum可以看到至少需要下面这些安装包,所以可以到许多rpm package站点中搜索下载相 ...

  2. 源码编译安装LAMP环境及配置基于域名访问的多虚拟主机

    实验环境及软件版本: CentOS版本: 6.6(2.6.32.-504.el6.x86_64) apache版本: apache2.2.27 mysql版本:  Mysql-5.6.23 php版本 ...

  3. Centos6.5源码编译安装nginx

    1.安装pcre下载地址:http://jaist.dl.sourceforge.net/project/pcre/pcre/8.38/pcre-8.38.tar.gz #tar -axvf pcre ...

  4. Mysql5.6 for Centos6.5源码编译安装

    ## 说明 不同服务器需要改变 server_id ,同一台机器上需要改变 port 1. 关闭防火墙[root@mysql ~]# service iptables status --查看防火墙状态 ...

  5. centos6.5 源码编译 mysql5.6.21

    1.yum安装各个依赖包 [root@WebServer ~]# yum -y install gcc gcc-devel gcc-c++ gcc-c++-devel autoconf* automa ...

  6. 源码编译安装LNMP环境及配置基于域名访问的多虚拟主机

    实验环境及软件版本: CentOS版本: 6.6(2.6.32.-504.el6.x86_64) nginx版本: nginx-1.6.2 mysql版本:  Mysql-5.6.23 php版本: ...

  7. Centos6.5 源码编译安装 Mysql5.7.11及配置

    安装环境 Linux(CentOS6.5 版).boost_1_59_0.tar.gz.mysql-5.7.11.tar.gzMySQL 5.7主要特性:    更好的性能:对于多核CPU.固态硬盘. ...

  8. httpd-2.4源码编译

    APR     APR(Apache portable Run-time libraries,Apache可移植运行库) 主要为上层的应用程序提供一个可以跨越多操作系统平台使用的底层支持接口库.在早 ...

  9. centos6.5环境源码编译安装mysql5.6.34

    centos6.5环境源码编译安装mysql5.6.34 源码下载地址http://dev.mysql.com/downloads/mysql/5.6.html#downloads 选择Generic ...

  10. mysql5.7.10 源码编译安装记录 (centos6.4)【转】

    一.准备工作 1.1 卸载系统自带mysql 查看系统是否自带MySQL, 如果有就卸载了, 卸载方式有两种yum, rpm, 这里通过yum卸载 rpm -qa | grep mysql //查看系 ...

随机推荐

  1. CSRF(Steam的链接不用随便点)

    漏洞详解 CSRF 漏洞原理: 攻击者会冒充或利用用户本人对web服务器发送请求,然而web服务器无法识别该请求是否为用户本人所发送,因此造成各种危害. 漏洞利用过程: 1)首先需要用户登录了上网站, ...

  2. C++ //vector 容器构造 vector赋值操作 vector 容量大小 vector插入和删除 //vector数据存取 vector互换容器 vector预留空间

    1 //vector 容器构造 vector赋值操作 vector 容量大小 vector插入和删除 2 //vector数据存取 vector互换容器 vector预留空间 3 #include&l ...

  3. mybatis批量插入的四种方式

    一.循环插入 public void insert(List<User> userList) { userList.forEach(user -> userDao.insert(us ...

  4. C#之winform捕获Console.WriteLine内容到日志文件

    问题描述 之前接手同事的项目,是一个类似于服务端后台的Winform程序,主界面隐藏起来,只再任务栏显示程序图标. 整个项目里面没有日志记录功能,全靠Console.WriteLine打印信息.自己调 ...

  5. 【stars-one】星念音乐下载器

    一款可将各个音乐网站可在线播放的音乐保存到本地的软件,目前暂且支持网易云音乐 获取软件 星念音乐下载器pc版v1.5 https://www.ilanzou.com/s/CI7zaWz 星念音乐下载器 ...

  6. Windows 2012 R2 修复CredSSP 远程执行代码漏洞 CVE-2018-0886

    本文基于window 2012 R2版本,各位参考下载自己版本对应的补丁包即可 说明 公司的安全性检查,需要修复服务器上的漏洞,其中有个漏洞是CVE-2018-0886,结果网上的资料和一番折腾,终于 ...

  7. atcoder: Moves on Binary Tree

    先进行压缩move的次数,再用biginteger. import java.io.BufferedReader; import java.io.IOException; import java.io ...

  8. 记录--h5调用手机摄像头踩坑

    这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 1. 背景 一般业务也很少接触摄像头,有也是现成的工具库扫个二维码.难得用一次,记录下踩坑. 2.调用摄像头的方法 2.1. input ...

  9. 一些 AppKit 的坑

    NSTextField 在 NSTableView 中需要先点一次再点一次才能编辑.且 hover 时鼠标指针不变化 在 storyboard 里,将 NSTableView 的 Highlight ...

  10. Docker网络模型以及容器通信

    本篇接着上篇:[Docker0网络及原理探究],继续深入探究容器网络通信原理,通过学习Docker网路驱动模型,更好地解决容器间的通信问题 1.Docker的网络驱动模型 1.1.Docker的网络驱 ...