Zabbix性能调优:配置优化
配置文件位于/etc/zabbix/zabbix_server.conf
通过日志可以分析当前服务状态。
LogFile=/tmp/zabbix_server.log #日志文件路径。
LogFileSize=1 #日志文件最大值(MB),超过则滚动,设为0表示不回滚。
DebugLevel=3 #调试日志级别:
# 0 - Zabbix进程启停基本信息。
# 1 - 严重信息。
# 2 - 错误信息。
# 3 - 警告。
# 4 - 调试模式。
# 5 - 调试模式-加强版。
数据库配置
若数据库与服务器在同一机器上,使用socket模式可以提高访问速度。
DBSocket=/tmp/mysql.sock
轮询进程数
通过并发来提高轮询或者捕获的效率,同时用来避免poller busy问题,根据CPU数量与系统负载综合调优。
StartPollers=80 #基本轮询进程数,范围0-1000。
StartIPMIPollers=0 #IPMI轮询进程数,若无智能卡监控,可置为0。
StartPollersUnreachable=1 #不可达主机的轮询进程数,包括IPMI和JAVA。
StartTrappers=1 #捕获模式进程数,若无active模式的客户端,则可减小该进程。
StartPingers=20 #ICMP ping数量,当大量使用ping用于心跳检测时,可适量增加。
StartDiscoverers=1 #自动发现实例数,若关闭此功能则减少该数量。
StartHTTPPollers=7 #HTTP轮询实例数,当使用到内置的WEB监测时,适量增加该值。
StartTimers=1 #定时器实例数。
StartEscalators=20 #扩展实例数。
StartDBSyncers=20 #DB同步器线程数。
StartJavaPollers=5 #JAVA轮询实例,当大量监控JMX时需要增加此项。
StartProxyPollers=1 #代理轮询线程。
缓存配置
CacheSize=8M #128K-8G,缓存配置项的大小,用于存储 host, item, trigger 数据。监控项
CacheUpdateFrequency=60 #提交缓存频率。
HistoryCacheSize=16M #历史缓存大小。
HistoryIndexCacheSize=4M #历史索引缓存大小。
TrendCacheSize=4M #趋势缓存大小。
ValueCacheSize=8M #历史项目值缓存,设为0表示禁用项目值缓存,history value 缓存大小,当缓存超标了,将会每隔 5 分钟往 server 日志里面记录。
用户配置
AllowRoot=0 #是否允许使用 root 启动, 0:不允许, 1:允许,默认情况下她会使用 zabbix 用户来启动 zabbix 进程。
User=zabbix #服务使用的用户。
超时配置
Timeout=4 #端探测超时时间。
TrapperTimeout=300 #捕捉器超时时间。
UnreachablePeriod=45 #不可达时间,超过视为不可达。
UnavailableDelay=60 #不可达期间尝试周期。
UnreachableDelay=15 #不可用期间尝试周期。
HousekeepingFrequency=1 #housekeeping 数据归档周期(h),housekeep 执行频率,默认每小时回去删除一些过期数据。如果 server 重启,那么 30 分钟之后才执行一次,接下来,每隔一小时在执行一次。。
MaxHousekeeperDelete=5000 #housekeeper表记录,一次删除的数据不能大于 MaxHousekeeperDelete。
SenderFrequency=30 #Zabbix尝试发送未发送数据频率,5-3600s。
例如:
修改zabbixserver的配置文件,修改如下:
StartPollers=360 #增加处理zabbix 数据的进程数
StartPollersUnreachable=60 #增加recheck的进程数
StartTrappers=30 #增加建立agent连接传输进程数
StartDiscoverers=30 #增加发现功能进程
CacheSize=256M #增加主机,监控项等配置缓存
StartDBSyncers=50 #增加写入db进程
HistoryCacheSize=128M #增加历史数据缓存
TrendCacheSize=64M #增加trend数据缓存
HistoryTextCacheSize=256M
ValueCacheSize=128M # 增加监控指标值缓存