自定义apache2模块将不会加载错误消息“无法找到API模块结构”

时间:2013-02-15 10:19:43

标签: c++ linux module apache2 apxs2

我是一名Windows开发人员,但现在尝试使用apxs2工具在linux上构建一个非常简单的apache2模块,如本文所述:[http://www.codeproject.com/Articles/491909/Apache-2-x - 模块的多功能CPLUSPLUS-部分-1] [1]

模块正在成功构建但由于某种原因无法加载。 Apache在重启时发出错误:“无法找到API模块结构”。

现在有些细节。

首先尝试使用以下命令构建模块

 apxs2 -i -a  -c mod_pixmongo.cpp

它失败并显示“无法确定引导符号名称”的错误消息,并且必须“使用选项'-n'指定一个”

当提供选项-n时,模块正在成功构建:

apxs2 -i -a -n pixmongo  -c mod_pixmongo.cpp

但尝试重启apache问题后出现错误:

apache2:/etc/apache2/apache2.conf第203行的语法错误:/etc/apache2/mods-enabled/pixmongo.load的第1行语法错误:找不到API模块结构`pixmongo_module'文件/usr/lib/apache2/modules/mod_pixmongo.so:/usr/lib/apache2/modules/mod_pixmongo.so:undefined symbol:pixmongo_module 动作'configtest'失败。

我对linux上的共享库知之甚少,但建议必须以某种方式导出模块结构。我的理解中的以下命令应该显示导出的符号:

nm -D /usr/lib/apache2/modules/mod_pixmongo.so

在我的案例中,它显示如下:

w _Jv_RegisterClasses
0000000000200778 A __bss_start
             w __cxa_finalize
             w __gmon_start__
0000000000200778 A _edata
0000000000200788 A _end
0000000000000558 T _fini
0000000000000418 T _init

所以结构“模块”真的不存在,我发现它很奇怪。要比较:任何其他预安装的模块都会导出该结构。例如:

nm -D /usr/lib/apache2/modules/mod_info.so

w _Jv_RegisterClasses
00000000002052b0 A __bss_start
             w __cxa_finalize
             w __gmon_start__
00000000002052b0 A _edata
00000000002052c0 A _end
0000000000002b48 T _fini
0000000000001708 T _init
************** the long list here *********
00000002050e0 D info_module
             U strcasecmp
             U strcmp

所以问题是我做错了什么。 很感谢任何形式的帮助。 示例模块的源代码如下:

头文件mod_pixmongo.hpp:

#ifndef MOD_PIXMONGO_HPP
#define MOD_PIXMONGO_HPP

#ifdef __cplusplus
#define EXTERN_C_BLOCK_BEGIN    extern "C" {
#define EXTERN_C_BLOCK_END      }
#define EXTERN_C_FUNC           extern "C"
#else
#define EXTERN_C_BLOCK_BEGIN
#define EXTERN_C_BLOCK_END
#define EXTERN_C_FUNC
#endif

#include <httpd.h>
#include <http_protocol.h>
#include <http_config.h>

#endif  /* MOD_PIXMONGO_HPP */

源文件mod_pixmongo.cpp:

#include "mod_pixmongo.hpp"

EXTERN_C_FUNC
int pixmongo_handler( request_rec* inpRequest )
{
    int nReturnVal = DECLINED;

if ( inpRequest->handler != NULL && strcmp( inpRequest->handler, "pixmongo" ) == 0 )
{
    ap_rputs( "Hello World from PIXMONGO", inpRequest );
    nReturnVal = OK;
}

return nReturnVal;
}

EXTERN_C_FUNC
void pixmongo_hooks( apr_pool_t* inpPool )
{
ap_hook_handler( pixmongo_handler, NULL, NULL, APR_HOOK_MIDDLE );
}

EXTERN_C_BLOCK_BEGIN
module AP_MODULE_DECLARE_DATA pixmongo_module =
{
  STANDARD20_MODULE_STUFF,
NULL,
NULL,
NULL,
NULL,
NULL,
pixmongo_hooks
};
EXTERN_C_BLOCK_END

1 个答案:

答案 0 :(得分:2)

我意识到自己的错误。实用程序apxs不能构建C ++模块但只能构建C(后者对我来说很好)。在上面提到的codeproject文章中,apxs实用程序仅用于部署已编译的模块,但不用于编译它。