`

apache 的模块安装

阅读更多

Apache HTTP服务器是一个模块化的软件,管理员可以通过选择服务器中包含的模块进行功能增减。模块可以在编译时被静态包含进httpd二进制文件,也可以编译成独立于httpd二进制文件的动态共享对象(DSO)。DSO模块可以与服务器一起编译,也可以用Apache扩展工具(apxs)单独编译。

本文阐述如何使用DSO模块及其工作原理。

实现
相关模块 相关指令
mod_so
LoadModule

Apache对独立模块的DSO支持是建立在只能被静态编译进Apache核心的mod_so基础之上的,这是core以外唯一不能作为DSO存在的模块,而其他所有已发布的Apache模块,都可以通过安装文档中阐述中的编译选项 --enable-module=shared 被独立地编译成DSO并使之生效。一个被编译为mod_foo.so的DSO模块,可以在httpd.conf中使用mod_so的LoadModule指令,在服务器启动或重新启动时被加载。

新提供的支持程序apxs(APache eXtenSion)可以在Apache源代码树之外编译基于DSO的模块,从而简化了Apache DSO模块的建立过程。其原理很简单:安装Apache时,configure的 make install 命令会安装Apache C头文件,并把依赖于特定平台的编译器和连接器参数传给apxs程序,使用户可以脱离Apache的发布源代码树编译其模块源代码,而不改变支持DSO的编译器和连接器的参数。

用法概要

Apache2.0 的DSO功能简要说明:

1. 编译并安装已发布的Apache模块,比如编译mod_foo.c为mod_foo.so的DSO模块:

  1. $ ./configure --prefix=/path/to/install --enable-foo=shared   
  2. $ make install  

2. 编译并安装第三方模块,比如编译mod_foo.c为mod_foo.so的DSO模块:
  1. $ ./configure --add-module=module_type:/path/to/3rdparty/mod_foo.c --enable-foo=shared   
  2. $ make install  

3. 配置Apache以便以后安装共享模块:
  1. $ ./configure --enable-so   
  2. $ make install  

4. 用apxs在Apache源码树以外编译并安装第三方模块,比如编译mod_foo.c为mod_foo.so的DSO模块:
  1. $ cd /path/to/3rdparty   
  2. $ apxs -c mod_foo.c   
  3. $ apxs -i -a -n foo mod_foo.la  

共享模块编译完毕后,必须在httpd.conf中用LoadModule指令使Apache启用该模块。

背景知识

现代的类Unix系统都有一种叫动态共享对象(DSO)的动态连接/加载的巧妙的机制,从而可以在运行时将编译成特殊格式的代码加载到一个可执行程序的地址空间。

加载的方法通常有两种:其一是在可执行文件启动时由系统程序ld.so自动加载;其二是在可执行程序中手动地通过Unix加载器的系统接口执行系统调用dlopen()/dlsym()进行加载。

按第一种方法,DSO通常被称为共享库(shared libraries)或者DSO库(DSO libraries),使用libfoo.so或libfoo.so.1.2的文件名,存储在系统目录中(通常是/usr/lib),并在编译安装时使用连接器参数 -lfoo 建立了指向可执行程序的连接。通过设置连接器参数 -R 或者环境变量LD_LIBRARY_PATH ,库中硬编码了可执行文件的路径,使Unix加载器能够在可执行程序启动时定位到位于/usr/lib目录中的libfoo.so ,以解析可执行文件中尚未解析的位于DSO中的符号。

通常,DSO不会引用可执行文件中的符号(因为它是通用代码的可重用库),也不会有后继的解析动作。可执行文件无须自己作任何动作以使用DSO中的符号,而完全由Unix加载器代办(事实上,调用ld.so的代码是被连入每个可执行文件的非静态运行时启动代码的一部分)。动态加载公共库代码的优点是明显的:只需要在系统库libc.so中存储一次库代码,从而为每个程序节省了磁盘存储空间。

按第二种方法,DSO通常被称为共享对象(shared objects)或DSO文件(DSO files),可以使用任何文件名(但是规范的名称是foo.so),被存储在程序特定的目录中,也不会自动建立指向其所用的可执行文件的连接,而由可执行文件在运行时自己调用dlopen()来加载DSO到其地址空间,同时也不会进行为可执行文件解析DSO中符号的操作。Unix加载器会根据可执行程序的输出符号表和已经加载的DSO库自动解析DSO中尚未解析的符号(尤其是无所不在的libc.so中的符号),如此DSO就获得了可执行程序的符号信息,就好象是被静态连接一样。

最后,为了利用DSO API的优点,可执行程序必须用dlsym()解析DSO中的符号,以备稍后在诸如指派表等等中使用。也就是说,可执行程序必须自己解析其所需的符号。这种机制的优点是允许不加载可选的程序部件,直到程序需要的时候才被动态地加载(也就不需要内存开销),以扩展程序的功能。

虽然这种DSO机制看似很直接,但至少有一个难点,就是在用DSO扩展程序功能(第二种方法)时为DSO对可执行程序中符号的进行解析,这是因为,"反向解析"可执行程序中的DSO符号在所有标准平台上与库的设计都是矛盾的(库不会知道什么程序会使用它)。实际应用中,可执行文件中的全局符号通常不是重输出的,因此不能为DSO所用。所以在运行时用DSO来扩展程序功能,就必须找到强制连接器输出所有全局符号的方法。

共享库是一种典型的解决方法,因为它符合DSO机制,而且为操作系统所提供的几乎所有类型的库所使用。另一方面,使用共享对象并不是许多程序为扩展其功能所采用的方法。

截止到1998年,只有少数的软件包使用DSO机制在运行时扩展其功能,诸如 Perl 5(通过其XS机制和DynaLoader模块),Netscape Server等。从1.3版本开始,Apache也加入此列,因为Apache已经用了基于指派表(dispatch-list-based)的方法来连接外部模块到Apache的核心。所以Apache也就当然地在运行时用DSO来加载其模块。

优点和缺点

上述基于DSO的功能有如下优点:

★ 由于服务器包的装配工作可以在运行时使用httpd.conf中的配置命令LoadModule来进行,而不是在编译中使用编译选项来进行,因此显得更灵活。比如,只需要安装一个Apache,就可以运行多个不同的服务器实例(如标准&SSL版本,浓缩&功能加强版本[mod_perl、PHP])。
★ 服务器可以在安装后使用第三方模块被轻易地扩展。这至少对厂商发行包的维护者有巨大的好处,他可以建立一个Apache核心包,而为诸如PHP、mod_perl、mod_fastcgi等扩展另建附加的包。
★ 更简单的Apache模块原型。使用DSO配合apxs,可以脱离Apache源代码树,仅需要一个 apxs -i 和一个 apachectl restart 命令,就可以把刚开发的新模块纳入到运行中的Apache服务器。

DSO有如下缺点:

★ 由于并不是所有操作系统都支持动态加载代码到一个程序的地址空间,因此DSO机制并不能用于所有平台。
★ 由于Unix加载器必须进行符号解析,服务器的启动会慢20%左右。
★ 在某些平台上,位置独立代码(positon independent code[PIC])需要复杂的汇编语言技巧来实现相对寻址,而绝对寻址则不需要,因此服务器在运行时会慢5%左右。
★ 由于DSO模块不能在所有平台上被其他基于DSO的库所连接(ld -lfoo),比如,基于a.out的平台通常不提供此功能,而基于ELF的平台则提供,因此DSO机制并不能被用于所有类型的模块。或者可以这样说,编译为DSO文件的模块只能使用由Apache核心、C库(libc)和Apache核心所用的所有其他动态或静态的库、含有独立位置代码的静态库(libfoo.a)所提供的符号。而要使用其他代码,就只能确保Apache核心本身包含对此代码的引用,或者自己用dlopen()来加载此代码。

分享到:
评论

相关推荐

    window环境下apache模块开发工具apxs及安装使用详细说明

    在Windows环境下,apxs(Apache eXtenSion tool)是一个非常重要的工具,它简化了Apache模块的编译和安装过程。本文将详细介绍apxs的安装和使用方法,以及在Windows环境中进行Apache模块开发的相关知识点。 **apxs...

    Apache2.2.15安装及配置过程

    这些选项包括Apache的安装路径、启用代理模块、启用SSL支持、选择多进程模块(MPM)以及开启动态加载模块(DSO)支持。例如: ```bash ./configure --prefix=/usr/local/web/apache \ --enable-proxy=shared \ --...

    Apache 2.0.55 安装程序

    这个安装程序包含了构建和配置Apache服务器所需的所有组件,使得用户能够在自己的计算机或服务器上部署并运行Apache服务。在本文中,我们将详细探讨Apache 2.0.55的安装过程以及相关的知识点。 首先,了解Apache...

    apache7.0安装文件

    10. **模块扩展**:Apache支持大量的模块扩展,如mod_rewrite用于URL重写,mod_proxy用于代理和负载均衡,mod_deflate用于内容压缩,可以根据需要安装和启用。 请注意,这里提到的"apache-tomcat-7.0.42"文件可能是...

    linux离线安装apache

    ### Linux离线安装Apache知识点详解 #### 一、前言 在Linux环境下离线安装Apache服务器涉及多个步骤,包括但不限于安装必要的开发工具如GCC、G++等,以及配置相关的库文件如PCRE、OpenSSL等。本文将详细介绍整个...

    apache for linux安装

    8. **安全与优化**:为了增强安全性,建议禁用不必要的Apache模块,限制对服务器的访问,以及安装SSL证书以提供HTTPS支持。 9. **日志管理**:Apache的日志文件位于`/var/log/apache2`(Debian/Ubuntu)或`/var/log...

    apache 安装后配置

    Apache通过模块化设计提供了丰富的功能,你可以通过在`httpd.conf`中加载或卸载模块来控制这些功能。例如,如果你需要支持PHP,你需要确保`mod_php`模块已经启用。 第二步,我们注意到`Include conf/extra/httpd-...

    apache优化和模块安装

    Apache 优化和模块安装是提升Web服务器性能的关键步骤。Apache 是一个广泛应用的开源HTTP服务器,它的性能可以通过调整配置参数和安装特定模块来显著提高。在这个过程中,我们将关注两个主要方面:Apache 的最大连接...

    SVN-Apache2.2.8安装配置说明

    - 配置Apache:编辑httpd.conf文件,添加对SVN的支持,设置SVN模块,以及定义SVN的访问路径。 - 用户和权限管理:通过htpasswd工具创建和管理用户,结合Apache的配置文件实现权限控制。 - 使用SSL保护服务器:...

    Apache模块开发

    Apache模块开发指南

    apache 模块开发的例子

    Apache模块可以处理请求、解析配置、过滤内容、管理用户认证等多种任务。本篇文章将深入探讨Apache模块开发的基本概念、流程以及一个名为"adservice"的示例模块。 一、Apache模块开发基础 1. 模块结构:Apache模块...

    离线安装apache所需要的所有包

    在没有网络连接或者网络环境不稳定的情况下,离线安装Apache变得尤为重要。本资源包含离线安装Apache在CentOS系统上所需的所有包,确保了在无网环境下的部署可能性。 首先,了解Apache的基础知识是必要的。Apache的...

    Apache服务器安装软件

    【Apache服务器安装软件】 Apache HTTP Server,简称Apache,是世界上最...总的来说,Apache服务器的安装和配置是一项基础但重要的工作,它为网站提供稳定的基础架构,并且通过各种模块扩展,能满足各种复杂的需求。

    Apache2.2 for Linux安装手册

    在这个例子中,`--prefix=/opt/apache2`指定了安装路径,`--enable-so`则启用模块加载功能。 5. **编译与安装**:接下来,使用`make`命令进行编译,然后使用`make install`命令进行安装。 6. **配置Apache**:配置...

    SVN + Apache 成功安装部署

    通常,这样的过程包括下载和安装两个软件,配置SVN仓库,设置Apache模块,以及可能的权限和安全设置。 **标签解析:** "源码"标签暗示我们将涉及源代码管理,即SVN作为版本控制系统的作用。"工具"标签则提示SVN和...

    apache 安装包(全部组件)

    安装Apache时,通常需要先安装这些依赖库,确保Apache能够正常运行。以下是一般步骤: 1. 解压下载的"appch安装"压缩包。 2. 配置环境:检查系统是否已经安装了apr、apr-util和pcre,如果没有,需要先安装这三个...

    apache模块化体系结构简析

    总结来说,Apache模块化体系结构的核心在于其灵活的挂钩机制,允许开发人员通过创建和注册模块来扩展服务器的功能。这种设计使得Apache不仅能够满足基本的HTTP服务需求,还能适应各种复杂的Web应用程序和服务,成为...

    安装apache mysql php 手册&&开发apache,php扩展模块方法

    3. 配置PHP,同时指定Apache模块(确保Apache已安装且在路径中):`./configure --with-apxs2=/usr/local/apache2/bin/apxs --with-mysql=/usr/local/mysql --with-config-file-path=/etc/php.ini` 4. 编译和安装:`...

    apache服务器安装程序 apache_2.2.6-win32-x86

    - Apache支持各种模块,如mod_rewrite用于URL重写,mod_deflate用于内容压缩,mod_security用于安全防护等,可以根据需求安装和配置。 - Apache还可以与MySQL数据库和PHP一起,形成LAMP(Linux, Apache, MySQL, ...

Global site tag (gtag.js) - Google Analytics