Сборка Zabbix агента на Windows
Oбзор
Этот раздел демонстрирует как можно собрать бинарные файлы Zabbix агента на Windows из исходного кода с / без поддержки TLS.
Компиляция OpenSSL
Следующие шаги помогут вам скомпилировать OpenSSL из исходного кода на MS Windows 10 (64-bit).
- Для компиляции OpenSSL на машине с Windows потребуются:
- Компилятор C языка (например, VS 2017 RC),
- NASM (https://www.nasm.us/),
- Perl (например, Strawberry Perl с http://strawberryperl.com/),
- Perl модуль Text::Template (cpan Text::Template).
- Загрузите исходный код OpenSSL с https://www.openssl.org/. В данном примере используется OpenSSL 1.1.1.
- Разархивируйте исходный код OpenSSL, например, в E:\openssl-1.1.1.
- Откройте окно командной строки, например, x64 Native Tools Command Prompt для VS 2017 RC.
- Перейдите в директорию с исходным кодом OpenSSL, например, E:\openssl-1.1.1.
- Удостоверьтесь, что NASM доступен:
e:\openssl-1.1.1> nasm --version NASM version 2.13.01 compiled on May 1 2017
- Удостоверьтесь, что NASM доступен:
- Сконфигурируйте OpenSSL, например:
e:\openssl-1.1.1> perl E:\openssl-1.1.1\Configure VC-WIN64A no-shared no-capieng no-srp no-gost no-dgram no-dtls1-method no-dtls1_2-method --api=1.1.0 --prefix=C:\OpenSSL-Win64-111-static --openssldir=C:\OpenSSL-Win64-111-static- Обратите внимание на опцию 'no-shared': при использовании 'no-shared' статические библиотеки OpenSSL libcrypto.lib и libssl.lib будут 'самодостаточными' и в результате бинарные файлы Zabbix будут включать в себя OpenSSL, не потребуется внешних DLL от OpenSSL. Преимущество: бинарные файлы Zabbix можно будет копировать на другие Windows машины без необходимости наличия библиотек OpenSSL. Недостаток: когда будет выпущена новая версия OpenSSL с исправлением ошибок, Zabbix агента будет необходимо скомпилировать и установить заново.
- Если 'no-shared' не используется, тогда статические библиотеки libcrypto.lib и libssl.lib будут использоваться во время выполнения DLL OpenSSL. Преимущество: когда будет выпущена новая версия OpenSSL с исправлением ошибок, возможно вы сможете обновить только OpenSSL DLL, без необходимости повторной компиляции Zabbix агента. Недостаток: при копировании Zabbix агента на другую машину необходимо также копировать OpenSSL DLL.
- Скомпилируйте OpenSSL, проведите тесты, установите:
e:\openssl-1.1.1> nmake e:\openssl-1.1.1> nmake test ... All tests successful. Files=152, Tests=1152, 501 wallclock secs ( 0.67 usr + 0.61 sys = 1.28 CPU) Result: PASS e:\openssl-1.1.1> nmake install_sw'install_sw' установит только компоненты приложения (такие как - библиотеки, файлы заголовков, но без документации). Если вы хотите установить всё, используйте "nmake install".
Компиляция PCRE
- Загрузите библиотеку PCRE или PCRE2 (поддерживается начиная с Zabbix 6.0) (https://pcre.org/).
- Извлеките архив в директорию E:\pcre2-10.39
- Установите CMake с https://cmake.org/download/, в процессе установки выберите и убедитесь, что cmake\bin существует в вашей директории (протестировано на версии 3.9.4).
- Создайте новую пустую директорию для сборки, предпочтительно создать поддиректорию в директории с исходным кодом. Например, E:\pcre2-10.39\build.
- Откройте окно командной строки, например, x64 Native Tools Command Prompt for VS 2017 и из этой командной оболочки выполните cmake-gui. Не пытайтесь запустить Cmake из меню Пуск Windows, так как такой запуск может привести к ошибкам.
- Ввведите E:\pcre2-10.39 и E:\pcre2-10.39\build для директорий с исходным кодом и для готовой сборки, соответственно.
- Нажмите на кнопку "Configure".
- При выборе генератора для этого проекта выберите "NMake Makefiles".
- Создайте новую, пустую директорию для установки. Например, E:\pcre2-10.39-install.
- Затем GUI перечислит несколько опций конфигурирования. Убедитесь, что следующие опции выбраны:
- PCRE_SUPPORT_UNICODE_PROPERTIES ON
- PCRE_SUPPORT_UTF ON
- CMAKE_INSTALL_PREFIX E:\pcre2-10.39-install
- Нажмите "Configure" снова. Соседняя кнопка "Generate" теперь должна быть активной.
- Нажмите "Generate".
- В случае возникновения ошибок рекомендуется удалить кэш CMake перед попыткой повторить процесс сборки CMake. В CMake GUI кэш можно удалить, выбрав "File > Delete Cache".
- Директория для готовой сборки теперь должна содержать пригодную систему для сборки - Makefile.
- Откройте окно командной строки, например, x64 Native Tools Command Prompt for VS 2017 и перейдите к вышеупомянутому Makefile.
- Выполните команду NMake:
E:\pcre2-10.39\build> nmake install
Компиляция Zabbix
Следующие шаги помогут вам скомпилировать Zabbix из исходного кода на MS Windows 10 (64-bit). Четвертый шаг - единственное существенное отличие при компиляции Zabbix с / без поддержки TLS.
- На Linux машине выгрузите исходный код с git:
$ git clone https://git.zabbix.com/scm/zbx/zabbix.git $ cd zabbix $ ./bootstrap.sh $ ./configure --enable-agent --enable-ipv6 --prefix=`pwd` $ make dbschema $ make dist - Скопируйте и распакуйте архив, например zabbix-4.4.0.tar.gz, на Windows машине.
- Давайте предположим, что исходный код располагается в e:\zabbix-4.4.0. Откройте окно командной строки, например, x64 Native Tools Command Prompt for VS 2017 RC. Перейдите в E:\zabbix-4.4.0\build\win32\project.
- Скомпилируйте zabbix_get, zabbix_sender и zabbix_agent.
- без поддержки TLS:
E:\zabbix-4.4.0\build\win32\project> nmake /K PCREINCDIR=E:\pcre2-10.39-install\include PCRELIBDIR=E:\pcre2-10.39-install\lib - с поддержкой TLS:
E:\zabbix-4.4.0\build\win32\project> nmake /K -f Makefile_get TLS=openssl TLSINCDIR=C:\OpenSSL-Win64-111-static\include TLSLIBDIR=C:\OpenSSL-Win64-111-static\lib PCREINCDIR=E:\pcre2-10.39-install\include PCRELIBDIR=E:\pcre2-10.39-install\lib E:\zabbix-4.4.0\build\win32\project> nmake /K -f Makefile_sender TLS=openssl TLSINCDIR="C:\OpenSSL-Win64-111-static\include TLSLIBDIR="C:\OpenSSL-Win64-111-static\lib" PCREINCDIR=E:\pcre2-10.39-install\include PCRELIBDIR=E:\pcre2-10.39-install\lib E:\zabbix-4.4.0\build\win32\project> nmake /K -f Makefile_agent TLS=openssl TLSINCDIR=C:\OpenSSL-Win64-111-static\include TLSLIBDIR=C:\OpenSSL-Win64-111-static\lib PCREINCDIR=E:\pcre2-10.39-install\include PCRELIBDIR=E:\pcre2-10.39-install\lib
- без поддержки TLS:
- Новые бинарные файлы будут располагаться в e:\zabbix-4.4.0\bin\win64. Так как OpenSSL скомпилирован с 'no-shared' опцией, бинарные файлы Zabbix внутри себя будут содержать OpenSSL и их можно будет скопировать на другие машины, на которых OpenSSL отсутствует.
Компиляция Zabbix с LibreSSL
Процесс схож с компиляцией с поддержкой OpenSSL, но Вам будет необходимо
внести небольшие изменения в файлы, расположенные в директории build\win32\project:
* В ''Makefile_tls'' удалите ''/DHAVE_OPENSSL_WITH_PSK''. например, найдите <code>
CFLAGS = $(CFLAGS) /DHAVE_OPENSSL
/DHAVE_OPENSSL_WITH_PSK</code>и замените на
CFLAGS = $(CFLAGS) /DHAVE_OPENSSL
* В ''Makefile_common.inc'' добавьте ''/NODEFAULTLIB:LIBCMT'' например, найдите <code>
/MANIFESTUAC:"level='asInvoker' uiAccess='false'" /DYNAMICBASE:NO
/PDB:$(TARGETDIR)\$(TARGETNAME).pdb</code>и замените на
/MANIFESTUAC:"level='asInvoker' uiAccess='false'" /DYNAMICBASE:NO /PDB:$(TARGETDIR)\$(TARGETNAME).pdb /NODEFAULTLIB:LIBCMT