网站首页 > 开源技术 正文
一:介绍
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服务,并设为开机自动运行
猜你喜欢
- 2024-10-18 基础|脑小血管病的概念与病理知识学习笔记
- 2024-10-18 键盘侠|老詹影响力不如库里AI的真相??美网友:超人我模仿不来
- 2024-10-18 病例分享:诡异的脑出血(脑出血的典型案例)
- 2024-10-18 眩晕是多种疾病的共同症状,轻则自愈,重则危及生命
- 2024-10-18 解剖收藏:神经解剖学——脊神经(脊神经结构)
- 2024-10-18 基础|重要神经结构的血供示意图(神经主要功能)
- 2024-10-18 提醒:胸前疼痛,不一定是心脏病,还可能是4个原因,别不当回事
- 2024-10-18 强迫症:被忽视的“自身免疫性疾病”
- 2024-10-18 中枢神经系统 | 脑(中枢神经系统脑和脊髓)
- 2024-10-18 ganglia监控部署(监控措施)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)