编程开源技术交流,分享技术与知识

网站首页 > 开源技术 正文

ganglia 介绍及安装部署(安装gawk)

wxchong 2024-10-18 14:16:20 开源技术 9 ℃ 0 评论

一:介绍

Ganglia是UC Berkeley发起的一个开源集群监视项目,设计用于测量数以千计的节点。Ganglia的核心包含gmond、gmetad以及一个Web前端。主要是用来监控系统性能,如:cpu 、mem、硬盘利用率, I/O负载、网络流量情况等,通过曲线很容易见到每个节点的工作状态,对合理调整、分配系统资源,提高系统整体性能起到重要作用

每台计算机都运行一个收集和发送度量数据的名为 gmond 的守护进程。接收所有度量数据的主机可以显示这些数据并且可以将这些数据的精简表单传递到层次结构中。正因为有这种层次结构模式,才使得 Ganglia 可以实现良好的扩展。gmond 带来的系统负载非常少,这使得它成为在集群中各台计算机上运行的一段代码,而不会影响用户性能。所有这些数据多次收集会影响节点性能。网络中的 “抖动”发生在大量小消息同时出现时,可以通过将节点时钟保持一致,来避免这个问题。

gmetad可以部署在集群内任一台节点或者通过网络连接到集群的独立主机,它通过单播路由的方式与gmond通信,收集区域内节点的状态信息,并以XML数据的形式,保存在数据库中。

由RRDTool工具处理数据,并生成相应的的图形显示,以Web方式直观的提供给客户端

Ganglia包括如下几个程序,他们之间通过XDR(xml的压缩格式)或者XML格式传递监控数据,达到监控效果。集群内的节点,通过运行gmond收集发布节点状态信息,然后gmetad周期性的轮询gmond收集到的信息,然后存入rrd数据库,通过web服务器可以对其进行查询展示

Gmond组件

Gmond组件

Gmond组件部署于集群中各个被监控的节点。其主要功能是从操作系统或指定的主机收集状态信息。其收集主机状态信息的方式灵活,状态信息均以XML格式进行传输。Gmond组件可以级联形成层次结构,这种层次结构使得Ganglia拥有良好的可扩展性。另外,Gmond组件带来的系统负载非常少,对用户的影响非常小。Gmond组件的工作模式有两种:单播和多播。单播模式下,Gmond组件发送其收集的主机状态信息到指定的一个或多个节点,可以跨网段;多播模式下,Gmond组件发送其监控的主机状态信息到同一网段内的所有节点,同时还接收同一网段内其他节点发送的状态信息。


Gmetad组件

Gmetad组件可以部署于集群中的某一节点,也可以部署于集群外的某一专门服务器,其主要功能是周期性地从指定的Gmond组件或其他Gmetad组件拉取数据,并将拉取的数据存储在本地数据库。这些存储的状态信息供Ganglia-Web组件使用。

Ganglia-Web组件

Ganlgia-Web组件和Gmetad组件须部署于同一节点,它通过数据库轮询的方式从Gmetad组件中获取状态信息,并以web形式图形化地展示各个节点的状态信息。


二:拓扑

三:安装

1.安装依赖包

yum -y install apr-develapr-util check-devel cairo-devel pango-devel libxml2-devel rpmbuild glib2-develdbus-devel freetype-devel fontconfig-devel gcc-c++ expat-devel python-devel libXrender-devel

yum -y install php php-gd php-xml php-bcmath php-mbstring php-mysql apr

yum -y install gcc glibc glibc-common rrdtool rrdtool-devel apr apr-devel expat expat-devel pcre pcre-devel dejavu-lgc-sans-mono-fonts dejavu-sans-mono-fonts

confuse

需要rpm 安装

2.检测依赖

rpm -q gcc glibc glibc-common rrdtool rrdtool-devel apr apr-devel expat expat-devel pcre pcre-devel dejavu-lgc-sans-mono-fonts dejavu-sans-mono-fonts

3.增加库支持

vi /etc/ld.so.conf

/usr/local/lib

/usr/local/lib64

启用配置

ldconfig

检查是否生效

ldconfig -v |grep "libpython2.7.so"

Ganglia监控服务的主节点需要安装:

ganglia

ganglia-web

php

apache

Ganglia被监控从节点需要安装:

ganglia

安装路径规划

ganglia安装路径

/usr/local/ganglia

php安装路径

yum 安装

apache安装路径

yum 安装

ganglia-web安装路径

/var/www/html/ganglia-web

rrds数据路径

/data/ganglia/rrds

3.安装ganglia (全部节点都要安装)

tar -zxf ganglia-3.6.1.tar.gz

cd ganglia-3.6.0

./configure --prefix=/usr/local/ganglia --with-gmetad --enable-gexec --with-python=/usr/local

make && make install

vi conf.php 调整为如下内容

$conf['gweb_confdir'] = "/var/www/html/ganglia-web";

$conf['gmetad_root'] = "/var/www";

vi header.php 添加时区

session_start();

ini_set('date.timezone','PRC');

//修改时区为本地时区

配置临时目录

cd /var/www/html/ganglia-web/dwoo

mkdir cache compiled

chmod 777 cache compiled

安装apache 及 php

yum -y install mysql-devel httpd php php-mysql

配置apache

vi /etc/httpd/conf/httpd.conf

User daemon Group daemon

修改为

User apache Group apache

然后找到

  DirectoryIndex index.html

修改为

  DirectoryIndex index.html index.php


接着增加如下内容:

AddType application/x-httpd-php .php

配置gmetad (主节点配置)

cd /usr/local/src/ganglia-3.6.1

cp ./gmetad/gmetad.init /etc/init.d/gmetad

cp ./gmetad/gmetad.conf /usr/local/ganglia/etc/

vi /etc/init.d/gmetad --修改如下内容

GMETAD=/usr/local/ganglia/sbin/gmetad

vi /usr/local/ganglia/etc/gmetad.conf -- 修改如下内容

data_source "hk gandlia" 10 ganglia_svr

xml_port 8651

interactive_port 8652

rrd_rootdir "/var/www/rrds"

case_sensitive_hostnames 0

修改rrds数据目录所有者

chown -R nobody:nobody /var/www/rrds

启动gmetad服务,并设为开机自动运行

service gmetad restart

chkconfig --add gmetad

配置gmond (全部节点配置)

cd /usr/local/src/ganglia-3.6.1

cp ./gmond/gmond.init /etc/init.d/gmond

./gmond/gmond -t > /usr/local/ganglia/etc/gmond.conf

vi /etc/init.d/gmond --修改如下内容

GMOND=/usr/local/ganglia/sbin/gmond

vi /usr/local/ganglia/etc/gmond.conf -- 修改如下内容

cluster {

name = "hk gandlia"

owner = "nobody"

latlong = "unspecified"

url = "unspecified"

}

复制python module到ganglia部署目录

mkdir /usr/local/ganglia/lib64/ganglia/python_modules

cp ./gmond/python_modules/*/*.py /usr/local/ganglia/lib64/ganglia/python_modules

安装程序ganglia-3.6.0默认提供了一些python module的配置文件,只需要部署到 /usr/local/ganglia/etc/conf.d 目录下面即可生效

若对默认提供的这些监控脚本不太关心,可以跳过下面这步:

mkdir /usr/local/ganglia/etc/conf.d

cp ./gmond/python_modules/conf.d/*.pyconf /usr/local/ganglia/etc/conf.d

启动gmond服务,并设为开机自动运行

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表