您可以通过从源代码编译来获取Zabbix的最新版本。
以下提供了从源代码安装Zabbix的逐步教程。
前往 Zabbix 下载页面 并下载源代码压缩包。下载完成后,通过运行以下命令解压源代码:
在命令中输入正确的 Zabbix 版本号。它必须与下载的压缩包的名称相匹配。
所有Zabbix守护进程都在非特权系统用户下运行。 如果从非特权用户账户启动Zabbix守护进程,它将继续以该用户身份运行。
在默认配置中,如果守护进程以root
启动,它将切换到zabbix
用户账户,该账户必须存在。 要创建zabbix
系统用户和组,请运行下面列出的命令。
基于RedHat的系统:
groupadd --system zabbix
useradd --system -g zabbix -d /usr/lib/zabbix -s /sbin/nologin -c "Zabbix Monitoring System" zabbix
基于Debian的系统:
addgroup --system --quiet zabbix
adduser --quiet --system --disabled-login --ingroup zabbix --home /var/lib/zabbix --no-create-home zabbix
无需为Zabbix前端创建单独的用户账户。
如果Zabbix 服务器 和 agent 在同一台机器上运行,建议在不同的用户账户下运行它们。 以同一个用户运行两者允许agent访问服务器的配置文件,这可能会向Zabbix中的任何管理员级别用户暴露敏感信息,例如数据库密码。
以root
、bin
或任何其他具有特殊权限的账户运行Zabbix是安全风险。
Zabbix进程不需要主目录,因此通常不建议创建一个。 但是,如果您需要需要主目录的功能(例如,在$HOME/.my.cnf中存储MySQL凭证),您可以使用下面列出的命令创建它。
在基于RedHat的系统上,运行:
在基于Debian的系统上,运行:
对Zabbixserver和proxy守护进程,还有Zabbix前端,必须要有一个数据库。但运行Zabbixagent不需要。
此处SQL脚本用于创建数据库模式和插入数据集。Zabbix proxy数据库只需要数据库模式,而Zabbix server数据库在数据库模式之上还需要数据集。
创建了Zabbix数据库之后,执行以下步骤来编译Zabbix。
构建Zabbix server、Zabbix proxy或Zabbix agent需要C99与GNU扩展。可以通过设置CFLAGS="-std=gnu99"来明确指定版本:
如果从Zabbix Git仓库安装,首先需要运行:
./bootstrap.sh
在为Zabbix server或proxy配置源代码时,必须指定要使用的数据库类型。每次只能为server或proxy进程编译一种数据库类型。
要查看所有支持的配置选项,在提取的Zabbix源代码目录中运行:
要为Zabbix server和agent配置源代码,可以运行类似命令:
./configure --enable-server --enable-agent --with-mysql --enable-ipv6 --with-net-snmp --with-libcurl --with-libxml2 --with-openipmi --with-ares
要为Zabbix server(与PostgreSQL等)配置源代码,可以运行:
要为Zabbix proxy(与SQLite等)配置源代码,可以运行:
要为Zabbix agent配置源代码,可以运行:
或者,对于Zabbix agent 2:
关于编译选项的说明:
web.page.*
Zabbix agent 监控项也是必需的。请注意,使用--with-libcurl配置选项时,需要cURL 7.20.0或更高版本。如果./configure由于缺少库或其他情况而失败,请查看config.log
文件以获取更多错误详情。例如,如果libssl
缺失,即时错误消息可能具有误导性:
而config.log
包含更详细的描述:
另请参阅:
如果从Zabbix Git repository安装,必须先执行:$ make dbschema
这一步应该以具有足够权限的用户身份运行(通常是 'root',或使用 sudo
)。
运行 make install
将默认在 /usr/local/sbin 目录安装守护进程二进制文件 (zabbix_server, zabbix_agentd, zabbix_proxy) ,在 /usr/local/bin ,目录安装客户端二进制文件(zabbix_get、zabbix_sender)。
要指定与 /usr/local 不同的位置,在之前配置源的步骤中使用 --prefix 键,例如 --prefix=/home/zabbix。在这种情况下,守护程序二进制文件将安装在 <prefix>/sbin 下,而实用程序则安装在 <prefix>/bin 下,手册页将安装在 <prefix>/share 下。
你需要为每个安装了 zabbix_agentd 的主机配置此文件。
你必须在文件中指定 Zabbix 服务器IP 地址,来自其他主机的连接将被拒绝。
你必须指定数据库名称、用户和密码(如果使用了)。
如果你是小型安装(最多十台受监控的主机),其他参数的默认值将适合你。 如果你想最大化 Zabbix server(或proxy)的性能,你应该修改默认参数。更多信息详见性能调优 章节。
你必须指定服务器 IP 地址和 proxy 的主机名(服务器必须知道),以及数据库名称、用户和密码(如果使用了)。
使用 SQLite 必须指定数据库文件的完整路径;不需要数据库用户和密码。
在服务器端运行 zabbix_server。
确保你的系统允许分配 36MB (或稍微多一点)的共享内存,否则 server 可能无法启动,你会在 server 的日志文件里看到“不能为<type of cache> 分配共享内存”。这可能在 FreeBSD 和 Solaris 8上发生。
请参阅本页底部的“另请参阅” 部分,了解如何配置共享内存。
在所有被监控的机器上运行 zabbix_agentd。
确保你的系统允许分配 2MB 的共享内存,否则 agent 可能无法启动,你会在 agent 的日志文件里看到 “无法为收集器分配共享内存。” 这可能在 Solaris 8 上发生。
如果你安装了 Zabbix proxy,运行zabbix_proxy。
Zabbix 前端使用 PHP 编写,因此需要一个支持 PHP 的 Web 服务器来运行它。 安装只需将 ui 目录下的 PHP 文件复制到 Web 服务器的 HTML 文档目录即可。
对于 Apache Web 服务器,HTML 文档目录的常见位置包括:
建议使用子目录而非 HTML 根目录。 要创建子目录并将 Zabbix 前端文件复制到其中,请执行以下命令,将 <htdocs>
替换为实际目录:
如果计划使用英语以外的任何语言,请参阅 安装额外的前端语言 获取说明。
请参阅Web界面安装页面,了解有关Zabbix前端安装向导的信息。
只有在你想监控 JMX 应用程序时,才需要安装Java gateway。Java gateway是轻量级的,不需要数据库。
从源代码安装,先下载 并解压源代码压缩包。
要编译Java gateway,请带 --enable-java
选项执行 ./configure
。建议指定 --prefix
选项来请求默认的 /usr/local 以外的安装路径,因为安装Java gateway 将创建一个完整的目录树,而不仅仅是一个可执行文件。
要将 Java gateway 编译并打包到一个JAR文件中,执行 make
。 请注意,这一步你的路径中可能需 javac
和 jar
可执行文件。
现在你在 src/zabbix_java/bin 目录有一个 zabbix-java-gateway-$VERSION.jar 文件。如果你对从分配的目录中的 src/zabbix_java 运行 Java gateway 感到满意,那么你可以继续按指导配置和运行 Java gateway。否则,请确保您有足够的权限并执行 make install
。
继续设置以获取更多关于配置和运行 Java gateway 的详细信息 。
仅当您想要使用 scheduled reports时,才需要安装Zabbix Web服务。
要从源代码安装,请首先 download并 提取源代码归档。
要编译Zabbix Web服务,请使用./configure
脚本与 --enable-webservice
选项运行。
构建Zabbix Web服务需要配置好的Go环境和supported Go version。
在安装了Web服务的机器上运行zabbix_web_service:
请继续参阅setup以获取更多关于配置计划报告生成的详细信息。