This page demonstrates how to build Zabbix agent 2 from sources on Windows 10 (64-bit or 32-bit).
Both 32-bit and 64-bit versions can be built on a 64-bit platform, but only the 32-bit version can be built on a 32-bit platform.
Building Zabbix agent 2 requires:
You can build Zabbix agent 2 using one of the following methods:
Before starting the build process, please keep in mind:
C:\Zabbix for all source files and build folders. However, compiled components should be installed in C:\Zabbix\x64 (or C:\Zabbix\x86 for 32-bit builds).This section contains instructions for building Zabbix agent with vcpkg, a package manager that simplifies dependency management and integration with C++ projects.
1. Download and install Build Tools for Visual Studio 2022. During installation, make sure to select the Desktop development with C++ workload, which includes the vcpkg package manager.
2. Download and install Go (available as an MSI installer). During installation, make sure to specify C:\Zabbix\Go as the installation folder.
3. Download the MinGW distribution that uses the Microsoft Visual C runtime library; for example:
x86_64-15.1.0-release-win32-seh-msvcrt-rt_v12-rev0.7zi686-15.1.0-release-win32-dwarf-msvcrt-rt_v12-rev0.7zThen, extract it to C:\Zabbix\mingw64 (or C:\Zabbix\mingw32 for 32-bit builds).
4. Initialize vcpkg and install the dependencies required for building Zabbix agent 2 (note that this may take some time):
cd C:\Zabbix
       
       set PATH=%PATH%;"C:\Program Files (x86)\Microsoft Visual Studio\2022\BuildTools\VC\vcpkg"
       vcpkg new --application
       vcpkg add port pcre2
       vcpkg add port libiconv
       vcpkg add port openssl
       
       # For 64-bit builds:
       set PATH=C:\Zabbix\mingw64\bin;%PATH%
       vcpkg install --triplet x64-mingw-static --x-install-root=x64
       
       # For 32-bit builds:
       set PATH=C:\Zabbix\mingw32\bin;%PATH%
       vcpkg install --triplet x86-mingw-static --x-install-root=x865. Download the Zabbix source archive and extract it to C:\Zabbix\zabbix-8.0.0.
6. Navigate to the Zabbix build directory (C:\Zabbix\zabbix-8.0.0\build\mingw) and create the following build.bat script:
:: Add MinGW and Go to the system `PATH` variable for the current session:
       set PATH=C:\Zabbix\mingw64\bin;%PATH%
       set PATH=C:\Zabbix\Go\bin;%PATH%
       
       :: Set vcpkg installation path:
       set vcpkg="C:\Zabbix\x64\x64-mingw-static"
       
       :: Set linker flags for Crypt32 library:
       SET CGO_LDFLAGS="-lCrypt32"
       
       :: Run the build process:
       mingw32-make GOFLAGS="-buildvcs=false" ARCH=AMD64 ^
           PCRE2="%vcpkg%" ^
           OPENSSL="%vcpkg%" ^
           all:: Add MinGW and Go to the system `PATH` variable for the current session:
       set PATH=C:\Zabbix\mingw32\bin;%PATH%
       set PATH=C:\Zabbix\Go\bin;%PATH%
       
       :: Set vcpkg installation path:
       set vcpkg="C:\Zabbix\x86\x86-mingw-static"
       
       :: Set linker flags for Crypt32 library:
       SET CGO_LDFLAGS="-lCrypt32"
       
       :: Run the build process:
       mingw32-make GOFLAGS="-buildvcs=false" ARCH=x86 ^
           PCRE2="%vcpkg%" ^
           OPENSSL="%vcpkg%" ^
           all7. Compile Zabbix agent 2 by executing the script:
After compilation, the Zabbix agent 2 binary will be located in C:\Zabbix\zabbix-8.0.0\bin\win64 (for 64-bit builds) or C:\Zabbix\zabbix-8.0.0\bin\win32 (for 32-bit builds). Zabbix agent 2 configuration files are located in C:\Zabbix\zabbix-8.0.0\src\go\conf.
To run the agent, zabbix_agent2.exe and its configuration files to a dedicated folder (e.g., C:\Zabbix\agent2) and then run the agent:
mkdir C:\Zabbix\agent2
       
       # For 64-bit builds:
       copy C:\Zabbix\zabbix-8.0.0\bin\win64\zabbix_agent2.exe C:\Zabbix\agent2\
       
       # For 32-bit builds:
       copy C:\Zabbix\zabbix-8.0.0\bin\win32\zabbix_agent2.exe C:\Zabbix\agent2\
       
       copy C:\Zabbix\zabbix-8.0.0\src\go\conf\zabbix_agent2.win.conf C:\Zabbix\agent2\
       xcopy /E /I C:\Zabbix\zabbix-8.0.0\src\go\conf\zabbix_agent2.d C:\Zabbix\agent2\zabbix_agent2.d\
       
       C:\Zabbix\agent2\zabbix_agent2.exe -c C:\Zabbix\agent2\zabbix_agent2.win.confIf necessary, continue with compiling Zabbix agent 2 loadable plugins.
1. Download the Zabbix plugin source that matches your Zabbix agent 2 version (e.g., zabbix-agent2-plugin-ember-plus-8.0.0.tar.gz) and extract it to C:\Zabbix.
2. Navigate to the extracted plugin directory and compile the plugin:
cd C:\Zabbix\zabbix-agent2-plugin-ember-plus-8.0.0
       
       # For 64-bit builds:
       mingw32-make ARCH=AMD64
       
       # For 32-bit builds:
       mingw32-make ARCH=x86After compilation, the Zabbix agent 2 plugin binary and its configuration file will be located in the same plugin directory.
The plugin executable may be placed anywhere as long as it is loadable by Zabbix agent 2. Specify the path to the plugin binary in the plugin configuration file, e.g., in ember.conf for the Ember+ plugin:
The path to the plugin configuration file must be specified in the Include parameter of the Zabbix agent 2 configuration file:
This method of building Zabbix agent 2 is suitable for users who require full control over the build environment or are in a restricted environment where using vcpkg is not possible.
This section contains instructions for building Zabbix agent 2 manually, which includes installing the required build tools and dependencies, and then compiling the agent.
1. Download and install MSYS2 (available as an MSI installer). During installation, make sure to specify C:\Zabbix\msys64 as the installation folder.
2. Download and install Go (available as an MSI installer; see currently supported Go versions). During installation, make sure to specify C:\Zabbix\Go as the installation folder.
3. Download the MinGW distribution that uses the Microsoft Visual C runtime library; for example:
x86_64-15.1.0-release-win32-seh-msvcrt-rt_v12-rev0.7zi686-15.1.0-release-win32-dwarf-msvcrt-rt_v12-rev0.7zThen, extract it to C:\Zabbix\mingw64 (or C:\Zabbix\mingw32 for 32-bit builds).
To compile Zabbix agent without TLS support, proceed to the Installing PCRE2 section.
1. Open the MSYS2 MSYS terminal with administrator privileges and run the following commands:
2. Download the OpenSSL source archive and extract it to C:\Zabbix\openssl-3.5.0.
3. Navigate to the extracted OpenSSL directory and create the following build.sh script:
#!/usr/bin/env bash
       
       export PATH="/c/Zabbix/mingw64/bin:$PATH"
       export d="/c/Zabbix/x64/OpenSSL-Win64-350-static"
       
       perl Configure mingw64 no-shared no-capieng no-winstore no-srp no-gost no-dgram no-dtls1-method no-dtls1_2-method thread_scheme=winthreads --api=1.1.0 --prefix=$d --openssldir=$d
       
       make
       make install#!/usr/bin/env bash
       
       export PATH="/c/Zabbix/mingw32/bin:$PATH"
       export d="/c/Zabbix/x86/OpenSSL-Win64-350-static"
       
       perl Configure mingw no-shared no-capieng no-winstore no-srp no-gost no-dgram no-dtls1-method no-dtls1_2-method thread_scheme=winthreads --api=1.1.0 --prefix=$d --openssldir=$d
       
       make
       make installMake sure to revoke write access from non-administrator users to the C:\Zabbix\x64\OpenSSL-Win64-350-static directory. Otherwise, the agent will load SSL settings from a path that can be modified by unprivileged users, resulting in a potential security vulnerability.
no-shared option makes libcrypto.lib and libssl.lib OpenSSL static libraries self-contained, so Zabbix binaries include OpenSSL without needing external DLLs. This means that Zabbix binaries can be copied to other Windows machines without OpenSSL libraries; however, when a new OpenSSL bugfix version is released, Zabbix agent will need to be recompiled.no-shared option, Zabbix relies on OpenSSL DLLs at runtime. This means that OpenSSL updates may not require recompiling Zabbix agent; however, when copying it to other machines, the OpenSSL DLLs must be also be copied.For more information about other OpenSSL configuration options, refer to OpenSSL documentation.
4. Configure and install OpenSSL by executing the script (note that this may take some time):
1. Download PCRE2 source archive and extract it to C:\Zabbix\pcre2-10.45.
2. Open the MSYS2 MSYS terminal with administrator privileges. Then, create a build directory in the extracted PCRE2 directory and navigate to it:
3. Configure PCRE2:
# For 64-bit builds:
       export PATH="/c/Zabbix/mingw64/bin:$PATH"
       cmake -DCMAKE_C_COMPILER=gcc -DCMAKE_C_FLAGS="-O2 -g" -DCMAKE_INSTALL_PREFIX="/c/Zabbix/x64/PCRE2" ..
       
       # For 32-bit builds:
       export PATH="/c/Zabbix/mingw32/bin:$PATH"
       cmake -DCMAKE_C_COMPILER=gcc -DCMAKE_C_FLAGS="-m32 -O2 -g" -DCMAKE_EXE_LINKER_FLAGS="-Wl,-mi386pe" -DCMAKE_INSTALL_PREFIX="/c/Zabbix/x86/PCRE2" ..If any errors occur, it is recommended to delete the CMake cache before attempting to repeat the CMake build process. The cache (CMakeCachecache.txt) can be located in the build directory of the extracted PCRE2 directory.
4. Install PCRE2:
1. Download the Zabbix source archive and extract it to C:\Zabbix\zabbix-8.0.0.
If you need to generate a source archive from the raw source repository (e.g., to apply custom patches or build from the latest source code), run the following commands on a Linux machine with Go installed (required for configuring Zabbix agent 2):
git clone https://git.zabbix.com/scm/zbx/zabbix.git
       cd zabbix
       ./bootstrap.sh
       ./configure --enable-agent2 --enable-ipv6 --prefix=`pwd`
       make distThis will create a source archive, which can then be copied to a Windows machine.
2. Open the Command Prompt with administrator privileges. Then, navigate to the Zabbix build directory and compile Zabbix agent; make sure to correctly specify the directories where OpenSSL and PCRE2 are installed:
cd C:\Zabbix\zabbix-8.0.0\build\mingw
       set PATH=C:\Zabbix\mingw64\bin;%PATH%
       mklink /D C:\Zabbix\x64\OpenSSL-Win64-350-static\lib C:\Zabbix\x64\OpenSSL-Win64-350-static\lib64
       
       # With TLS support:
       mingw32-make ARCH=AMD64 PCRE2="C:\Zabbix\x64\PCRE2" OPENSSL="C:\Zabbix\x64\OpenSSL-Win64-350-static"
       
       # Without TLS support:
       mingw32-make ARCH=AMD64 PCRE2="C:\Zabbix\x64\PCRE2"cd C:\Zabbix\zabbix-8.0.0\build\mingw
       set PATH=C:\Zabbix\mingw32\bin;%PATH%
       
       # With TLS support:
       mingw32-make ARCH=x86 PCRE2="C:\Zabbix\x86\PCRE2" OPENSSL="C:\Zabbix\x86\OpenSSL-Win64-350-static"
       
       # Without TLS support:
       mingw32-make ARCH=x86 PCRE2="C:\Zabbix\x86\PCRE2"After compilation, the Zabbix agent 2 binary will be located in C:\Zabbix\zabbix-8.0.0\bin\win64 (or C:\Zabbix\zabbix-8.0.0\bin\win32 for 32-bit builds). Zabbix agent 2 configuration files are located in C:\Zabbix\zabbix-8.0.0\src\go\conf.
To run the agent, copy the zabbix_agent2.exe binary and its configuration files to a dedicated folder (e.g., C:\Zabbix\agent2) and then run the agent:
mkdir C:\Zabbix\agent2
       copy C:\Zabbix\zabbix-8.0.0\bin\win64\zabbix_agent2.exe C:\Zabbix\agent2\
       copy C:\Zabbix\zabbix-8.0.0\src\go\conf\zabbix_agent2.win.conf C:\Zabbix\agent2\
       xcopy /E /I C:\Zabbix\zabbix-8.0.0\src\go\conf\zabbix_agent2.d C:\Zabbix\agent2\zabbix_agent2.d\
       
       C:\Zabbix\agent2\zabbix_agent2.exe -c C:\Zabbix\agent2\zabbix_agent2.win.confIf necessary, continue with compiling Zabbix agent 2 loadable plugins.