ошибка: «res_ninit» не был объявлен в этой области; вы имели в виду «res_init»?

#c #linux #linux-kernel #alpine

Вопрос:

Я пытаюсь установить приложение из его исходного кода в alpine , в котором говорится , что его нет res_ninit , res_nsearch res_nclose но здесь мы видим, что оно существует в заголовках Linux, и я уже установил apk add linux-headers , как я могу решить эту проблему?

 make install
Consolidate compiler generated dependencies of target save_linker_opts
[  2%] Built target save_linker_opts
[  2%] Built target build_protobuf
Consolidate compiler generated dependencies of target cdk_foundation
[  3%] Building CXX object cdk/foundation/CMakeFiles/cdk_foundation.dir/socket_detail.cc.o
/dep/mysql-connector-cpp/cdk/foundation/socket_detail.cc: In function 'std::forward_list<cdk::foundation::connection::detail::Srv_host_detail> cdk::foundation::connection::detail::srv_list(const stringamp;)':
/dep/mysql-connector-cpp/cdk/foundation/socket_detail.cc:1097:3: error: 'res_ninit' was not declared in this scope; did you mean 'res_init'?
 1097 |   res_ninit(amp;state);
      |   ^~~~~~~~~
      |   res_init
/dep/mysql-connector-cpp/cdk/foundation/socket_detail.cc:1107:13: error: 'res_nsearch' was not declared in this scope; did you mean 'res_search'?
 1107 |   int res = res_nsearch(amp;state, hostname.c_str(), ns_c_in, ns_t_srv, query_buffer, sizeof (query_buffer) );
      |             ^~~~~~~~~~~
      |             res_search
/dep/mysql-connector-cpp/cdk/foundation/socket_detail.cc:1143:3: error: 'res_nclose' was not declared in this scope
 1143 |   res_nclose(amp;state);
      |   ^~~~~~~~~~
make[2]: *** [cdk/foundation/CMakeFiles/cdk_foundation.dir/build.make:146: cdk/foundation/CMakeFiles/cdk_foundation.dir/socket_detail.cc.o] Error 1
make[1]: *** [CMakeFiles/Makefile2:1061: cdk/foundation/CMakeFiles/cdk_foundation.dir/all] Error 2
 

Обновление: Я нашел файл заголовка /usr/include/resolv.h , и мы видим, что этой функции не существует, поэтому вопрос в том, как я могу настроить заголовок Linux, такой как ubuntu, который может работать в alpine?

 #ifndef _RESOLV_H
#define _RESOLV_H

#include <stdint.h>
#include <arpa/nameser.h>
#include <netinet/in.h>

#ifdef __cplusplus
extern "C" {
#endif

#define MAXNS           3
#define MAXDFLSRCH      3
#define MAXDNSRCH       6
#define LOCALDOMAINPARTS    2

#define RES_TIMEOUT     5
#define MAXRESOLVSORT       10
#define RES_MAXNDOTS        15
#define RES_MAXRETRANS      30
#define RES_MAXRETRY        5
#define RES_DFLRETRY        2
#define RES_MAXTIME     65535

/* unused; purely for broken apps */
typedef struct __res_state {
    int retrans;
    int retry;
    unsigned long options;
    int nscount;
    struct sockaddr_in nsaddr_list[MAXNS];
# define nsaddr nsaddr_list[0]
    unsigned short id;
    char *dnsrch[MAXDNSRCH 1];
    char defdname[256];
    unsigned long pfcode;
    unsigned ndots:4;
    unsigned nsort:4;
    unsigned ipv6_unavail:1;
    unsigned unused:23;
    struct {
        struct in_addr addr;
        uint32_t mask;
    } sort_list[MAXRESOLVSORT];
    void *qhook;
    void *rhook;
    int res_h_errno;
    int _vcsock;
    unsigned _flags;
    union {
        char pad[52];
        struct {
            uint16_t        nscount;
            uint16_t        nsmap[MAXNS];
            int         nssocks[MAXNS];
            uint16_t        nscount6;
            uint16_t        nsinit;
            struct sockaddr_in6 *nsaddrs[MAXNS];
            unsigned int        _initstamp[2];
        } _ext;
    } _u;
} *res_state;

#define __RES   19960801

#ifndef _PATH_RESCONF
#define _PATH_RESCONF        "/etc/resolv.conf"
#endif

struct res_sym {
    int number;
    char *name;
    char *humanname;
};

#define RES_F_VC    0x00000001
#define RES_F_CONN  0x00000002
#define RES_F_EDNS0ERR  0x00000004

#define RES_EXHAUSTIVE  0x00000001

#define RES_INIT    0x00000001
#define RES_DEBUG   0x00000002
#define RES_AAONLY  0x00000004
#define RES_USEVC   0x00000008
#define RES_PRIMARY 0x00000010
#define RES_IGNTC   0x00000020
#define RES_RECURSE 0x00000040
#define RES_DEFNAMES    0x00000080
#define RES_STAYOPEN    0x00000100
#define RES_DNSRCH  0x00000200
#define RES_INSECURE1   0x00000400
#define RES_INSECURE2   0x00000800
#define RES_NOALIASES   0x00001000
#define RES_USE_INET6   0x00002000
#define RES_ROTATE  0x00004000
#define RES_NOCHECKNAME 0x00008000
#define RES_KEEPTSIG    0x00010000
#define RES_BLAST   0x00020000
#define RES_USEBSTRING  0x00040000
#define RES_NOIP6DOTINT 0x00080000
#define RES_USE_EDNS0   0x00100000
#define RES_SNGLKUP 0x00200000
#define RES_SNGLKUPREOP 0x00400000
#define RES_USE_DNSSEC  0x00800000

#define RES_DEFAULT (RES_RECURSE|RES_DEFNAMES|RES_DNSRCH|RES_NOIP6DOTINT)

#define RES_PRF_STATS   0x00000001
#define RES_PRF_UPDATE  0x00000002
#define RES_PRF_CLASS   0x00000004
#define RES_PRF_CMD 0x00000008
#define RES_PRF_QUES    0x00000010
#define RES_PRF_ANS 0x00000020
#define RES_PRF_AUTH    0x00000040
#define RES_PRF_ADD 0x00000080
#define RES_PRF_HEAD1   0x00000100
#define RES_PRF_HEAD2   0x00000200
#define RES_PRF_TTLID   0x00000400
#define RES_PRF_HEADX   0x00000800
#define RES_PRF_QUERY   0x00001000
#define RES_PRF_REPLY   0x00002000
#define RES_PRF_INIT    0x00004000

struct __res_state *__res_state(void);
#define _res (*__res_state())

int res_init(void);
int res_query(const char *, int, int, unsigned char *, int);
int res_querydomain(const char *, const char *, int, int, unsigned char *, int);
int res_search(const char *, int, int, unsigned char *, int);
int res_mkquery(int, const char *, int, int, const unsigned char *, int, const unsigned char*, unsigned char *, int);
int res_send(const unsigned char *, int, unsigned char *, int);
int dn_comp(const char *, unsigned char *, int, unsigned char **, unsigned char **);
int dn_expand(const unsigned char *, const unsigned char *, const unsigned char *, char *, int);
int dn_skipname(const unsigned char *, const unsigned char *);

#ifdef __cplusplus
}
#endif

#endif
 

Комментарии:

1. Неужели в верхней части файла нет комментариев?? how can I set up Linux header like ubuntu that can work in the alpine? Вы хотите «настроить» файл заголовка? Что вы имеете в виду под этим? Файлы заголовков существуют, они не являются «настройками».

2. @KamilCuk Я просто скопировал/вставил весь файл. мы устанавливаем linux-headers , чтобы получить доступ к определенным заголовкам Linux, поэтому по умолчанию они не существуют. очевидно <resolv.h> , заголовки Alpine не совпадают с официальным заголовком Linux. Я предполагаю, что мы могли бы избавиться от недостающих функций, переопределив файл, что означает, что нам нужно установить правильный пакет в alpine, если таковой имеется!

3. файлы заголовков предназначены только для компиляции. Для запуска программы вы также должны установить соответствующую библиотеку. Вот почему вы не можете просто скопировать заголовок Ubuntu.

4. @старк, может быть, я не мог объяснить, что было у меня на уме, правильными словами… Я не новичок. так что нет необходимости в разговорах с новичками 😉

5. Спасибо, что объяснили это. Я испытываю огромное облегчение.

Ответ №1:

в заголовках Linux

Linux-это, как правило,/разговорное название всех операционных систем unix с ядром Linux, но, в частности, Linux относится к самому ядру Linux. Заголовки разрешения не являются частью ядра Linux. linux-headers установите заголовки, необходимые для компиляции модулей ядра Linux. Это никак не связано.

Упомянутые заголовки распознавателей реализованы в библиотеке GNU C glibc. В дистрибутиве Alpine используется реализация musl стандартной библиотеки C, а не glibc.

как я могу решить эту проблему?

Один из:

  • вы можете реализовать res_ninit и соответствующую функцию, зависящую от musl, и использовать эту реализацию при компиляции приложения
  • исправьте mysql-соединитель самостоятельно, чтобы его можно было компилировать с помощью musl
  • скомпилируйте/установите glibc в свою систему и скомпилируйте mysql-коннектор против нее
  • не используйте alpine для программ, требующих glibc, и используйте только дистрибутив Linux, совместимый с glibc
  • уведомите разработчиков mysql-коннектора об этой проблеме и окажите им финансовую поддержку, чтобы они исправили проблему

Комментарии:

1. Я предпочитаю #3, я пытался установить apk add libc6-compat , но содержимое файла не изменилось.

2. Что ж, я бы предложил № 4. Весь смысл alpine в том, что он использует musl — при установке glibc вам, возможно, лучше использовать что-то новое с glibc, нет смысла. the content of the file didn't change. Эта часть compile mysql-connector against it также важна. Я понятия не имею, как настроить приложение, я также не знаю, libc6-compat содержит ли оно все необходимые реализации, я предполагаю, что, скорее всего, это не так.

3. Да, вы правы, мне нужно вернуться и использовать образ ubuntu для базы, я хотел использовать alpine, потому что он был легче, но я думаю, что это больше не вариант :/