描述: | 在启动或重启时将可执行代码和模块加载到服务器中 |
---|---|
状态: | 延期 |
模块标识符: | so_module |
源文件: | mod_so.c |
兼容性: | 这是Windows上的基本模块(始终包括在内) |
在选定的操作系统上,此模块可用于在运行时通过动态共享对象(DSO)机制将模块加载到Apache HTTP Server中,而无需重新编译。
在Unix上,加载的代码通常来自共享对象文件(通常带有.so
扩展名),在Windows上,可以是.so
或.dll
扩展名。
为一个主要版本的Apache HTTP Server构建的模块通常无法在另一个版本上使用。(例如1.3 vs. 2.0或2.0 vs. 2.2),一个主要版本与另一个主要版本之间通常会进行API更改,因此需要修改模块才能与新版本一起使用。
在Windows上,可加载文件的文件扩展名通常为.dll
,mod_whatever.so
与其他平台上一样,它们称为Apache httpd模块
。但是,您可能会遇到继续使用该.dll
约定的第三方模块(例如PHP)。
尽管mod_so
仍然使用ApacheModuleFoo.dll
名称加载模块
,但是首选新的命名约定;如果您要将可装载模块转换为2.0,请将该名称固定为该2.0约定。
在Unix和Windows版本之间,Apache httpd模块API保持不变。许多模块将在Windows上运行,而与Unix相比几乎没有变化,尽管其他模块依赖于Windows中不存在的Unix体系结构,并且将无法正常工作。
模块工作时,可以通过以下两种方法之一将其添加到服务器。与Unix一样,它可以编译到服务器中。因为Windows的Apache httpd没有
Configure
Unix的Apache httpd程序,所以必须将模块的源文件添加到ApacheCore项目文件中,并且必须将其符号添加到
os\win32\modules.c
文件中。
第二种方法是将模块编译为DLL,这是一个共享库,可以使用LoadModule
指令在运行时将其加载到服务器中。这些模块DLL可以在Windows安装的任何Apache httpd上分发和运行,而无需重新编译服务器。
要创建模块DLL,需要对模块的源文件进行一些小的更改:必须从DLL中导出模块记录(稍后将创建DLL;请参见下文)。为此,将AP_MODULE_DECLARE_DATA
(在Apache httpd头文件中定义)添加到模块的模块记录定义中。例如,如果您的模块具有:
module foo_module;
将以上内容替换为:
module AP_MODULE_DECLARE_DATA foo_module;
请注意,这只会在Windows上激活,因此如果需要,该模块可以继续与Unix一起使用,并且保持不变。另外,如果您熟悉.DEF
文件,则可以使用该方法导出模块记录。
现在,创建一个包含您的模块的DLL。您需要将其链接到编译libhttpd.dll共享库时创建的libhttpd.lib导出库。您可能还必须更改编译器设置,以确保正确找到Apache httpd头文件。您可以在服务器根目录的modules目录中找到此库。最好从树中获取一个现有的模块.dsp文件,以确保正确配置了构建环境,或者交替比较编译器和链接选项与.dsp。
这将创建模块的DLL版本。现在,只需将其放置在modules
服务器根目录下,并使用LoadModule
指令进行加载。