apxs - apache扩展工具编译命令解析

本文介绍了如何使用apxs工具为Apache HTTP服务器编译和安装扩展模块,包括安装、配置和测试过程,适用于已具备DSO特性的平台。

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 ,用于编译和安装此模块。
-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 ,以增加连接器特有的选项。
-i
此选项表示需要执行安装操作,以安装一个或多个动态共享对象到服务器的 modules目录中。
-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
$ _

### 在 CentOS 上安装 Apache 扩展包 要在 CentOS 系统上安装 Apache扩展包,可以通过 `yum` 或者手动编译的方式完成。以下是详细的说明: #### 使用 Yum 安装 Apache 扩展包 CentOS 提供了一个丰富的软件仓库,其中包含了多个 Apache扩展模块。可以使用以下命令来查找并安装所需的扩展包。 通过运行以下命令,可以列出可用的 Apache 模块: ```bash yum search mod_ ``` 如果需要安装特定的模块(例如 `mod_ssl`),可以直接执行以下命令: ```bash sudo yum install mod_ssl -y ``` 这会自动下载并安装 SSL/TLS 支持的相关依赖项[^2]。 #### 手动编译安装 Apache 扩展包 对于某些不在官方仓库中的模块或者需要定制化功能的情况,可以选择手动编译安装。具体步骤如下: 1. **获取源码** 下载目标模块的源代码压缩包,并解压到指定目录。 2. **加载动态共享对象 (DSO)** 修改 `/etc/httpd/conf.modules.d/00-base.conf` 文件,确保启用了 DSO 支持: ```apache LoadModule socache_shmcb_module modules/mod_socache_shmcb.so ``` 3. **重新编译 Apache 并启用新模块** 假设已经安装了开发工具链以及必要的库文件,则可按照以下方式操作: ```bash ./configure --with-apxs=/usr/bin/apxs && make && sudo make install ``` 这里的 `--with-apxs` 参数指定了 apxs 工具的位置,用于生成适合当前环境使用的 `.so` 动态链接库文件[^1]。 4. **验证模块是否成功加载** 启动或重启 HTTPD 服务之后,可通过以下方法确认新增加的功能已正常工作: ```bash httpd -M | grep yourmodule ``` #### 调整配置以支持 .htaccess 和 PHP 解析 为了使网站能够识别 `.htaccess` 文件内的指令集并且正确处理 PHP 请求,在全局配置文件 `/etc/httpd/conf/httpd.conf` 中添加下列片段即可实现此目的: ```apache <FilesMatch "\.php$"> SetHandler application/x-httpd-php </FilesMatch> AllowOverride All ``` 最后记得再次刷新守护进程状态以便应用更改[^3]。 --- ### 总结 无论是采用自动化管理还是手工构建流程都可以顺利完成任务需求;前者简单快捷适用于大多数场景下的常规维护作业,而后者则给予管理员更大的灵活性去满足特殊场合的要求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值