#!/usr/bin/env python #coding=utf-8 import sys import os import commands class QpsTps(object): def __init__(self): self.QPS = '' self.TPS = '' def getQps(self): (Queries,QPS_result) = commands.getstatusoutput("mysqladmin -uroot -p123456 extended-status | grep 'Queries' | cut -d'|' -f3") self.QPS = int(QPS_result) return self.QPS def getTps(self): (Com_commit,cm_result) = commands.getstatusoutput("mysqladmin -uroot -p123456 extended-status | grep 'Com_commit' | cut -d'|' -f3 ") (Com_rollback,rb_result) = commands.getstatusoutput("mysqladmin -uroot -p123456 extended-status | grep 'Com_rollback' | cut -d'|' -f3 | awk 'NR==1'") self.TPS = int(cm_result) + int(rb_result) return self.TPS class error_out(object): def error_print(self): '''代入值少输,输出错误''' print print 'Usage : ' + sys.argv[0] + ' MysqlStatusKey ' print sys.exit(1) class Main(object): def main(self): if len(sys.argv) == 1: error = error_out() error.error_print() elif sys.argv[1] == 'QPS': a = QpsTps() print a.getQps() elif sys.argv[1] == 'TPS': a = QpsTps() print a.getTps() if __name__ == '__main__': main_obj = Main() main_obj.main() |
将代码上传至系统,赋值权限,在zabbix的mysql配置文中加入:
UserParameter=mysql.QPS,python /usr/local/zabbix/scripts/get_qps_tps.py QPS UserParameter=mysql.TPS,python /usr/local/zabbix/scripts/get_qps_tps.py TPS |
服务端取值测试:
# /usr/local/zabbix/bin/zabbix_get -s 10.16.1.68 -p 10050 -k"mysql.QPS" 1783724 # /usr/local/zabbix/bin/zabbix_get -s 127.0.0.1 -p 10050 -k"mysql.QPS" 3695982 # /usr/local/zabbix/bin/zabbix_get -s 127.0.0.1 -p 10050 -k"mysql.TPS" 278279 |
优化版:
#!/usr/bin/env python #coding=utf-8 import sys import os import time import commands from db_init import InitDb class MysqlPeerStatus(object): def __init__(self): a = InitDb() a.readconfigfile() self.user = a.GetUser() self.passwd = a.GetPasswd() self.value = 0 def GetValue(self, key): (temp,last) = commands.getstatusoutput("mysqladmin -u%s -p%s extended-status | grep '%s>' | cut -d'|' -f3"%(self.user,self.passwd,key)) last = float(last) return last class MysqlQpsTps(object): def __init__(self): """init""" self.a = MysqlPeerStatus() for key in ('Com_insert','Com_update', 'Com_delete', 'Com_select'): if key == 'Com_insert': self.com_insert = self.a.GetValue(key) elif key == 'Com_update': self.com_update = self.a.GetValue(key) elif key == 'Com_delete': self.com_delete = self.a.GetValue(key) else: self.com_select = self.a.GetValue(key) def Tps(self): Tps = self.com_insert + self.com_update + self.com_delete return Tps def Qps(self): Qps = self.com_insert + self.com_update + self.com_delete + self.com_select return Qps class InnodbBufferStatus(object): def __init__(self): """init""" self.a = MysqlPeerStatus() for key in ('Innodb_buffer_pool_pages_total','Innodb_buffer_pool_read_requests','Innodb_buffer_pool_reads', 'Innodb_buffer_pool_pages_free','Innodb_buffer_pool_pages_dirty'): if key == 'Innodb_buffer_pool_pages_total': self.pages_total = self.a.GetValue(key) elif key == 'Innodb_buffer_pool_read_requests': self.cache_read = self.a.GetValue(key) elif key == 'Innodb_buffer_pool_reads': self.disk_read = self.a.GetValue(key) elif key == 'Innodb_buffer_pool_pages_free': self.free_pages = self.a.GetValue(key) else: self.pages_dirty = self.a.GetValue(key) def InnodbBufferReadHitRate(self): result = (1 - self.disk_read/self.cache_read) * 100 return result def InnodbBufferUsage(self): result = (1 - self.free_pages/self.pages_total) * 100 return result def InnodbBufferPoolDirtyPercentage(self): result = self.pages_dirty/self.pages_total * 100 return result class error_out(object): def error_print(self): '''输出错误信息''' print print 'Usage : ' + sys.argv[0] + ' time ' + ' MysqlStatusKey ' print 'MysqlStatusKey include (Qps, Tps, innodb_buffer_read_hit_ratio, innodb_buffer_usage, Queries Etc!)' print sys.exit(1) class Main(object): def main(self): if len(sys.argv) == 1: error = error_out() error.error_print() elif len(sys.argv) == 2: #times = float(sys.argv[1]) key = sys.argv[1] if key == 'innodb_buffer_read_hit_ratio': b = InnodbBufferStatus() print b.InnodbBufferReadHitRate() elif key == 'innodb_buffer_usage': b = InnodbBufferStatus() print b.InnodbBufferUsage() elif key == 'innodb_pages_dirty_percentage': b = InnodbBufferStatus() print b.InnodbBufferPoolDirtyPercentage() elif key == 'Qps': b = MysqlQpsTps() print b.Qps() elif key == 'Tps': b = MysqlQpsTps() print b.Tps() else: b = MysqlPeerStatus() print b.GetValue(key) #print last #time.sleep(times) #print (b.GetValue(key) - last) / times if __name__ == '__main__': main_obj = Main() main_obj.main() |
上述脚本不适合mysql 5.6 以上版本,所以要用MySQLdb模块去写:
#!/usr/bin/env python #coding=utf8 import sys import os class GetMysqlStatus(): def __init__(self): self.val = {} self.result = {} def check(self): import MySQLdb import MySQLdb.cursors try: self.db = MySQLdb.connect(user="root", passwd="123456", host="192.168.1.62", port=3306, cursorclass=MySQLdb.cursors.DictCursor) except Exception, e: raise Exception, 'Cannot interface with MySQL server, %s' % e def extract(self, key): try: c = self.db.cursor() c.execute("""show global status like '%s';""" % key) self.val = c.fetchone() #print self.val return float(self.val['Value']) c.close() self.db.close() except Exception, e: print e.message def init(self): for key in ('Com_insert', 'Com_delete', 'Com_select', 'Com_rollback', 'Com_update', 'Com_commit', 'Innodb_buffer_pool_pages_total', 'Innodb_buffer_pool_read_requests', 'Innodb_buffer_pool_reads', 'Innodb_buffer_pool_pages_free', 'Innodb_buffer_pool_pages_dirty', 'Key_blocks_used', 'Key_blocks_unused', 'Key_reads', 'Key_read_requests', 'Key_writes', 'Key_write_requests'): self.result[key] = self.extract(key) def get_tps(self): TPS = self.result['Com_commit'] + self.result['Com_rollback'] return TPS def get_qps(self): QPS = self.result['Com_insert'] + self.result['Com_delete'] + self.result['Com_select'] + self.result['Com_update'] return QPS def GetKeyReadHitRatio(self): if self.result['Key_read_requests'] == 0: Key_read_hit_ratio = 0 else: Key_read_hit_ratio = (1 - self.result['Key_reads'] / self.result['Key_read_requests']) * 100 return Key_read_hit_ratio def GetKeyUsageRatio(self): Key_usage_ratio = self.result['Key_blocks_used'] / (self.result['Key_blocks_used'] + self.result['Key_blocks_unused']) * 100 return Key_usage_ratio def GetKeyWriteHitRatio(self): if self.result['Key_write_requests'] == 0: Key_write_hit_ratio = 0 else: Key_write_hit_ratio = (1 - self.result['Key_writes'] / self.result['Key_write_requests']) * 100 return Key_write_hit_ratio def GetInnodbBufferReadHitRatio(self): Innodb_buffer_read_hit_ratio = (1 - self.result['Innodb_buffer_pool_reads'] / self.result['Innodb_buffer_pool_read_requests']) * 100 return Innodb_buffer_read_hit_ratio def GetInnodbBufferPoolUsage(self): Innodb_buffer_usage = (1 - self.result['Innodb_buffer_pool_pages_free'] / self.result['Innodb_buffer_pool_pages_total']) * 100 return Innodb_buffer_usage def GetInnodbBufferPoolDirtyRatio(self): Innodb_buffer_pool_dirty_ratio = (self.result['Innodb_buffer_pool_pages_dirty'] / self.result['Innodb_buffer_pool_pages_total']) * 100 return Innodb_buffer_pool_dirty_ratio def get_alive_status(self): import socket sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sock.settimeout(1) try: sock.connect(('192.168.1.62', 3306)) #print 'MySQL is alive!' result = 1 return result except Exception: #print 'MySQL 3306 not connect!' result = 0 return result sock.close() class ErrorOut(): def error_print(self): """输出错误信息""" print print 'Usage: ' + sys.argv[0] + ' ' + ' MySQL_Status_Key ' print sys.exit(1) class Main(): def main(self): if len(sys.argv) == 1: error = ErrorOut() error.error_print() elif len(sys.argv) == 2: key = sys.argv[1] a = GetMysqlStatus() a.check() a.init() if key == 'Innodb_buffer_read_hit_ratio': print a.GetInnodbBufferReadHitRatio() elif key == 'Innodb_buffer_usage': print a.GetInnodbBufferPoolUsage() elif key == 'Innodb_buffer_pool_dirty_ratio': print a.GetInnodbBufferPoolDirtyRatio() elif key == 'QPS': print a.get_qps() elif key == 'TPS': print a.get_tps() elif key == 'Key_usage_ratio': print a.GetKeyUsageRatio() elif key == 'Key_read_hit_ratio': print a.GetKeyReadHitRatio() elif key == 'Key_write_hit_ratio': print a.GetKeyWriteHitRatio() elif key == 'MySQL_alive': print a.get_alive_status() else: print a.extract(key) if __name__ == "__main__": exe = Main() exe.main() |
运行:
D:flask>python get_mysql_status.py Usage: get_mysql_status.py MySQL_Status_Key D:flask>python get_mysql_status.py Innodb_buffer_pool_reads 144.0 D:flask>python get_mysql_status.py MySQL_alive 1 D:flask>python get_mysql_status.py Innodb_buffer_read_hit_ratio 68.6274509804 |
这样的if else让人有点蛋疼,继续优化代码:
#!/usr/bin/env python #coding=utf8 import sys import os import inspect class GetMysqlStatus(): def __init__(self): self.val = {} self.result = {} def check(self): import MySQLdb import MySQLdb.cursors try: self.db = MySQLdb.connect(user="root", passwd="LVS@071103", host="192.168.1.62", port=3306, cursorclass=MySQLdb.cursors.DictCursor) except Exception, e: raise Exception, 'Cannot interface with MySQL server, %s' % e def extract(self, key): try: c = self.db.cursor() c.execute("""show global status like '%s';""" % key) self.val = c.fetchone() return float(self.val['Value']) c.close() self.db.close() except Exception, e: print e.message def init(self): for key in ('Com_insert', 'Com_delete', 'Com_select', 'Com_rollback', 'Com_update', 'Com_commit', 'Innodb_buffer_pool_pages_total', 'Innodb_buffer_pool_read_requests', 'Innodb_buffer_pool_reads', 'Innodb_buffer_pool_pages_free', 'Innodb_buffer_pool_pages_dirty', 'Key_blocks_used', 'Key_blocks_unused', 'Key_reads', 'Key_read_requests', 'Key_writes', 'Key_write_requests'): self.result[key] = self.extract(key) def TPS(self): TPS = self.result['Com_commit'] + self.result['Com_rollback'] return TPS def QPS(self): QPS = self.result['Com_insert'] + self.result['Com_delete'] + self.result['Com_select'] + self.result['Com_update'] return QPS def Key_read_hit_ratio(self): if self.result['Key_read_requests'] == 0: Key_read_hit_ratio = 0 else: Key_read_hit_ratio = (1 - self.result['Key_reads'] / self.result['Key_read_requests']) * 100 return Key_read_hit_ratio def Key_usage_ratio(self): Key_usage_ratio = self.result['Key_blocks_used'] / (self.result['Key_blocks_used'] + self.result['Key_blocks_unused']) * 100 return Key_usage_ratio def Key_write_hit_ratio(self): if self.result['Key_write_requests'] == 0: Key_write_hit_ratio = 0 else: Key_write_hit_ratio = (1 - self.result['Key_writes'] / self.result['Key_write_requests']) * 100 return Key_write_hit_ratio def Innodb_buffer_read_hit_ratio(self): Innodb_buffer_read_hit_ratio = (1 - self.result['Innodb_buffer_pool_reads'] / self.result['Innodb_buffer_pool_read_requests']) * 100 return Innodb_buffer_read_hit_ratio def Innodb_buffer_usage(self): Innodb_buffer_usage = (1 - self.result['Innodb_buffer_pool_pages_free'] / self.result['Innodb_buffer_pool_pages_total']) * 100 return Innodb_buffer_usage def Innodb_buffer_pool_dirty_ratio(self): Innodb_buffer_pool_dirty_ratio = (self.result['Innodb_buffer_pool_pages_dirty'] / self.result['Innodb_buffer_pool_pages_total']) * 100 return Innodb_buffer_pool_dirty_ratio def MySQL_alive(self): import socket sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sock.settimeout(1) try: sock.connect(('192.168.1.62', 3306)) #print 'MySQL is alive!' result = 1 return result except Exception: #print 'MySQL 3306 not connect!' result = 0 return result sock.close() class ErrorOut(): def error_print(self): """输出错误信息""" print print 'Usage: ' + sys.argv[0] + ' ' + ' MySQL_Status_Key ' print sys.exit(1) class Main(): def main(self): if len(sys.argv) == 1: error = ErrorOut() error.error_print() elif len(sys.argv) == 2: method_name = sys.argv[1] a = GetMysqlStatus() a.check() a.init() if hasattr(a, method_name): print getattr(a, method_name)() else: print a.extract(method_name) if __name__ == "__main__": run = Main() run.main() |
进一步优化代码,让代码可以根据不同的端口取值,取出的值先存入一个元组,然后遍历元组,取出相应key的值,这样就可以减少对数据库查询:
#!/usr/bin/env python #coding=utf8 import sys import os import inspect import MySQLdb import MySQLdb.cursors class GetMysqlStatus(): def __init__(self): self.result = '' self.each_result = '' def check(self, port): try: self.db = MySQLdb.connect(user="root", passwd="LVS@071103", host="127.0.0.1", port=port, cursorclass=MySQLdb.cursors.DictCursor) except Exception, e: raise Exception, 'Cannot interface with MySQL server, %s' % e def extract(self): try: c = self.db.cursor() c.execute("""show global status;""") self.result = c.fetchall() return self.result c.close() self.db.close() except Exception, e: print e def getVal(self, key): for i in self.result: if i['Variable_name'] == key: self.each_result = i['Value'] return self.each_result def TPS(self): TPS = int(self.getVal('Com_commit')) + int(self.getVal('Com_rollback')) return TPS def QPS(self): return int(self.getVal('Com_insert')) + int(self.getVal('Com_delete')) + int(self.getVal('Com_select')) + int(self.getVal('Com_update')) def Key_read_hit_ratio(self): try: Key_read_hit_ratio = (1 - float(self.getVal('Key_reads')) / float(self.getVal('Key_read_requests'))) * 100 except ZeroDivisionError, e: print "integer division or modulo by zero", e return Key_read_hit_ratio def Key_usage_ratio(self): try: Key_usage_ratio = float(self.getVal('Key_blocks_used')) / (float(self.getVal('Key_blocks_used')) + float(self.getVal('Key_blocks_unused'))) except ZeroDivisionError, e: print "integer division or modulo by zero", e return Key_usage_ratio def Key_write_hit_ratio(self): try: Key_write_hit_ratio = (1 - float(self.getVal('Key_writes')) / float(self.getVal('Key_write_requests'))) * 100 except ZeroDivisionError, e: print "integer division or modulo by zero", e return Key_write_hit_ratio def Innodb_buffer_read_hit_ratio(self): try: Innodb_buffer_read_hit_ratio = (1 - float(self.getVal('Innodb_buffer_pool_reads')) / float(self.getVal('Innodb_buffer_pool_read_requests'))) * 100 except ZeroDivisionError, e: print "integer division or modulo by zero", e return Innodb_buffer_read_hit_ratio def Innodb_buffer_usage(self): try: Innodb_buffer_usage = (1 - float(self.getVal('Innodb_buffer_pool_pages_free')) / float(self.getVal('Innodb_buffer_pool_pages_total'))) * 100 except ZeroDivisionError, e: print "integer division or modulo by zero", e return Innodb_buffer_usage def Innodb_buffer_pool_dirty_ratio(self): try: Innodb_buffer_pool_dirty_ratio = (float(self.getVal('Innodb_buffer_pool_pages_dirty')) / float(self.getVal('Innodb_buffer_pool_pages_total'))) * 100 except ZeroDivisionError, e: print "integer division or modulo by zero", e return Innodb_buffer_pool_dirty_ratio class ErrorOut(): def error_print(self): """输出错误信息""" print print 'Usage: ' + sys.argv[0] + ' ' + ' MySQL_Status_Key ' print sys.exit(1) class Main(): def main(self): error = ErrorOut() if len(sys.argv) == 1: error.error_print() elif len(sys.argv) == 2: error.error_print() elif len(sys.argv) == 3: port = int(sys.argv[1]) key = sys.argv[2] a = GetMysqlStatus() a.check(port) a.extract() if hasattr(a, key): print getattr(a, key)() else: print a.getVal(key) if __name__ == "__main__": run = Main() run.main() |
字典方式: (增加端口指定)
#!/usr/bin/env python #coding=utf8 import sys import os import inspect import MySQLdb import MySQLdb.cursors class GetMysqlStatus(): def __init__(self): self.result = '' self.dict = {} def check(self, port): try: self.db = MySQLdb.connect(user="root", passwd="LVS@071103", host="127.0.0.1", port=port, cursorclass=MySQLdb.cursors.DictCursor) except Exception, e: raise Exception, 'Cannot interface with MySQL server, %s' % e def extract(self): try: c = self.db.cursor() c.execute("""show global status;""") self.result = c.fetchall() for i in self.result: self.dict[i['Variable_name']] = i['Value'] return self.dict c.close() self.db.close() except Exception, e: print e def get_val(self, key): return self.dict[key] def TPS(self): TPS = int(self.dict['Com_commit']) + int(self.dict['Com_rollback']) return TPS def QPS(self): return int(self.dict['Com_insert']) + int(self.dict['Com_delete']) + int(self.dict['Com_select']) + int(self.dict['Com_update']) def Key_read_hit_ratio(self): try: Key_read_hit_ratio = (1 - float(self.dict['Key_reads']) / float(self.dict['Key_read_requests'])) * 100 except ZeroDivisionError, e: print "integer division or modulo by zero", e return Key_read_hit_ratio def Key_usage_ratio(self): try: Key_usage_ratio = float(self.dict['Key_blocks_used']) / (float(self.dict['Key_blocks_used']) + float(self.dict['Key_blocks_unused'])) except ZeroDivisionError, e: print "integer division or modulo by zero", e return Key_usage_ratio def Key_write_hit_ratio(self): try: Key_write_hit_ratio = (1 - float(self.dict['Key_writes']) / float(self.dict['Key_write_requests'])) * 100 except ZeroDivisionError, e: print "integer division or modulo by zero", e return Key_write_hit_ratio def Innodb_buffer_read_hit_ratio(self): try: Innodb_buffer_read_hit_ratio = (1 - float(self.dict['Innodb_buffer_pool_reads']) / float(self.dict['Innodb_buffer_pool_read_requests'])) * 100 except ZeroDivisionError, e: print "integer division or modulo by zero", e return Innodb_buffer_read_hit_ratio def Innodb_buffer_usage(self): try: Innodb_buffer_usage = (1 - float(self.dict['Innodb_buffer_pool_pages_free']) / float(self.dict['Innodb_buffer_pool_pages_total'])) * 100 except ZeroDivisionError, e: print "integer division or modulo by zero", e return Innodb_buffer_usage def Innodb_buffer_pool_dirty_ratio(self): try: Innodb_buffer_pool_dirty_ratio = (float(self.dict['Innodb_buffer_pool_pages_dirty']) / float(self.dict['Innodb_buffer_pool_pages_total'])) * 100 except ZeroDivisionError, e: print "integer division or modulo by zero", e return Innodb_buffer_pool_dirty_ratio class ErrorOut(): def error_print(self): """输出错误信息""" print print 'Usage: ' + sys.argv[0] + ' ' + ' MySQL_Status_Key ' print sys.exit(1) class Main(): def main(self): error = ErrorOut() if len(sys.argv) == 1: error.error_print() elif len(sys.argv) == 2: error.error_print() elif len(sys.argv) == 3: port = int(sys.argv[1]) key = sys.argv[2] a = GetMysqlStatus() a.check(port) a.extract() if hasattr(a, key): print getattr(a, key)() else: print a.get_val(key) if __name__ == "__main__": run = Main() run.main() |
相关推荐
zabbix监控mysql pecona模板 zabbix 3.0版本可用 zabbix 3.0版本可用
Zabbix是一个开源的分布式监控系统,它能够监控各种网络服务、服务器和网络硬件等。而MySQL是目前最流行的开源数据库管理系统,它为各种应用提供数据存储和查询功能。在实际使用中,对于运行在MySQL数据库上的Zabbix...
### Zabbix监控MySQL数据库...通过上述步骤,我们可以构建起一个完整的Zabbix监控环境,不仅能够监控MySQL数据库的状态和性能,还能扩展到其他类型的服务器和服务。这为提高数据中心的整体稳定性提供了强有力的支持。
1. 安装Zabbix Server和Agent:首先确保Zabbix Server和被监控的MySQL服务器上已安装Zabbix Server和Agent,并完成基本配置。 2. 配置Zabbix Agent:在MySQL服务器上的Zabbix Agent配置文件(通常是/etc/zabbix/...
此脚本文件用于zabbix监控redis哨兵时收集redis sentinel监控信息。
在搭建监控MySQL数据库的Zabbix监控系统时,需要按照以下步骤配置相关文件和脚本。 首先,要配置Zabbix代理的配置文件,这是在Linux操作系统中实现的。配置文件路径为`/usr/local/zabbix/etc/zabbix_agentd.conf`,...
5. **配置过程**:安装并导入模板后,你需要在Zabbix中配置相应的主机,关联这个模板,并根据你的MySQL环境调整阈值和监控项。这涉及到Zabbix的Agent配置、服务端设置以及数据库权限的设定。 6. **报警机制**:...
Zabbix 监控 Mysql 的安装,此文档对于安装zabix 监控 Mysql 有非常大的作用,里面配置了 监控启动脚本,脚本内容非常完善,对于安装 zabbix 有非常大作用。
- **2.1 自带配置**: Zabbix Agent在`/etc/zabbix/zabbix_agentd.d/userparameter_mysql.conf`配置文件中预设了四个监控项:`mysql.status[*]`, `mysql.size[*]`, `mysql.ping`, 和 `mysql.version`。 - **2.2 ...
JMX是Java平台的标准管理框架,用于管理和监控Java应用程序。Zabbix可以通过JMX连接到Java应用服务器,如Tomcat、JBoss等,获取内存使用、线程状态、Garbage Collection等关键信息。 在Java环境中,集成Zabbix监控...
本教程将详细介绍如何利用Zabbix结合MySQL来创建一个监控系统,用于检查SVN(Subversion)主从版本库的版本一致性。通过这个自动化监控脚本,我们可以及时发现并处理版本不匹配的问题,确保数据的一致性和完整性。 ...
zabbix4.0监控mysql的xml文件
以上步骤介绍了一个从零开始配置Zabbix监控MySQL的过程,涵盖了监控和报警的基本操作。通过这些步骤,可以实现对MySQL数据库的实时监控,并通过及时报警来防范潜在的问题,确保系统的稳定性与可靠性。此外,熟练掌握...
https://blog.csdn.net/abel_dwh #zabbix监控mysql模版,已修改下载可直接导入监控
本篇文章将详细介绍如何使用Zabbix监控Tomcat,特别是通过JMX(Java Management Extensions)来监控Tomcat,并涉及到相关的jar包和Zabbix模板。 首先,让我们了解一下`cmdline-jmx`和`catalina-jmx`这两个标签所指...
山石系列zabbix监控模板
通过上述步骤,可以成功地使用 zabbix 对路由器进行监控,从而可以实时地监控路由器的状态,提高网络的可靠性和安全性。 zabbix 的监控功能非常强大,支持多种监控协议,包括 SNMP、TCP、ICMP 等,可以对路由器、...
《Zabbix监控系统深度实践》是一本专注于Zabbix监控系统的专业书籍,旨在帮助读者深入了解和掌握这个强大的开源监控解决方案。Zabbix是一款广泛应用于企业IT基础设施监控的工具,它能够实时监控网络状态、服务器性能...