Пользовательский модуль apache2 не будет загружаться с сообщением об ошибке "Не удается найти структуру модуля API"

Я разработчик для Windows, но сейчас пытаюсь собрать очень простой модуль apache2 в Linux с помощью инструмента apxs2, как описано в этой статье: [http://www.codeproject.com/Articles/491909/Apache-2-x-Modules- В-Cplusplus-Part-1][1]

Модуль успешно собирается, но не может быть загружен по какой-либо причине. Apache выдает следующую ошибку при перезапуске: "Не удается найти структуру модуля API".

Теперь некоторые подробности.

Прежде всего, пытаясь собрать модуль с помощью следующей команды

 apxs2 -i -a  -c mod_pixmongo.cpp

Сбой с сообщением об ошибке, что он "не может определить имя символа начальной загрузки" и что необходимо "указать его с параметром`-n'"

Когда указана опция -n, модуль успешно собирается:

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

Но попытка перезапустить apache приводит к следующей ошибке:

apache2: синтаксическая ошибка в строке 203 файла /etc/apache2/apache2.conf: синтаксическая ошибка в строке 1 файла /etc/apache2/mods-enabled/pixmongo.load: не удается найти структуру модуля API `pixmongo_module'в файле /usr/lib/apache2/modules/mod_pixmongo.so: /usr/lib/apache2/modules/mod_pixmongo.so: неопределенный символ: 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 ответ

Я понял свою ошибку. Утилита apxs не способна создавать модули C++, а только C (последний работал нормально для меня). В вышеупомянутой статье codeproject утилита apxs используется только для развертывания уже скомпилированного модуля, но не для его компиляции.

Другие вопросы по тегам