©
Ce document utiliseManuel du site Web PHP chinoisLibérer
apxs
是一个为Apache HTTP服务器编译和安装扩展模块的工具,用于编译一个或多个源程序或目标代码文件为动态共享对象,使之可以用由mod_so
提供的LoadModule
指令在运行时加载到Apache服务器中。
因此,要使用这个扩展机制,你的平台必须支持DSO特性,而且Apachehttpd
必须内建了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[ -Sname=value] -nmodname
apxs-q[ -Sname=value]query...
apxs-c[ -Sname=value] [ -odsofile] [ -Iincdir] [ -Dname=value] [ -Llibdir] [ -llibname] [ -Wc,compiler-flags] [ -Wl,linker-flags]files...
apxs-i[ -Sname=value] [ -nmodname] [ -a] [ -A]dso-file...
apxs-e[ -Sname=value] [ -nmodname] [ -a] [ -A]dso-file...
-nmodname
-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`
-Sname=value
-g
-n
)和其中的两个文件:一个是名为
mod_name.c
的样板模块源程序,可以用来建立你自己的模块,或是学习使用apxs机制的良好开端;另一个则是对应的
Makefile
,用于编译和安装此模块。
-c
-o
选项,则此输出文件名由
files中的第一个文件名推测得到,也就是默认为
mod_name.so
。
-odsofile
mod_unknown.so
。
-Dname=value
-Iincdir
-Llibdir
-llibname
-Wc,compiler-flags
libtool --mode=compile
中附加
compiler-flags,以增加编译器特有的选项。
-Wl,linker-flags
libtool --mode=link
中附加
linker-flags,以增加连接器特有的选项。
-i
-a
LoadModule
行到
httpd.conf
文件中,以激活此模块,或者,如果此行已经存在,则启用之。
-A
-a
选项类似,但是它增加的
LoadModule
命令有一个井号前缀(
#
),即此模块已经准备就绪但尚未启用。
-e
-a
和
-A
选项配合使用,与
-i
操作类似,修改Apache的
httpd.conf
文件,但是并不安装此模块。
假设有一个扩展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
$ _