# syntax=docker/dockerfile:1 ARG MAJOR_VERSION=7.2 ARG ZBX_VERSION=${MAJOR_VERSION}.1 ARG BUILD_BASE_IMAGE=zabbix-build-pgsql:alpine-${ZBX_VERSION} FROM ${BUILD_BASE_IMAGE} AS builder FROM alpine:3.21 ARG MAJOR_VERSION ARG ZBX_VERSION ARG ZBX_SOURCES=https://git.zabbix.com/scm/zbx/zabbix.git ENV TERM=xterm \ ZBX_VERSION=${ZBX_VERSION} ZBX_SOURCES=${ZBX_SOURCES} \ MIBDIRS=/usr/share/snmp/mibs:/var/lib/zabbix/mibs MIBS=+ALL \ NMAP_PRIVILEGED="" \ ZABBIX_USER_HOME_DIR="/var/lib/zabbix" \ ZABBIX_CONF_DIR="/etc/zabbix" ENV ZBX_DB_NAME="dummy_db_name" \ ZBX_FPINGLOCATION="/usr/sbin/fping" \ ZBX_LOADMODULEPATH="${ZABBIX_USER_HOME_DIR}/modules" \ ZBX_SNMPTRAPPERFILE="${ZABBIX_USER_HOME_DIR}/snmptraps/snmptraps.log" \ ZBX_SSHKEYLOCATION="${ZABBIX_USER_HOME_DIR}/ssh_keys/" \ ZBX_SSLCERTLOCATION="${ZABBIX_USER_HOME_DIR}/ssl/certs/" \ ZBX_SSLKEYLOCATION="${ZABBIX_USER_HOME_DIR}/ssl/keys/" \ ZBX_SSLCALOCATION="${ZABBIX_USER_HOME_DIR}/ssl/ssl_ca/" LABEL org.opencontainers.image.authors="Alexey Pustovalov " \ org.opencontainers.image.description="Zabbix server with PostgreSQL database support" \ org.opencontainers.image.documentation="https://www.zabbix.com/documentation/${MAJOR_VERSION}/manual/installation/containers" \ org.opencontainers.image.licenses="AGPL v3.0" \ org.opencontainers.image.source="${ZBX_SOURCES}" \ org.opencontainers.image.title="Zabbix server (PostgreSQL)" \ org.opencontainers.image.url="https://zabbix.com/" \ org.opencontainers.image.vendor="Zabbix SIA" \ org.opencontainers.image.version="${ZBX_VERSION}" STOPSIGNAL SIGTERM COPY --from=builder ["/tmp/zabbix-${ZBX_VERSION}-output/server/sbin/zabbix_server", "/usr/sbin/zabbix_server"] COPY --from=builder ["/tmp/zabbix-${ZBX_VERSION}-output/general/bin/*", "/usr/bin/"] COPY --from=builder ["/tmp/zabbix-${ZBX_VERSION}-output/server/conf/", "${ZABBIX_CONF_DIR}/"] COPY --from=builder ["/tmp/zabbix-${ZBX_VERSION}-output/server/database/postgresql/", "/usr/share/doc/zabbix-server-postgresql/"] RUN set -eux && \ INSTALL_PKGS="bash \ traceroute \ nmap \ fping \ tzdata \ iputils \ libcap \ libcurl \ libevent \ libldap \ libssh \ libxml2 \ net-snmp-agent-libs \ openipmi-libs \ pcre2 \ postgresql17-client \ gzip \ unixodbc \ zlib" && \ apk add \ --no-cache \ --clean-protected \ ${INSTALL_PKGS} && \ addgroup \ --system \ --gid 1995 \ zabbix && \ adduser \ --system \ --gecos "Zabbix monitoring system" \ --disabled-password \ --uid 1997 \ --ingroup zabbix \ --shell /sbin/nologin \ --home ${ZABBIX_USER_HOME_DIR} \ zabbix && \ adduser zabbix dialout && \ chgrp zabbix /usr/bin/nmap && \ setcap cap_net_raw+eip /usr/bin/nmap && \ mkdir -p ${ZABBIX_CONF_DIR} && \ mkdir -p ${ZABBIX_USER_HOME_DIR} && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/dbscripts && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/enc && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/enc_internal && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/export && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/mibs && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/modules && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/snmptraps && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/ssh_keys && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/ssl && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/ssl/certs && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/ssl/keys && \ mkdir -p ${ZABBIX_USER_HOME_DIR}/ssl/ssl_ca && \ mkdir -p /usr/lib/zabbix/alertscripts && \ mkdir -p /usr/lib/zabbix/externalscripts && \ mkdir -p /usr/share/doc/zabbix-server-postgresql && \ chown --quiet -R zabbix:root ${ZABBIX_CONF_DIR}/zabbix_server_modules.conf ${ZABBIX_USER_HOME_DIR} && \ chown --quiet zabbix:root ${ZABBIX_CONF_DIR}/ && \ chgrp -R 0 ${ZABBIX_CONF_DIR}/zabbix_server_modules.conf ${ZABBIX_USER_HOME_DIR} && \ chgrp 0 ${ZABBIX_CONF_DIR} && \ chmod -R g=u ${ZABBIX_CONF_DIR}/zabbix_server_modules.conf ${ZABBIX_USER_HOME_DIR} && \ chmod g=u ${ZABBIX_CONF_DIR} EXPOSE 10051/TCP WORKDIR ${ZABBIX_USER_HOME_DIR} VOLUME ["${ZABBIX_USER_HOME_DIR}/snmptraps", "${ZABBIX_USER_HOME_DIR}/export"] COPY ["docker-entrypoint.sh", "/usr/bin/"] ENTRYPOINT ["/usr/bin/docker-entrypoint.sh"] USER 1997 CMD ["/usr/sbin/zabbix_server", "--foreground", "-c", "/etc/zabbix/zabbix_server.conf"]