Esta página demonstra como compilar o agent do Zabbix a partir do código-fonte no Windows 10 (64 bits).
Essas instruções se aplicam às versões do Windows que suportam o Visual Studio 2022.
A compilação do agent do Zabbix requer:
Você pode compilar o agent do Zabbix usando um dos seguintes métodos:
Dependendo das suas necessidades de monitoramento, bibliotecas adicionais podem ser necessárias. Para mais informações, consulte Requisitos.
Antes de iniciar o processo de compilação, por favor, tenha em mente:
C:\Zabbix para todos os arquivos-fonte e pastas de compilação. No entanto, os componentes compilados devem ser instalados em C:\Program Files\Zabbix\x64.Esta seção contém instruções para compilar o agent Zabbix com o vcpkg, um gerenciador de pacotes que simplifica o gerenciamento de dependências e a integração com projetos C++.
1. Baixe e instale o Build Tools for Visual Studio 2022. Durante a instalação, certifique-se de selecionar a carga de trabalho Desenvolvimento de área de trabalho com C++, que inclui as ferramentas necessárias para compilar o agent com o vcpkg:
2. Inicialize o vcpkg e instale as dependências necessárias para compilar o agent Zabbix (observe que isso pode levar algum tempo):
cd C:\Zabbix
vcpkg new --application
vcpkg add port pcre2
vcpkg add port openssl
vcpkg install --triplet x64-windows-static --x-install-root="C:\Program Files\Zabbix\x64"3. Baixe o arquivo de origem do Zabbix e extraia-o para C:\Zabbix\zabbix-8.0.0.
4. Navegue até o diretório de compilação do Zabbix (C:\Zabbix\zabbix-8.0.0\build\win32\project) e crie o seguinte script build.bat; certifique-se de especificar corretamente os diretórios onde o OpenSSL e o PCRE2 estão instalados:
:: Defina o caminho de instalação do vcpkg:
set vcpkg=C:\Program Files\Zabbix\x64\x64-windows-static
:: Execute o processo de compilação:
nmake -f Makefile CPU=AMD64 ^
PCRE2INCDIR="%vcpkg%\include" ^
PCRE2LIBDIR="%vcpkg%\lib" ^
TLS=openssl ^
TLSINCDIR="%vcpkg%\include" ^
TLSLIBDIR="%vcpkg%\lib" ^
LIBS="$(LIBS) Crypt32.lib" ^
all5. Compile o agent Zabbix executando o script:
Após a compilação, os binários dos componentes do Zabbix estarão localizados em C:\Zabbix\zabbix-8.0.0\bin\win64. O arquivo de configuração do agent Zabbix está localizado em C:\Zabbix\zabbix-8.0.0\conf.
Para executar o agent, copie zabbix_agent.exe e seu arquivo de configuração para uma pasta dedicada (por exemplo, C:\Zabbix\agent) e, em seguida, execute o agent:
mkdir C:\Zabbix\agent
copy C:\Zabbix\zabbix-8.0.0\bin\win64\zabbix_agent.exe C:\Zabbix\agent\
copy C:\Zabbix\zabbix-8.0.0\conf\zabbix_agent.win.conf C:\Zabbix\agent\
C:\Zabbix\agent\zabbix_agent.exe -c C:\Zabbix\agent\zabbix_agent.win.confEste método de compilação do agent do Zabbix é adequado para usuários que precisam de controle total sobre o ambiente de compilação ou estão em um ambiente restrito onde usar o vcpkg não é possível.
Esta seção contém instruções para compilar o agent do Zabbix manualmente, o que inclui instalar as ferramentas de compilação e dependências necessárias (Perl, OpenSSL, PCRE2) e, em seguida, compilar o agent.
1. Baixe e instale o Build Tools for Visual Studio 2022. Durante a instalação, certifique-se de selecionar a carga de trabalho Desenvolvimento de área de trabalho com C++, que inclui as ferramentas necessárias para compilar o agent manualmente:
Para compilar o agent Zabbix sem suporte a TLS, prossiga para a seção Instalando o PCRE2.
1. Baixe e instale o Strawberry Perl (disponível como um instalador MSI). Durante a instalação, certifique-se de especificar C:\Zabbix\Strawberry como a pasta de instalação.
2. Instale o módulo Perl Text::Template:
3. Verifique se o Netwide Assembler (NASM; necessário para compilar o OpenSSL) foi compilado durante a instalação do Strawberry Perl:
Se o NASM não estiver compilado, instale-o manualmente. Para mais informações, consulte a documentação do NASM.
4. Baixe o arquivo de origem do OpenSSL e extraia-o para C:\Zabbix\openssl-3.5.0.
5. Navegue até o diretório extraído e configure o OpenSSL, por exemplo:
cd C:\Zabbix\openssl-3.5.0
perl Configure VC-WIN64A no-shared no-capieng no-winstore no-srp no-gost no-dgram no-dtls1-method no-dtls1_2-method --api=1.1.0 --prefix="C:\Program Files\Zabbix\x64\OpenSSL" --openssldir="C:\Program Files\Zabbix\x64\OpenSSL"Se você escolher um diretório personalizado para o OpenSSL ao compilar o agent Zabbix no Windows (por exemplo, C:\zabbix ou C:\openssl-64bit), certifique-se de revogar o acesso de gravação de usuários não administradores a esse diretório. Caso contrário, o agent carregará as configurações SSL de um caminho que pode ser modificado por usuários sem privilégios, resultando em uma potencial vulnerabilidade de segurança.
no-shared faz com que as bibliotecas estáticas libcrypto.lib e libssl.lib do OpenSSL sejam autossuficientes, de modo que os binários do Zabbix incluam o OpenSSL sem precisar de DLLs externas. Isso significa que os binários do Zabbix podem ser copiados para outras máquinas Windows sem as bibliotecas OpenSSL; no entanto, quando uma nova versão de correção de bugs do OpenSSL for lançada, o agent Zabbix precisará ser recompilado.no-shared, o Zabbix depende das DLLs do OpenSSL em tempo de execução. Isso significa que as atualizações do OpenSSL podem não exigir a recompilação do agent Zabbix; no entanto, ao copiá-lo para outras máquinas, as DLLs do OpenSSL também devem ser copiadas.Para mais informações sobre outras opções de configuração do OpenSSL, consulte a documentação do OpenSSL.
6. Compile o OpenSSL e execute os testes (observe que isso pode levar algum tempo):
Execute os testes sem privilégios administrativos; caso contrário, isso pode levar a resultados inesperados ou riscos de segurança. Se alguns testes falharem, consulte a documentação do OpenSSL para solução de problemas.
nmake
nmake test
...
All tests successful.
Files=325, Tests=3101, 822 wallclock secs ( 4.81 usr + 0.81 sys = 5.62 CPU)
Result: PASS7. Instale o OpenSSL:
Para instalar apenas os componentes de software (bibliotecas, arquivos de cabeçalho, mas sem documentação), você pode usar nmake install_sw.
1. Baixe e instale o CMake (disponível como instalador MSI). Durante a instalação, certifique-se de especificar C:\Zabbix\CMake como a pasta de instalação e selecione a opção Add CMake to the PATH environment variable.
2. Baixe o arquivo de origem do PCRE2 e extraia-o para C:\Zabbix\pcre2-10.45.
3. Crie um diretório build no diretório extraído do PCRE2 e navegue até ele:
4. Configure o PCRE2:
cmake -G "NMake Makefiles" -DPCRE_SUPPORT_UNICODE_PROPERTIES=ON -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX="C:\Program Files\Zabbix\x64\PCRE2" "C:\Zabbix\pcre2-10.45"Se ocorrerem erros, recomenda-se excluir o cache do CMake antes de tentar repetir o processo de build do CMake. O cache (CMakeCachecache.txt) pode ser localizado no diretório build do diretório extraído do PCRE2.
5. Compile o PCRE2 usando o NMake:
6. Instale o PCRE2:
1. Baixe o arquivo fonte do Zabbix e extraia-o para C:\Zabbix\zabbix-8.0.0.
Se você precisar gerar um arquivo fonte a partir do repositório de código-fonte bruto (por exemplo, para aplicar patches personalizados ou compilar a partir do código-fonte mais recente), execute os seguintes comandos em uma máquina Linux:
git clone https://git.zabbix.com/scm/zbx/zabbix.git
cd zabbix
./bootstrap.sh
./configure --enable-agent --enable-ipv6 --prefix=`pwd`
make distIsso criará um arquivo fonte, que pode então ser copiado para uma máquina Windows.
2. Navegue até o diretório de build do Zabbix e compile o agent do Zabbix (ou outros componentes); certifique-se de especificar corretamente os diretórios onde o OpenSSL e o PCRE2 estão instalados:
cd C:\Zabbix\zabbix-8.0.0\build\win32\project
# Com suporte a TLS:
nmake /K -f Makefile_agent PCRE2INCDIR="C:\Program Files\Zabbix\x64\PCRE2\include" PCRE2LIBDIR="C:\Program Files\Zabbix\x64\PCRE2\lib" TLS=openssl TLSINCDIR="C:\Program Files\Zabbix\x64\OpenSSL\include" TLSLIBDIR="C:\Program Files\Zabbix\x64\OpenSSL\lib"
nmake /K -f Makefile_get PCRE2INCDIR="C:\Program Files\Zabbix\x64\PCRE2\include" PCRE2LIBDIR="C:\Program Files\Zabbix\x64\PCRE2\lib" TLS=openssl TLSINCDIR="C:\Program Files\Zabbix\x64\OpenSSL\include" TLSLIBDIR="C:\Program Files\Zabbix\x64\OpenSSL\lib"
nmake /K -f Makefile_sender PCRE2INCDIR="C:\Program Files\Zabbix\x64\PCRE2\include" PCRE2LIBDIR="C:\Program Files\Zabbix\x64\PCRE2\lib" TLS=openssl TLSINCDIR="C:\Program Files\Zabbix\x64\OpenSSL\include" TLSLIBDIR="C:\Program Files\Zabbix\x64\OpenSSL\lib"
# Sem suporte a TLS:
nmake /K -f Makefile_agent PCRE2INCDIR="C:\Program Files\Zabbix\x64\PCRE2\include" PCRE2LIBDIR="C:\Program Files\Zabbix\x64\PCRE2\lib"
nmake /K -f Makefile_get PCRE2INCDIR="C:\Program Files\Zabbix\x64\PCRE2\include" PCRE2LIBDIR="C:\Program Files\Zabbix\x64\PCRE2\lib"
nmake /K -f Makefile_sender PCRE2INCDIR="C:\Program Files\Zabbix\x64\PCRE2\include" PCRE2LIBDIR="C:\Program Files\Zabbix\x64\PCRE2\lib"Após a compilação, os binários dos componentes do Zabbix estarão localizados em C:\Zabbix\zabbix-8.0.0\bin\win64. O arquivo de configuração do agent do Zabbix está localizado em C:\Zabbix\zabbix-8.0.0\conf.
Para executar o agent, copie zabbix_agent.exe e seu arquivo de configuração para uma pasta dedicada (por exemplo, C:\Zabbix\agent) e então execute o agent: