当前位置:Linux教程 - Apache - apache - apache基本教程

apache - apache基本教程

apache基本教程
2004-04-23 15:18 pm
来自:Linux文档
现载:Www.8s8s.coM
地址:无名

Apache(1)

发布日期:1999-12-09
文摘内容:
--------------------------------------------------------------------------------
原著:Mark Lomarinski 和 Cary Collett


编译Apache

逐步指导如何定制世界最流行的Web服务器

概要:

如果你的工作职则包括管理Apache,很有可能有一天你需要自己编译Apache。Mark 和Cary介绍了一些Apache的编译及其模块的选项,并演示了他们如何建立一个命令行的配置来编译Apache。


现在你已经拿到了你那闪亮的新Linux机器,它已经安装了Apache,运行地很好。但是现在你需要升级你的Web服务器,或你想运行一些可选的模块,可能你也想去掉一些缺省的模块,你不见得在已编译的Apache版本中找得到你需要的模块。

现在就需要你自己编译Apache了。

即使你不需要增加或删除Apache模块,在你事业的某一刻作为系统管理员你也有可能需要改变Apache的实时配置。

不管是哪种情况,Apache的缺省配置或配置你自己的安装在最开始都会让人气馁。
这个月,我们要谈谈编译Apache1.3的实时配置及其它常用的实时.conf 文件例子。

获得Apache

获得apache源代码最方便的方法是到Apache项目网址(http://www.apache.org/)或其镜相点(见以下的资源)上的下载区域(http://your.nearyby.apache.mirror/dist/)。选择最新的版本。在我们写这篇文章的时候最新版是1.3.3。

由于Apache小组一直在修补bug并改进代码,重要的是你得到最新的版本。

 

编译Apache

在1.3版以前,Apache使用的配置的基础即不是GNU的autoconf也不是Imake---两种最常用的自动配置的工具。另外,也没有现成的安装可使你用熟悉的办法安装。

现在一切都会很好办,如果你在你想要运行Apache的目录中解开tarball。 但是如果你想要在不同的目录树中运行Apache,你将不得不用手复制目录结构。

版本1.3使用GNU autoconf但是仍然为宁愿它的那些人支持配置的旧的风格。 除此之外基于更多标准的GNU autoconf,版本1.3使增加第三方模块变得容易: 为了增加一种新的模块,你

在构成Apache时简单地使用--激活模块指示。 因此不再需要编辑文件。

只要你在配置使用autoconf的Apache时运行./configure--help是一个好主意。 这应该产生一个配置会接受的冗长的一般标记表,在最后还有你所编译程序的列表。

由于这是一张长的表,你将有可能想要通过进入把它输送到你特别喜爱页码程序(例如,less):

./configure--help|less

在./configure--help开始时所列出的输出选项中,有一个你将要很有可能想要使用--prefix。 它控制Apache安装的根目录的位置。 其它有用的指示下面在表格上被列出。

--datadir=DIR
文件根(htdocs)和cgi-bin目录将在

什么地方被建立,缺 省为<prefix>/share

--runtimedir=DIR
过程识别(PID)文件将在什么地方被保存

缺省为<prefix>/var/apache/run

--logfiledir=DIR
log文件将在什么地方被保存

缺省为<prefix>/var/apache/log

如果DIR前面没有/,它被理解为与你冠有--prefix的目录有关,否则被理解为一条绝对的路径。

所有这些(除安装目录外)能在.conf文件中的时间库中修改。 然而,如果你想要新的Apache控制程序(Apachetl)充分发挥作用而没有任何修改,你至少应该在编译时间表明的位置留下PID文件。

好的规则

更进一步的--help输出是更有趣的指示。 下一段是一套配置规则,我们想用Apache支持IRIXN32,IRIXNIS,PARANOID,SHARED-CHAIN,SHARED-CORE,SOCKS4,SOCKS5,和/或WANTHSREGEX。

头两项规则与SGI的Irix有关,它们可以忽略并保留缺省值。 PARANOID是在编译模块时间里与执行Shell命令的Apache1.3能力相联系的。 如果你键入

--enable-rule=PARANOID

配置将发出回声它执行的命令终端。

SHARED-CHAIN和SHARED-CORE规则是Apache动态的共用的对象(DSO)支持的一部分。 DSO大部分的强迫特性让你再编译模块并装载它而不用再编译Apache。

DSO仍然是实验性和有疑问的,尤其如果你使用不支持它的第三方模块。 我们不推荐DSO除非你确实需要它。

你可能需要SHARED-CHAIN,如果你有模块你作为编译共用的对象,其参考其它共用的对象或者库。

SHARED-CORE也使Apache核心共用。 对于这个例子,只要使用其缺省值。

SOCKS4和SOCKS5指示仅仅在你使用Apache作为proxy服务器时使用。 它们分别支持SOCK代理协议的版本4和5。 使用Apache作为代理人服务器超出本文的范围,如此我们暂时放开这个话题,但是我们计划在未来讨论它。

最后是WANTHSREGEX规则。 它控制Apache是否将使用系统常规的表达库或者随Apache发布来的regex库。 我们通常发现简单地使用随Apache发布的regex库是容易的。 这样,所有规则中,这是将在配置命令行中唯一一个。

 
在规则段之下是激活第三方模块的两条指令。 第一,--add-module=<file>,将首先从<file>拷贝模块到Apache建造目录并激活它; 第二,--activate-module=<file>,如果你已经在适当的位置上有模块,此指令会被使用。

 
<file>的确切的形式依模块而变化。 我们将不再讨论增加第三方模块,但是我们计划在以后讨论。

 
模块操纵

下一段控制随Apache而来的模块,许多你从不需要触到。

完全的列表(从./configure--help输出)为:

access=yes
actions=yes
alias=yes

asis=yes
auth=yes
auth-anon=no

auth-db=no
auth-dbm=no
autoindex=yes

cern-meta=no
cgi=yes
digest=no

dir=yes
env=yes
example=no

expires=no
headers=no
imap=yes

include=yes
info=no
log_agent=no

log_config=yes
log_referer=no
mime=yes

mime_magic=no
mmap-static=no
negotiation=yes

proxy=no
rewrite=no
setenvif=yes

so=no
speling=no
status=yes

unique_id=no
userdir=yes
usertrack=no

所有的模块的短描述能在src/Configuration中被找到。 有些模块你很有可能将要用到,下面是简要的描述。 我们没有涉及到的那些模块可以使用缺省设置。 简言之,如果你对一些模块

不是很确定的话就使用其缺省设置。

下列的组模块控制进入和验证,如果你不打算限制Web进入或者使用一种其它的方法,你可以使其禁用。
Apache(2)

发布日期:1999-12-09
文摘内容:
--------------------------------------------------------------------------------

来源:中国Linux论坛 <http://www.linuxforum.net/>
原著:Mark Lomarinski 和 Cary Collett
翻译:<>


Acess
你想要进入控制吗?

auth
检查Unix-style口令和组文件的基本的验证。

auth-anon
使用匿名的FTP-style usernames和口令。

auth-dbm
使用Berkeley db文件存储usernames,口令,和组信息。如果你有很多usernames并关心性能, 这是很有用的。

digest
使用HTTP文摘验证,这比基本的验证更安全。

expire(过期)模块让你定制Expire: 基于像进入时间或者修改时间一样的事情的各种各样的资源的标题。
 

如果你想要能够跟踪你站点的点击,不想要使用某种进入控制的方法,你能使usertrack激活。 它使用cookie值作为一个唯一的ID。
 
共用的模块通过so模块成为可用。 如上所述,共用的模块和DSO是实验性的,不推荐使用。

在Apache1.3中鼓励你通过客户log记录所有登录。 Apache提供复制标准的agent和refer报告格式的log格式。 这意味你将很有可能想要把log_config设置把为On,log_agent和log_refer为off,因为它们是多余的。

如果你不想要你的用户自动地有一个目录可以为HTML服务(通过http://your.server.com/~user),你能使userdir模块禁用。

最后,如果你需要做URI-to-filename地图,你能够重写模块。 它可让你使用常规的表达式对要求做复杂(和简单!) 重写。

一个具体的例子: 我们如何构成Apache

当我们建立构成命令行,我们喜欢打开Xemacs缓冲器并且打出(或者拷贝和粘贴)命令并且为将来的再编译保存它。

我们当前Apache配置行看起来如下:

./configure--prefix=/home/httpd
--enable-rule=WANTHSREGEX
--activate-module=src/modules/PyApache/mod-pyapache.c
--activate-module=src/modules/php3/libphp3.a
--enable-module=headers

首先,我们告诉Apache使用捆绑的regex库; 然后,我们使两种第三方模块可用:PyApache的(在Apache中嵌入Python 解释器以消除Python CGI语句解释程序的启动时间)和PHP3(类C的HTML嵌入语言); 最后,我们打开标题模块,因为我们为登录目的使用某种专断的标题。

当我们运行配置,我们得到以下输出:

Configuring for Apache, Version 1.3.3
+ activated pyapache module (modules/PyApache/mod_pyapache.c)
+ activated php3 module (modules/php3/libphp3.a)
Creating Makefile
Creating Configuration.apaci in src
Creating Makefile in src
+ configured for Linux platform
+ setting C compiler to gcc
+ setting C pre-processor to gcc -E
+ checking for system header files
+ adding selected modules
o PyApache uses ConfigStart/End
o php3_module uses ConfigStart/End
+ doing sanity check on compiler and options
Creating Makefile in src/support
Creating Makefile in src/main
Creating Makefile in src/ap
Creating Makefile in src/regex
Creating Makefile in src/os/unix
Creating Makefile in src/modules/standard
Creating Makefile in src/modules/PyApache
Creating Makefile in src/modules/php3

所有坚苦的工作现在被完成! 键入:

make install

它应该建造二进制文件(httpd加一些帮助程序),建立目录树并且安装各种文件。

Apache1.3的缺省目录布局是:

./bin
帮助程序和原代码(htpasswd)

./etc/apache
Apache配置文件

./include/apache
Apache标题文件

./libexec
共用的对象文件

./man
man 页

./sbin
服务器二进制,apachectl原本,log rotator

./share/cgi-bin
缺省CGI原本/二进制的目录

./share/htdocs
缺省文件根

./share/htdocs/manual
Apache手册

./share/icon
包含各种图标GIFs的目录

./var/apache/log
log文件的目录

./var/apache/proxy
proxy缓存目录

./var/apache/run
httpd.pid(包含主要的httpd过程标识

符的文件)在此目录

与Apache1.3一样apachectl原代码也是新的,它让你停止、开始,得到服务器状态并且再装入.conf文件。从安装目录开始运行Apache键入

sbin/apachectl start.

运行sbin/apachectl(没有变元)将给你变元和简短描述的列表。

你现在有手工定制的Apache服务器运行并准备提供页面服务并且执行CGIs!

关于更多信息,你当然应该访问Apache的Web页面,在那里你总可以找到最新的信息、补丁和公告。 你也可以登记Apache邮件列表。([email protected])或者阅读comp.infosystems.www.servers.unix newsgroup。

我们下个月将从功能、安全、和性能等方面讨论Apache的运行配置。接下来的部分将讨论诸如mod-php3和mod-perl的各种第三方模块。

关于作者

Mark Komarinski是Waltham,MA的Auraora Technologies的系统管理人员。 他是以前Linux期刊LinuxCompanion的专栏作者和作者。 他和Cary Collett 共同发表了The Linux System Administration Handbook