使用apxs工具给apache添加模块(无需重新编译安装apache)

转自:http://www.cublog.cn/u3/105800/showart_2099945.html

下面是使用apxs工具给apache添加模块

如添加的模块:

LoadModule cgi_module       libexec/mod_cgi.so

LoadModule cgid_module     libexec/mod_cgid.so

添加方法:

如要额外安装cgi,先找到mod_cgi.c及mod_cgid.c。一般在apache安装包目录下/httpd-2.2.11/modules/generators。

[root@local ~]#cd /software/httpd-2.2.11/modules/generators

[root@local generators]# /usr/local/apache/bin/apxs -i -a -c mod_cgi.c

/usr/local/apr/build-1/libtool --silent --mode=compile gcc -prefer-pic   -DLINUX=2 -D_REENTRANT -D_GNU_SOURCE -

D_LARGEFILE64_SOURCE -g -O2 -pthread -I/usr/local/apache/include  -I/usr/local/apr/include/apr-1   -I/usr/local/apr-

util/include/apr-1   -c -o mod_cgi.lo mod_cgi.c && touch mod_cgi.slo

/usr/local/apr/build-1/libtool --silent --mode=link gcc -o mod_cgi.la  -rpath /usr/local/apache/modules -module -

avoid-version    mod_cgi.lo

/usr/local/apache/build/instdso.sh SH_LIBTOOL='/usr/local/apr/build-1/libtool' mod_cgi.la /usr/local/apache/modules

/usr/local/apr/build-1/libtool --mode=install cp mod_cgi.la /usr/local/apache/modules/

cp .libs/mod_cgi.so /usr/local/apache/modules/mod_cgi.so

cp .libs/mod_cgi.lai /usr/local/apache/modules/mod_cgi.la

cp .libs/mod_cgi.a /usr/local/apache/modules/mod_cgi.a

chmod 644 /usr/local/apache/modules/mod_cgi.a

ranlib /usr/local/apache/modules/mod_cgi.a

PATH="$PATH:/sbin" ldconfig -n /usr/local/apache/modules

----------------------------------------------------------------------

Libraries have been installed in:

   /usr/local/apache/modules

If you ever happen to want to link against installed libraries

in a given directory, LIBDIR, you must either use libtool, and

specify the full pathname of the library, or use the `-LLIBDIR'

flag during linking and do at least one of the following:

   - add LIBDIR to the `LD_LIBRARY_PATH' environment variable

     during execution

   - add LIBDIR to the `LD_RUN_PATH' environment variable

     during linking

   - use the `-Wl,--rpath -Wl,LIBDIR' linker flag

   - have your system administrator add LIBDIR to `/etc/ld.so.conf'

See any operating system documentation about shared libraries for

more information, such as the ld(1) and ld.so(8) manual pages.

----------------------------------------------------------------------

chmod 755 /usr/local/apache/modules/mod_cgi.so

[activating module `cgi' in /usr/local/apache/conf/httpd.conf]   //这行表示,在httpd.conf中已经加载了cgi module

[root@local generators]# /usr/local/apache/bin/apxs -i -c -a mod_cgid.c

/usr/local/apr/build-1/libtool --silent --mode=compile gcc -prefer-pic   -DLINUX=2 -D_REENTRANT -D_GNU_SOURCE -

D_LARGEFILE64_SOURCE -g -O2 -pthread -I/usr/local/apache/include  -I/usr/local/apr/include/apr-1   -I/usr/local/apr-

util/include/apr-1   -c -o mod_cgid.lo mod_cgid.c && touch mod_cgid.slo

/usr/local/apr/build-1/libtool --silent --mode=link gcc -o mod_cgid.la  -rpath /usr/local/apache/modules -module -

avoid-version    mod_cgid.lo

/usr/local/apache/build/instdso.sh SH_LIBTOOL='/usr/local/apr/build-1/libtool' mod_cgid.la /usr/local/apache/modules

/usr/local/apr/build-1/libtool --mode=install cp mod_cgid.la /usr/local/apache/modules/

cp .libs/mod_cgid.so /usr/local/apache/modules/mod_cgid.so

cp .libs/mod_cgid.lai /usr/local/apache/modules/mod_cgid.la

cp .libs/mod_cgid.a /usr/local/apache/modules/mod_cgid.a

chmod 644 /usr/local/apache/modules/mod_cgid.a

ranlib /usr/local/apache/modules/mod_cgid.a

PATH="$PATH:/sbin" ldconfig -n /usr/local/apache/modules

----------------------------------------------------------------------

Libraries have been installed in:

   /usr/local/apache/modules

If you ever happen to want to link against installed libraries

in a given directory, LIBDIR, you must either use libtool, and

specify the full pathname of the library, or use the `-LLIBDIR'

flag during linking and do at least one of the following:

   - add LIBDIR to the `LD_LIBRARY_PATH' environment variable

     during execution

   - add LIBDIR to the `LD_RUN_PATH' environment variable

     during linking

   - use the `-Wl,--rpath -Wl,LIBDIR' linker flag

   - have your system administrator add LIBDIR to `/etc/ld.so.conf'

See any operating system documentation about shared libraries for

more information, such as the ld(1) and ld.so(8) manual pages.

----------------------------------------------------------------------

chmod 755 /usr/local/apache/modules/mod_cgid.so

[activating module `cgid' in /usr/local/apache/conf/httpd.conf]  //这行表示,在httpd.conf中已经加载了cgid module

apxs - Apache 扩展工具

apxs 是一个为Apache HTTP服务器编译和安装扩展模块的工具,用于编译一个或多个源程序或目标代码文件为动态共享对象,使之可以用由mod_so 提供的LoadModule 指令在运行时加载到Apache服务器中。

因此,要使用这个扩展机制,你的平台必须支持DSO特性,而且Apache httpd 必须内建了mod_so 模块。apxs 工具能自动探测是否具备这样的条件,你也可以自己用这个命令手动探测:

$ httpd -l

该命令的输出列表中应该有mod_so 模块。如果所有这些条件均已具备,则可以很容易地借助apxs 安装你自己的DSO模块以扩展Apache服务器的功能:

$ apxs -i -a -c mod_foo.c

gcc -fpic -DSHARED_MODULE -I/path/to/apache/include -c mod_foo.c

ld -Bshareable -o mod_foo.so mod_foo.o

cp mod_foo.so /path/to/apache/modules/mod_foo.so

chmod 755 /path/to/apache/modules/mod_foo.so

[activating module 'foo' in /path/to/apache/etc/httpd.conf]

$ apachectl restart

/path/to/apache/sbin/apachectl restart: httpd not running, trying to start

[Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module

/path/to/apache/sbin/apachectl restart: httpd started

$ _

其中的参数files 可以是任何C源程序文件(.c)、目标代码文件(.o)、甚至是一个库(.a)。apxs 工具会根据其后缀自动编译C源程序或者连接目标代码和库。但是,使用预编译的目标代码时,必须保证它们是地址独立代码(PIC),使之能被动态地加载。如果使用GCC编译,则应该使用 -fpic 参数;如果使用其他C编译器,则应该查阅其手册,为apxs 使用相应的编译参数。

有关Apache对DSO的支持的详细信息,可以阅读mod_so 文档,或者直接阅读src/modules/standard/mod_so.c 源程序。

语法

apxs -g [ -S name =value ] -n modname

apxs -q [ -S name =value ] query ...

apxs -c [ -S name =value ] [ -o dsofile ] [ -I incdir ] [ -D name =value ] [ -L libdir ] [ -l libname ] [ -Wc, compiler-flags ] [ -Wl, linker-flags ] files ...

apxs -i [ -S name =value ] [ -n modname ] [ -a ] [ -A ] dso-file ...

apxs -e [ -S name =value ] [ -n modname ] [ -a ] [ -A ] dso-file ...

选项

一般选项

-n modname

它明确设置了 -i (安装)和 -g (模板生成)选项的模块名称。对 -g 选项,它是必须的;对 -i 选项,apxs 工具会根据源代码判断,或(在失败的情况下)按文件名推测出这个模块的名称。

查询选项

-q

查询某种apxs 设置的信息。该选项的query 参数可以是下列一个或多个字符串:CC , CFLAGS , CFLAGS_SHLIB , INCLUDEDIR , LD_SHLIB , LDFLAGS_SHLIB , LIBEXECDIR , LIBS_SHLIB , SBINDIR , SYSCONFDIR , TARGET 。

这个参数用于手动查询某些设置。比如,要手动处理Apache的C头文件,可以在Makefile中使用:

INC=-I`apxs -q INCLUDEDIR`

配置选项

-S name =value

此选项可以改变apxs的上述设置。

模板生成选项

-g

此选项生成一个名为name 的子目录(见选项 -n )和其中的两个文件:一个是名为mod_name .c 的样板模块源程序,可以用来建立你自己的模块,或是学习使用apxs机制的良好开端;另一个则是对应的Makefile ,用于编译和安装此模块。

DSO编译选项

-c

此选项表示需要执行编译操作。它首先会编译C源程序(.c)files 为对应的目标代码文件(.o),然后连接这些目标代码和files 中其余的目标代码文件(.o和.a),以生成动态共享对象dsofile 。如果没有指定 -o 选项,则此输出文件名由files 中的第一个文件名推测得到,也就是默认为mod_name .so 。

-o dsofile

明确指定所建立的动态共享对象的文件名,它不能从files 文件列表中推测得到。如果没有明确指定,则其文件名将为mod_unknown.so 。

-D name =value

此选项直接传递到给编译命令,用于增加自定义的编译变量。

-I incdir

此选项直接传递到给编译命令,用于增加自定义的包含目录。

-L libdir

此选项直接传递到给连接命令,用于增加自定义的库文件目录。

-l libname

此选项直接传递到给连接命令,用于增加自定义的库文件。

-Wc,compiler-flags

此选项用于向编译命令 libtool --mode=compile 中附加compiler-flags ,以增加编译器特有的选项。

-Wl,linker-flags

此选项用于向连接命令 libtool --mode=link 中附加linker-flags ,以增加连接器特有的选项。

DSO的安装和配置选项

-i

此选项表示需要执行安装操作,以安装一个或多个动态共享对象到服务器的modules 目录中。

-a

此选项自动增加一个LoadModule 行到httpd.conf 文件中,以激活此模块,或者,如果此行已经存在,则启用之。

-A

与 -a 选项类似,但是它增加的LoadModule 命令有一个井号前缀(# ),即此模块已经准备就绪但尚未启用。

-e

表示需要执行编辑操作,它可以与 -a 和 -A 选项配合使用,与 -i 操作类似,修改Apache的httpd.conf 文件,但是并不安装此模块。

使用apxs工具给apache添加模块(无需重新编译安装apache)

举例

假设有一个扩展Apache功能的模块mod_foo.c ,使用下列命令,可以将C源程序编译为共享模块,以在运行时加载到Apache服务器中:

$ apxs -c mod_foo.c

/path/to/libtool --mode=compile gcc ... -c mod_foo.c

/path/to/libtool --mode=link gcc ... -o mod_foo.la mod_foo.slo

$ _

然后,必须修改Apache的配置,以确保有一个LoadModule 指令来加载此共享对象。为了简化这一步骤,apxs 可以自动进行该操作,以安装此共享对象到"modules"目录,并更新httpd.conf 文件,命令如下:

$ apxs -i -a mod_foo.la

/path/to/instdso.sh mod_foo.la /path/to/apache/modules

/path/to/libtool --mode=install cp mod_foo.la /path/to/apache/modules ... chmod 755 /path/to/apache/modules/mod_foo.so

[activating module 'foo' in /path/to/apache/conf/httpd.conf]

$ _

如果配置文件中尚不存在,会增加下列的行:

LoadModule foo_module modules/mod_foo.so

如果你希望默认禁用此模块,可以使用 -A 选项,即:

$ apxs -i -A mod_foo.c

要快速测试apxs机制,可以建立一个Apache模块样板及其对应的Makefile :

$ apxs -g -n foo

Creating [DIR] foo

Creating [FILE] foo/Makefile

Creating [FILE] foo/modules.mk

Creating [FILE] foo/mod_foo.c

Creating [FILE] foo/.deps

$ _

然后,立即可以编译此样板模块为共享对象并加载到Apache服务器中:

$ cd foo

$ make all reload

apxs -c mod_foo.c

/path/to/libtool --mode=compile gcc ... -c mod_foo.c

/path/to/libtool --mode=link gcc ... -o mod_foo.la mod_foo.slo

apxs -i -a -n "foo" mod_foo.la

/path/to/instdso.sh mod_foo.la /path/to/apache/modules

/path/to/libtool --mode=install cp mod_foo.la /path/to/apache/modules ... chmod 755 /path/to/apache/modules/mod_foo.so

[activating module 'foo' in /path/to/apache/conf/httpd.conf]

apachectl restart

/path/to/apache/sbin/apachectl restart: httpd not running, trying to start

[Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module

/path/to/apache/sbin/apachectl restart: httpd started

相关推荐