• YOUYOU深入学习Ganglia之三(gmetad的软件架构)


    Ganglia这个东西,目前的情况是测试的多,真正在数据中心部署过的人少;使用的多,真正能了解其代码架构的人少。这里根据我的经验,分解一下ganglia的gmetad的软件架构,欢迎大家交流。


    上面的图片是我本人自己总结的。MongoDB部分是我增加的,读者大可以略去不看。

    从上面的图中,读者可以发现以下信息:

    1 针对每一个cluster,gmetad都会开启一个线程来处理,这就要求,凡是线程里面用到的函数,必须是可重入的,全局变量必须加互斥量。

    2 Data Thread主要的作用是分析XML文件,这里面使用的工具叫做Expat,这个工具采用信号的方式解析XML文件。通过这个XML分析可以获取所有主机的数据。

    3 Server Thread我没有研究过,我认为的主要功能是想上一级gmetad返回XML数据。

    4 XML文件是什么样子的?可以参考下图,但是Gmond返回的XML和Gmetad返回的XML是不同的,但是大体结构相同。建议读者自己存储gmetad中的xml的buf,可以获取你自己的xml文件。


    在整个gmetad中,向rrd中插入数据的代码中三处:

    1 解析host主机数据时,向rrd中插入所有主机数据

    2 解析host主机后,end cluster时,向rrd中插入cluster的summary

    3 在主进程中,向rrd中插入grid的summary

    以上是gmetad的大体软件架构,大家有什么不明白的可以向我提问,我会做出解答。

  • 相关阅读:
    基于FPGA的均值滤波算法实现
    QuartusII 13.0 PLL IP Core调用及仿真
    varnish-4.x VCL之grace mode
    varnish-4.x VCL之cookie及缓存时间
    varnish-4.x VCL之强制cache miss
    Mariadb-Galera10二进制包安装
    MariaDB Replication
    MariaDB 使用CONNECT存储引擎
    MariaDB 使用TokuDB存储引擎
    Ubuntu启用VNC服务的配置
  • 原文地址:https://www.cnblogs.com/dyllove98/p/3165423.html
Copyright © 2020-2023  润新知