apache(源码包安装)

apache的安装  (用脚本安装下面有脚本安装的方法)
最新版本的就是变态,本来你安装了apr和apr-util包了,但就是预编译配置通不过,那就直接上源码包。
安装前的准备:
yum -y install gcc 
yum -y install gcc-c++
yum -y install openssl-devel
以为安装这些了就可以了,编译的时候出现error,基本我属于那种有警告不管,但是尼玛出现error了,木有办法了,那只有解决了。
[root@localhost /]# rpm -qa | grep apr
apr-util-ldap-1.3.9-3.el6.i686
apr-1.3.9-3.el6.i686
apr-util-1.3.9-3.el6.i686
这几个是搭建apache必须安装的,系统显示已经安装了相应的rpm包了。但是你去编译apache的时候还是可能出现错误,那不管了,直接上源码包
 
error1:
configure: error: APR not found. Please read the documentation.
 
解决error1:
tar zxvf apr-1.4.2.tar.gz -C /usr/src/
   
   cd /usr/src/apr-1.4.2
  ./configure --prefix=/usr/local/apr
  make && make install
 
error2:
configure: error: APR-util not found. Please read the documentation
 
解决error2:cd /
tar zxvf apr-util-1.3.10.tar.gz -C /usr/src/
 
  cd  /usr/src/apr-util-1.3.10
  ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr/bin/apr-1-config
  make && make install
 
error3:
configure: error: pcre-config for libpcre not found. PCRE is required and available from http://pcre.org/
 
解决error3:
tar zxvf pcre-8.11.tar.gz -C /usr/src/
 
   cd /usr/src/pcre-8.11
   ./configure --prefix=/usr/local/pcre
   make && make install
 
最后这些都解决完了,尼玛终于没有错误了!!!!我感动啊!!
tar zxvf httpd-2.4.3.tar.gz -C /usr/src/ 
 
  cd /usr/src/httpd-2.4.3
  ./configure --prefix=/usr/local/apache2  --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --with-pcre=/usr/local/pcre --enable-so --enable-rewrite --enable-ssl --with-ssl=/usr/lib--enable-auth-digest --enable-cgi --enable-suexec --with-suexec-caller=daemon --with-suexec-docroot=/usr/local/apache2/htdocs
 
make && make install
 
apache搭建完成后
装完成后,了解apache服务器相关的主要目录和文件
/usr/local/apache2/bin/           (httpd服务器包含的执行程序)
/usr/local/apache2/conf/          (httpd服务器包含的配置文件) 
/usr/local/apache2/htdocs/        (httpd服务器存放的网页文件的根目录)
/usr/local/apache2/logs/          (存放访问httpd服务器的日志)
/usr/local/apache2/man/           (httpd服务器的帮助手册) 
/usr/local/apache2/modules/       (存放提供给httpd服务器动态加载的模块文件)
 
开启搭建好的服务
开启服务的命令
/usr/local/apache2/bin/apachectl start    (开启服务)
/usr/local/apache2/bin/apachectl stop     (关闭服务)
/usr/local/apache2/bin/apachectl restart  (重启服务)
/usr/local/apache2/bin/apachectl -t       (检查配置文件是否出错)
 
echo "/usr/local/apache2/bin/apachectl start" >> /etc/rc.d/rc.local (服务器开机之后自动开启服务)
 
[root@localhost apache2]# /usr/local/apache2/bin/apachectl start(源码包安装需要这样才能开启服务)
AH00558: httpd: Could not reliably determine the server's fully qualified domain name, using localhost.localdomain. Set the 'ServerName' directive globally to suppress this message
httpd (pid 902) already running    显示已经开启了,会出现命令的提示,解决这个问题
 
查看配置文件
 vim /usr/local/apache2/conf/httpd.conf
 
###添加这句(直接copy)
ServerName 192.168.4.184:80 
###保存退出
ServerName 192.168.4.184:80 (有域名就写域名ServerName www.abc.com:80)
在重启服务就不会提示上面的信息了。
 
[root@localhost apache2]# /usr/local/apache2/bin/apachectl start (这次开启的时候发现什么都木有)
但是服务已经开启了!!
查看一下httpd的端口状态和进程状态
[root@localhost apache2]# netstat -pant | grep httpd
tcp        0      0 :::80                   :::*                  LISTEN      1524/httpd          
[root@localhost apache2]# ps aux | grep httpd
root      1524  0.0  0.4   5272  2372 ?        Ss   02:39   0:00 /usr/local/apache2/bin/httpd -k start
daemon    1525  0.0  0.4 283004  2116 ?        Sl   02:39   0:00 /usr/local/apache2/bin/httpd -k start
daemon    1526  0.0  0.4 283004  2120 ?        Sl   02:39   0:00 /usr/local/apache2/bin/httpd -k start
daemon    1527  0.0  0.4 283004  2120 ?        Sl   02:39   0:00 /usr/local/apache2/bin/httpd -k start
root      1706  0.0  0.1   4312   728 pts/1    S+   02:41   0:00 grep httpd
(要杀死进程 killall -9 1524 1525 1526 1527)
 
每次开启服务都要这样敲入这么长的命令/usr/local/apache2/bin/apachectl start很麻烦
能不能直接向rpm包安装apache一样用service httpd start这样启动呢?
先rpm -qa | grep httpd确保系统木有rpm包安装的httpd,有就用yum -y remove httpd删除
然后cp /usr/src/httpd-2.4.3/build/rpm/httpd.init /etc/init.d/httpd  
把httpd.init(文件路径一定要正确)文件copy到服务启动脚本目录下面并改名为httpd
先修改脚本启动配置文件
vim /etc/init.d/httpd 
 
########修改一些内容
prog=$(basename $0 | sed -e 's/^[SK][0-9][0-9]//')
if [ -f /etc/sysconfig/${prog} ]; then
        . /etc/sysconfig/${prog}
fi
httpd=${HTTPD-/usr/local/apache2/bin/httpd}
prog=httpd
pidfile=${PIDFILE-/usr/local/apache2/${prog}.pid}
lockfile=${LOCKFILE-/var/lock/subsys/${prog}}
RETVAL=0
check13 () {
        CONFFILE=/usr/local/apache2/conf/httpd.conf  
########保存退出
 
然后在修改apache的配置文件
vim /usr/local/apache2/conf/httpd.conf
 
###添加这句
pidfile  "/usr/local/apache2/httpd.pid"
###然后保存退出配置文件
 
 
在试试service httpd start|stop|restart
[root@localhost init.d]# service httpd start
Starting httpd: (98)Address already in use: make_sock: could not bind to address [::]:80
(98)Address already in use: make_sock: could not bind to address 0.0.0.0:80
no listening sockets available, shutting down
Unable to open logs
                                                           [FAILED]
[root@localhost init.d]# service httpd stop
Stopping httpd:                                            [FAILED]
发现还是出现这样的错误,别急,在来小小的修改一下
[root@localhost rpm]# ps aux | grep httpd
root     20462  0.0  0.4   8204  2080 ?        Ss   19:59   0:00 /usr/local/apache2/bin/httpd
daemon   20464  0.0  0.3   8340  1568 ?        S    19:59   0:00 /usr/local/apache2/bin/httpd
daemon   20465  0.0  0.3   8340  1568 ?        S    19:59   0:00 /usr/local/apache2/bin/httpd
daemon   20466  0.0  0.3   8340  1568 ?        S    19:59   0:00 /usr/local/apache2/bin/httpd
daemon   20467  0.0  0.3   8340  1568 ?        S    19:59   0:00 /usr/local/apache2/bin/httpd
daemon   20468  0.0  0.3   8340  1568 ?        S    19:59   0:00 /usr/local/apache2/bin/httpd
root     20862  0.0  0.6  10912  3308 pts/2    S+   21:09   0:00 vim httpd
root     20986  0.0  0.1   4308   732 pts/3    S+   21:37   0:00 grep httpd
[root@localhost rpm]# kill -9 20462 20464 20465 20466 20467 20468(杀死这些进程)
然后在试试service httpd start|stop|restart,行则ok,不行,那就在检查检查上面的配置文件
[root@localhost rpm]# service httpd start
Starting httpd:                                            [  OK  ] 
[root@localhost rpm]# service httpd restart
Stopping httpd:                                            [  OK  ]
Starting httpd:                                            [  OK  ]
[root@localhost rpm]# 
 
有人说何必这么费劲也可以这样
cp /usr/local/apache2/bin/apachectl /etc/init.d/httpd  #复制为系统服务
vim /etc/init.d/httpd    #编辑此服务,将前三行修改为
#!/bin/bash
# chkconfig: 35 85 15
#description:Apache httpd
service httpd start
但是这样敲了之后,这个命令不会出现Starting httpd:    [  OK  ] ,不信你可以试试,这样就还需要
查看是否开启了没有netstat -pant | grep 80 有80就开启了
确保开机服务器自动启动
chkconfig --add httpd
chkconfig --level 35 httpd on
 
每次打开配置文件的时候都有很多无用的
#######为便于查看可以用这个命令清楚不需要的东西######
   cp http.conf http.conf.bak(先进行备份)
 grep -v "#" httpd.conf.bak | grep -v "^$" > httpd.conf
grep -v "#" 去掉#号
grep -v "^$" 去掉空格
##############常用的全局配置参数######################
Serverroot: 用于设置httpd服务器的根目录
Listen: 设置apache用于监听的端口号,默认为80
User: 设置运行httpd进程的用户身份
Group: 设置运行httpd进程的组身份
Serveradmin: 设置服务器管理员的e-mail地址
Servername: 设置服务器的完整主机名
Documentroot: 设置网页文档根目录
Directoryindex: 设置网站的默认首页格式
Errorlog: 错误日志的路径和文件名
LogLevel:记录日志的级别,默认为warn
Customlog: 访问日志的路径和格式类型
Pidfile: 保存服务器程序进程号(pid)的文件,默认为logs/httpd.pid
Timeout: web服务器与浏览器之间网络连接的超时秒数,默认为300秒
Keepalive: 是否使用保持连接功能:off on 
Maxkeepaliverequests: 客户端每次连接允许请求的最大文件数,默认为100个。当keepalive设置为on时才生效
Keepalivetimeout: 保持连接的超时秒数,默认为15秒
Include: 用于包含另一个配置文件的内容
###################apache的相关操作####################################
1.虚拟目录
先修改配置文件
vim /usr/local/apache2/conf/httpd.conf
###在<IfModule alias_module>模块中添加一句,然后在</IfModule>下面添加几句</Directory >
<IfModule alias_module>
     Alias    /test         "/data/web"      
</IfModule>
<Directory "/data/web">
    AllowOverride None
    Options None
    Require all granted
</Directory>
 
#######</Directory>里面写的东西配置文件里面是有模板的copy之后改动一点就ok了然后保存退出
 
然后要新建那个虚拟目录
mkdir -p /data/web
   /data目录可以是挂载到linux系统中的,所以这个目录就看你硬盘多大了
在新建的目录里面 vim index.html里面随便写一点东东就ok了
然后重启httpd服务器
访问的时候 http://ip/test(记住这里一定不要敲/直接回车)
 
 
2.虚拟主机
  a)同ip同域名不同端口
vim /usr/local/apache2/conf/httpd.conf 
修改配置文件
 
####添加这些
Listen 8001
Listen 8002
<VirtualHost 172.16.1.1:8001>
ServerAdmin  webmaster@dummy-host.example.com
DocumentRoot  /data/web/test1
ServerName    www.test.com
ErrorLog      /data/web/log/test1.err.log
CustomLog     /data/web/log/test1.acc.log common
</VirtualHost>
<VirtualHost 172.16.1.1:8002>
ServerAdmin  webmaster@dummy-host.example.com
DocumentRoot  /data/web/test2
ServerName    www.test.com
ErrorLog       /data/web/log/test2.err.log
CustomLog      /data/web/log/test2.acc.log  common
</VirtualHost>
#####保存退出
 
参数的解释:
ServerAdmin webmaster@dummy-host.example.com   
   (这个可以随便写,这个是管理员的邮箱地址)
DocumentRoot /data/web/test1  
   (这个是存放网页文件的目录)
ServerName www.test.com            
   (这个是写域名的,有自己的域名,就写自己的域名,没有域名随便写了也不要紧,因为我们用ip访问)
CustomLog  data/web/log/test1.acc.log common
   (用于设置httpd服务器访问日志文件的路径和格式类型,这个文件里面写入这你登录的记录)
ErrorLog     /data/web/log/test1.err.log
   (用于设置错误日志文件的路径和文件名(如果你设置了,那这个目录和文件必须存在,木有就新建)这个文件写入的是,你登录错误的记录)
 
新建配置文件里面指定的虚拟主机目录,因为没有,那就要新建
cd /data/web/                                                  (切换目录,在这个目录里面去新建)
mkdir test1 test2 log                          (新建两个存放网页目录的文件和一个存放日志的文件)
cd log/                                                        (切换到日志的目录文件中)
touch test1.err.log test1.acc.log  test2.err.log test2.acc.log (新建四个日志文件)
vim /data/web/test1/index.html                                 (编辑两个网页文件便于测试)
    this is test1 page
vim /data/web/test2/index.html  
    this is test2 page
 
 
访问测试 http://ip:8001 (看见this is test1 page  就ok了)
         http://ip:8002  (看见this is test2 page  就ok了)
 
b)同ip不同域名同端口
  vim /usr/local/apache2/conf/httpd.conf 
修改配置文件
 
####添加这些:wq
<VirtualHost 172.16.1.1:80>
ServerAdmin  webmaster@dummy-host.example.com
DocumentRoot  /data/web/test1
ServerName    www.test1.com
ErrorLog      /data/web/log/test1.err.log
CustomLog     /data/web/log/test1.acc.log common
</VirtualHost>
<VirtualHost 172.16.1.1:80>
ServerAdmin  webmaster@dummy-host.example.com
DocumentRoot  /data/web/test2
ServerName    www.test2.com
ErrorLog       /data/web/log/test2.err.log
CustomLog      /data/web/log/test2.acc.log  common
</VirtualHost>
#####保存退出
重启服务
 
如果临时的不能搭建dns,可以用host文件代替
vim /etc/hosts
172.16.1.1   www.test1.com
172.16.1.1  www.test2.com
   (!!!还是要新建配置文件里面指定的虚拟主机目录!!!)
访问测试 http://www.test1.com (看见this is test1 page  就ok了)
         http://www.test2.com  (看见this is test2 page  就ok了)
c)不同ip同域名同端口
 
vim /usr/local/apache2/conf/httpd.conf 
修改配置文件
 
####添加这些
<VirtualHost 172.16.1.10:80>
ServerAdmin  webmaster@dummy-host.example.com
DocumentRoot  /data/web/test1
ServerName    www.test.com
ErrorLog      /data/web/log/test1.err.log
CustomLog     /data/web/log/test1.acc.log common
</VirtualHost>
<VirtualHost 172.16.1.20:80>
ServerAdmin  webmaster@dummy-host.example.com
DocumentRoot  /data/web/test2
ServerName    www.test.com
ErrorLog       /data/web/log/test2.err.log
CustomLog      /data/web/log/test2.acc.log  common
</VirtualHost>
#####保存退出
重启服务
模拟ip出来
ifconfig eth0:0 172.16.1.10 up
ifconfig eth0:1 172.16.1.20 up
 
访问测试 http://172.16.1.10 (看见this is test1 page  就ok了)
         http://172.16.1.20 (看见this is test2 page  就ok了)
 
3.系统用户的个人主页
a)修改配置文件
vim /usr/local/apache2/conf/httpd.conf 
 
####把配置文件中的这两句前面的#去掉
LoadModule userdir_module modules/mod_userdir.so
Include conf/extra/httpd-userdir.conf  
#####保存退出,这里就采用默认的路径
b)新建用户给出密码
#################################
useradd li
useradd liuh
passwd li(li)
passwd liu(liu)
#################################
c)在li和liu用户的宿主目录中新建文件
cd /home/li
mkdir public_html
cd public_html
vim index.html(为li用户新建自己的主页)
cd /home/liu
mkdir public_html
cd public_html
vim index.html(为liu用户新建自己的主页)
chmod o+x /home/li* (为宿主目录中的用户修改权限)
d)重启服务
#################访问浏览器##################
http://ip/~li/  (其中li为用户名)
###############################################
 
 
4.做授权认证
修改配置文件
vim /usr/local/apache2/conf/httpd.conf
 
#####添加这几句(用了一个虚拟目录)
     Alias  /test     "/data/web"
<Directory "/data/web">
    Options Indexes MultiViews FollowSymLinks
    AllowOverride All
    AuthType basic
    AuthName "welcome test"
    AuthUserFile /usr/local/apache2/conf/httppwd
    Require user liu
</Directory>
####保存退出
 
建立网页目录和文件
mkdir -p /data/web
vim /data/web/index.html
 
建立存储认证用户账号及口令的文件
/usr/local/apache2/bin/htpasswd -c /usr/local/apache2/conf/httppwd liu
New password: 
Re-type new password:  
(添加第二个,或者多个的时候都不需要-c了)
/usr/local/apache2/conf/httppwd 这个就是AuthUserFile认证用户文件的路径文件)
 
然后重启服务
 
访问 http://ip/test
  输入用户名和密码
 
组的认证
 
修改配置文件
vim /usr/local/apache2/conf/httpd.conf
 
#####添加这几句(用了一个虚拟目录)
     Alias  /test     "/data/web"
<Directory "/data/web">
    Options Indexes MultiViews FollowSymLinks
    AllowOverride All
    AuthType basic
    AuthName "welcome test"
    AuthUserFile /usr/local/apache2/conf/httppwd
    AuthGroupFile /usr/local/apache2/conf/httpgrp
    Require group admin
</Directory>
####保存退出
 
建立组认证的文件
vim /usr/local/apache2/conf/httpgrp
 
###添加组里面的成员
admin:test jie(需要加入直接玩后面添加)
####然后保存退出
 
用户密码和之前建立的一样
 
然后重启服务
 
 
#######apache配置文件的一些其它参数######
# User home directories
#Include conf/extra/httpd-userdir.conf  (把这个#号去掉就可以做个人主页网址)
         这个可以自己写路径,建议路径的目录最好在conf目录下
#LoadModule userdir_module modules/mod_userdir.so (这个# 号是随着上面的一起的,这个
就是userdir的模块,这句也在配置文件中,可以找到)
 
# Virtual hosts
#Include conf/extra/httpd-vhosts.conf
这句是做虚拟主机
#########建议主配置文件内容越少越好######
 
$$$$$$$$$$$额外的补充$$$$$$$$$$$$$$$$$$$
禁止使用IP直接访问apache
1. 新建立一个默认主机,即出现在所有<VirtualHost *:80>最重要的
 
<VirtualHost *:80>
  ServerName x.x.x
  DocumentRoot /var/www/error
  RewriteEngine On
  RewriteRule   ^.*  /400.php
</VirtualHost>
 
2. 编辑文件/var/www/error/400.php, 输出以下代码:
<?php
header("HTTP/1.1 400 Bad Request");  
?>
<h1>Bad Request</h1>
 
如此,即可实现禁止直接用ip访问apache。
 
解释一下上面的原理:
1. 将对默认主机的所有请求重写向到/var/www/error/400.php
2.   利用php程序输出400状态。
 
不足之处,apache服务器必须安装php解析模块。
$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$                   
 
 
 
 
$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$参考脚本$$$$$$$$$$$$$$$$$$$$$
运行脚本提示:
   这个是一个脚本,运行这个脚本能够一次性成功安装完源码包搭建的apache,此脚本只供方便,我执行这个脚本是已经成功安装几遍了,此脚本运行成功,先要搭建好yum(如何搭建yum这里不在此介绍了),然后解压好所需的源码包。解压没有先后顺序,但是安装的时候有先后顺序。
tar zxvf httpd-2.4.3.tar.gz -C /usr/src/
tar zxvf apr-1.4.2.tar.gz -C /usr/src/
tar zxvf apr-util-1.3.10.tar.gz -C /usr/src/
tar zxvf pcre-8.11.tar.gz -C /usr/src/
然后在/usr/src/目录下面vim 一个文件
eg:vim httpd.sh
然后把下面的copy到httpd.sh里面保存退出在给httpd.sh添加可执行的权限
chmod +x /usr/src/httpd.sh
然后在执行脚本 /usr/src/httpd.sh
以下所有都是需要复制的内容(从#bin/bash都开始复制)
 
#bin/bash
echo "####first,use yum install this rpm####"
yum -y install gcc 
yum -y install gcc-c++
yum -y install openssl-devel
echo "###second,install httpd the dependencies###"
echo "#####welcome to apr install#####"
cd /usr/src/apr-1.4.2
./configure --prefix=/usr/local/apr && make && make install
echo "#####apr is installed#####"
 
echo "#####welcome to apr-util install#####"
cd  /usr/src/apr-util-1.3.10
./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr/bin/apr-1-config && make && make install
echo "#####apr-util is installed#####"
 
echo "#####welcome to pcre install#####"
cd /usr/src/pcre-8.11
./configure --prefix=/usr/local/pcre && make && make install
echo "#####prce is installed#####"
 
echo "###now,install httpd###"
echo "#####welcome to httpd install######"
cd /usr/src/httpd-2.4.3
./configure --prefix=/usr/local/apache2  --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --with-pcre=/usr/local/pcre --enable-so --enable-rewrite --enable-ssl --with-ssl=/usr/lib--enable-auth-digest --enable-cgi --enable-suexec --with-suexec-caller=daemon --with-suexec-docroot=/usr/local/apache2/htdocs && make && make install
echo "#####httpd is installed#####"
echo "####please check httpd is ok,if no error above before,please start httpd #####"