Linux系统如何编译安装Apache服务器
作者:唱记_665 | 来源:互联网 | 2014-05-28 10:53
Linuxapache编译安装文章分类:操作系统1.下载httpd-2.2.15.tar.gzwgethttp://mirror.bjtu.edu.cn/apache/httpd/httpd-2.2.17.tar.gz[root@test-AS4~]#mkdir-P/usr/local/src/apache/#创建源包
1.下载httpd-2.2.15.tar.gz
wget
http://mirror.bjtu.edu.cn/apache/httpd/httpd-2.2.17.tar.gz
[root@test-AS4 ~]# mkdir -P
/usr/local/src/apache/ #创建源包存放的目录
[root@test-AS4 ~]# cd
/usr/local/src/apache/
#把httpd-2.2.15.tar.gz放入此目录下
[root@test-AS4 apache]# tar zxvf
httpd-2.2.15.tar.gz
#解压文件会生成httpd-2.2.15目录
[root@test-AS4 apache]# ll
total 6464
drwxr-xr-x 11 angel angel 4096 Mar 10 07:42
httpd-2.2.15
-rw-r--r-- 1 root root 6593633 Mar 10
2010 httpd-2.2.15.tar.gz
[root@test-AS4 httpd-2.2.15]# cd httpd-2.2.15
[root@test-AS4 httpd-2.2.15]# ./configure
--prefix=/usr/local/apache-2.2.15 --enable-so
--enable-mods-shared=most --with-mpm=worker
如果发现gcc没有装,请先安装GCC yum -y install gcc
[root@test-AS4 httpd-2.2.15]# make
#执行make前执行 apt-get build-dep fcitx
[root@test-AS4 httpd-2.2.15]# make install
# --prefix=
指明编译后的二进制文件安装到目录,用实际安装路径替换,如--prefix=/usr/local/apache-2.2.15
,如果省略此配置参数,默认安装到/usr/local/apache2目录。
# --enable-so
指明编译动态加载模块(DSO)支持到httpd二进制文件,此模块使得Apache的各功能模块可以与核心分开编译、运行时动态加载。有了DSO支持,升级和增加模块时只需编译相关的模块即可,不必重新编译整个系统。最新版本的Apache缺省编译此模块到httpd二进制文件,如果你在使用早期版本的apache并且需要DSO支持,可能要明确指出此选项。
# --enable-mods-shared=
明确指明要以DSO方式编译的模块,为空格分隔的模块名列表、all或者most,all表示包含所有模块,most表示包含大部分模块,如--enable-mods-share="rewrite
deflate",--enable-mods-share=most,效果等同于多个--enable-=share
# --with-mpm=
先择Apache多路处理模块,={beos|event|worker|prefork|mpmt_os2},prefork为Unix系统下默认处理模块,它将运行一个非线程型的、预派生的Web服务器,适合于没有线程安全库,需要避免线程兼容性问题的系统,它是要求将每个请求相互独立的情况下最好的MPM,这样若一个请求出现问题就不会影响到其他请求。worker为支持混合的多线程多进程的多路处理模块,由于使用线程来处理请求,所以可以处理海量请求,而系统资源的开销小于基于进程的MPM,同时,它也使用了多进程,每个进程又有多个线程,以获得基于进程的MPM的稳定性。如果你的系统是基于线程安全的,那么笔者建议使用worker替代prefork,它将使得你的系统得到实际的性能改善。
2. 设置开机自启动服务控制脚本
Apache安装后可通过其安装路径的bin目录下的apachectl脚本控制服务的启动和停止。本例中apache安装在/usr/local/apache-2.2.15,服务控制脚本为:
/usr/local/apache-2.2.15/bin/apachectl
执行下面的命令启动Apache服务:
/usr/local/apache-2.2.15/bin/apachectl start
执行下面的命令停止Apache服务:
/usr/local/apache-2.2.15/bin/apachectl stop
可以简单地把Apache启动命令加到/etc/rc.local文件,让Apache随系统启动而自动启动:
echo "/usr/local/apache-2.2.15/bin/apachectl start"
>> /etc/rc.local
下面介绍如何把Apache加入到系统服务,用service命令来控制Apache的启动和停止。
## 这里请注意一下!如果Linux服务器上默认安装了httpd的话(用rpm -qa|grep httpd查看),
## 会有 /etc/init.d/httpd 这个脚本文件的,所以你也可以用以下方法直接生成这个文件来覆盖它
## 那么下次就可以用 service httpd start 来启动了
## 如果需要区分开来的话就使用下面的方式
首先以apachectl脚本为模板生成Apache服务控制脚本:
grep -v "#" /usr/local/apache-2.2.15/bin/apachectl >
/etc/init.d/apache
用vi编辑Apache服务控制脚本/etc/init.d/apache:
vi /etc/init.d/apache
在文件最前面插入下面的行,使其支持chkconfig命令:
#!/bin/sh
# chkconfig: 2345 85 15
# description: Apache is a World Wide Web server.
保存后退出vi编辑器,执行下面的命令增加Apache服务控制脚本执行权限:
chmod +x /etc/init.d/apache
执行下面的命令将Apache服务加入到系统服务:
chkconfig --add apache
执行下面的命令检查Apache服务是否已经生效:
chkconfig --list apache
命令输出类似下面的结果:
apache 0:off
1:off 2:on 3:on 4:on 5:on 6:off
表明apache服务已经生效,在2、3、4、5运行级别随系统启动而自动启动,以后可以使用service命令控制Apache的启动和停止。
启动Apache服务:
service apache start
停止Apache服务:
service apache stop
执行下面的命令关闭开机自启动:
chkconfig apache off
执行下面的命令改变开机自启动的运行级别为3、5:
chkconfig --level 35 apache on
3. Apache的配置
源码包方式安装目录结构
源码包方式安装时通常是在configure命令的--prefix选项指定的目录中建立如下的目录结构,特殊指定的目录除外:
./icons #Apache图标文件目录
./modules #动态加载模块目录
./lib #库文件目录
./logs #日志文件目录
./build #
./conf #主配置文件目录
./conf/extra #扩展及模块配置文件目录
./error #默认错误应答文件目录
./manual #Apache文档目录
./include #包含头文件目录
./htdocs #默认WEB文档根目录
./cgi-bin #默认cgi文件目录
./bin #Apache二进制程序及服务程序目录
./man #man帮助文件目录
4. 配置文件 http.conf
ServerRoot
"/usr/local/apache-2.2.15"
##设置服务器的基础目录,默认为Apache安装目录
Listen
80
##设置服务器监听的IP和端口
LoadModule authn_file_module modules/mod_authn_file.so
LoadModule authn_dbm_module modules/mod_authn_dbm.so
LoadModule authn_anon_module modules/mod_authn_anon.so
LoadModule authn_dbd_module modules/mod_authn_dbd.so
LoadModule authn_default_module modules/mod_authn_default.so
LoadModule authz_host_module modules/mod_authz_host.so
LoadModule authz_groupfile_module
modules/mod_authz_groupfile.so
LoadModule authz_user_module modules/mod_authz_user.so
LoadModule authz_dbm_module modules/mod_authz_dbm.so
LoadModule authz_owner_module modules/mod_authz_owner.so
LoadModule authz_default_module modules/mod_authz_default.so
LoadModule auth_basic_module modules/mod_auth_basic.so
LoadModule auth_digest_module modules/mod_auth_digest.so
LoadModule dbd_module modules/mod_dbd.so
LoadModule dumpio_module modules/mod_dumpio.so
LoadModule reqtimeout_module modules/mod_reqtimeout.so
LoadModule ext_filter_module modules/mod_ext_filter.so
LoadModule include_module modules/mod_include.so
LoadModule filter_module modules/mod_filter.so
LoadModule substitute_module modules/mod_substitute.so
LoadModule deflate_module modules/mod_deflate.so
LoadModule log_config_module modules/mod_log_config.so
LoadModule logio_module modules/mod_logio.so
LoadModule env_module modules/mod_env.so
LoadModule expires_module modules/mod_expires.so
LoadModule headers_module modules/mod_headers.so
LoadModule ident_module modules/mod_ident.so
LoadModule setenvif_module modules/mod_setenvif.so
LoadModule version_module modules/mod_version.so
LoadModule mime_module modules/mod_mime.so
LoadModule dav_module modules/mod_dav.so
LoadModule status_module modules/mod_status.so
LoadModule autoindex_module modules/mod_autoindex.so
LoadModule asis_module modules/mod_asis.so
LoadModule info_module modules/mod_info.so
LoadModule cgid_module modules/mod_cgid.so
LoadModule dav_fs_module modules/mod_dav_fs.so
LoadModule vhost_alias_module modules/mod_vhost_alias.so
LoadModule negotiation_module modules/mod_negotiation.so
LoadModule dir_module modules/mod_dir.so
LoadModule imagemap_module modules/mod_imagemap.so
LoadModule actions_module modules/mod_actions.so
LoadModule speling_module modules/mod_speling.so
LoadModule userdir_module modules/mod_userdir.so
LoadModule alias_module modules/mod_alias.so
LoadModule rewrite_module modules/mod_rewrite.so
User daemon ##设置实际提供服务的子进程的用户。
Group daemon ##设置提供服务的Apache子进程运行时的用户组。
ServerAdmin you@example.com
##设置在所有返回给客户端的错误信息中包含的管理员邮件地址。
ServerName 192.168.221.128
##设置服务器用于辨识自己的主机名和端口号(用IP代替)。
DocumentRoot
"/usr/local/apache-2.2.15/htdocs"
##设置Web文档根目录。
###和用于封装一组指令,使之仅对某个目录及其子目录生效。
Options FollowSymLinks
AllowOverride None
Order deny,allow
Deny from all
##设置DocumentRoot指定目录的属性
Options Indexes FollowSymLinks
##建议拿掉Indexes
AllowOverride None
Order allow,deny
Allow from all
##设置默认目录资源列表文件
DirectoryIndex index_top.html entrance.html
index.html index.php index.htm index.asp index.php3
##拒绝对.ht开头文件的访问,以保护.htaccess文件
Order allow,deny
Deny from all
Satisfy All
ErrorLog "logs/error_log"
##指定错误日志文件
LogLevel warn
##指定记录到错误日志的消息级别
##定义访问日志的格式
LogFormat "%h %l %u %t \"%r\" %>s %b
\"%{Referer}i\" \"%{User-Agent}i\"" combined
LogFormat "%h %l %u %t \"%r\" %>s %b"
common
LogFormat "%h %l %u %t \"%r\" %>s
%b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio
CustomLog "logs/access_log"
common ##指定访问日志及使用的格式
##设定默认CGI脚本目录及别名
ScriptAlias /cgi-bin/
"/usr/local/apache-2.2.15/cgi-bin/"
##设定默认CGI脚本目录的属性
AllowOverride None
Options None
Order allow,deny
Allow from all
DefaultType text/plain ##设定默认MIME内容类型
TypesConfig conf/mime.types
AddType application/x-compress .Z
AddType application/x-gzip .gz .tgz
SSLRandomSeed startup builtin
SSLRandomSeed connect builtin
##编译参数 --with-mpm=worker时,使用worker.c模块
ServerLimit
25 ##/usr/local/apache-2.2.15/bin/apachectl
-l查看使用模块
ThreadLimit 200
StartServers 3
MaxClients 2000
MinSpareThreads 50
MaxSpareThreads 200
ThreadsPerChild 100
MaxRequestsPerChild 1000
Timeout 15
KeepAlive On
MaxKeepAliveRequests 100
KeepAliveTimeout 3
UseCanonicalName Off
AccessFileName .htaccess
ServerTokens Prod
ServerSignature Off
HostnameLookups Off
NameVirtualHost *:80
DocumentRoot
/usr/local/apache-2.2.15/htdocs/irene
ServerName www.irene.com
DocumentRoot
/usr/local/apache-2.2.15/htdocs/angel
ServerName www.angel.com
-----------------------------------------------------------------------------------------
4. 认证和授权配置
## 在httpd.conf配置文件中添加如下代码
AllowOverride
None ## 不使用.htaccess文件
AuthType
Basic ##
指定使用基本认证方式
AuthName
"apache.passwd" ## 指定认证领域名称
AuthUserFile
/usr/local/apache-2.2.15/htdocs/protect/apache.passwd ##
认证口令存放位置
require
valid-user ## 授权给认证口令文件中的所有用户
#Order allow,deny
#Allow from all
** 由于文本中 DocumentRoot "/usr/local/apache-2.2.15/htdocs"
已经指定了你的文档根目录
** 所以在这个目录下建立相关目录作为指定的保护文档位置
** 也可以使用Alias别名 指定一个其他目录
[root@test-AS4 ~]# cd /usr/local/apache-2.2.15/htdocs
[root@test-AS4 htdocs]# mkdir protect
[root@test-AS4 protect]# htpasswd -c apache.passwd angel
[root@test-AS4 protect]# ll
total 8
-rw-r--r-- 1 root root 20 Mar 14 21:14 apache.passwd
[root@test-AS4 protect]# cat apache.passwd
angel:Grka1xfi6y5RM
[root@test-AS4 protect]#
## 打开浏览器URL: http://192.168.221.128/protect/
推荐阅读
-
计划建立个人博客来分享生活与工作的见解和经验,选择WordPress是因为它专为博客设计,功能强大且易于使用。 ...
[详细]
蜡笔小新 2024-11-22 11:13:36
-
本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ...
[详细]
蜡笔小新 2024-11-21 20:16:59
-
-
本文详细介绍如何安装和配置DedeCMS的移动端站点,包括新版本安装、老版本升级、模板适配以及必要的代码修改,以确保移动站点的正常运行。 ...
[详细]
蜡笔小新 2024-11-22 18:44:25
-
本文详细介绍了JavaScript在不同域之间进行数据传输或通信的技术,包括使用JSONP、修改document.domain、利用window.name以及HTML5的postMessage方法等跨域解决方案。 ...
[详细]
蜡笔小新 2024-11-22 16:27:56
-
本文详细介绍了如何在Oracle VM VirtualBox中实现主机与虚拟机之间的数据交换,包括安装Guest Additions增强功能,以及如何利用这些功能进行文件传输、屏幕调整等操作。 ...
[详细]
蜡笔小新 2024-11-21 18:13:22
-
本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ...
[详细]
蜡笔小新 2024-11-21 17:42:08
-
在Android应用开发过程中,开发者经常遇到诸如CPU使用率过高、内存泄漏等问题。本文将介绍几种常用的命令及其应用场景,帮助开发者有效定位并解决问题。 ...
[详细]
蜡笔小新 2024-11-22 09:50:34
-
本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ...
[详细]
蜡笔小新 2024-11-22 05:45:48
-
近期,关于Android开发行业的讨论在多个平台上热度不减,许多人担忧其未来发展。本文将探讨当前Android开发市场的现状、薪资水平及职业选择建议。 ...
[详细]
蜡笔小新 2024-11-21 18:08:07
-
本文深入探讨了软件测试行业的发展现状及未来趋势,旨在帮助有志于在该领域取得高薪的技术人员明确职业方向和发展路径。 ...
[详细]
蜡笔小新 2024-11-21 17:32:44
-
在日常生活中,支付宝已成为不可或缺的支付工具之一。本文将详细介绍如何通过支付宝实现免费提现,帮助用户更好地管理个人财务,避免不必要的手续费支出。 ...
[详细]
蜡笔小新 2024-11-21 16:47:52
-
问题描述现在,不管开发一个多大的系统(至少我现在的部门是这样的),都会带一个日志功能;在实际开发过程中 ...
[详细]
蜡笔小新 2024-11-21 15:14:45
-
我的读书清单(持续更新)201705311.《一千零一夜》2006(四五年级)2.《中华上下五千年》2008(初一)3.《鲁滨孙漂流记》2008(初二)4.《钢铁是怎样炼成的》20 ...
[详细]
蜡笔小新 2024-11-21 13:01:23
-
本文详细探讨了Linux系统中的文件权限设置,包括常见的755、700等权限模式,以及这些权限在实际应用中的具体含义和作用。 ...
[详细]
蜡笔小新 2024-11-21 11:35:38
-
在开发微信公众号或小程序的时候,由于微信平台规则的限制,部分接口需要通过线上域名才能正常访问。但我们一般都会在本地开发,因为这能快速的看到 ...
[详细]
蜡笔小新 2024-11-21 11:15:53
-