安装redislive
wget --no-check-certificate https://github.com/pypa/pip/archive/1.5.5.tar.gz
tar zvxf 1.5.5.tar.gz
cd pip-1.5.5
yum groupinstall "Development tools"
yum install zlib-devel
yum install bzip2-devel
yum install openssl-devel
yum install ncurses-devel
yum install sqlite-devel
wget --no-check-certificate https://www.python.org/ftp/python/2.7.9/Python-2.7.9.tar.xz
tar xf Python-2.7.9.tar.xz
cd Python-2.7.9
./configure --prefix=/usr/local
make && make altinstall
wget http://pypi.python.org/packages/2.7/s/setuptools/setuptools-0.6c11-py2.7.egg
sh setuptools-0.6c11-py2.7.egg
ln -s /usr/local/bin/python2.7 /usr/local/bin/python
python setup.py install
pip install tornado
pip install redis
pip install python-dateutil
git clone https://github.com/kumarnitin/RedisLive.git
cd /usr/local/src/RedisLive/src
mv redis-live.conf.example redis-live.conf
vim redis-live.conf
{
"RedisServers":
[
{
"server": "192.168.80.103",
"port" : 6379,
"password":"123456"
}
],
"DataStoreType" : "redis",
"RedisStatsServer":
{
"server" : "192.168.80.103",
"port" : 6385,
"password":"123456"
},
"SqliteStatsStore" :
{
"path": "/usr/local/src/RedisLive/src/db/redislive.sqlite"
}
}
~
RedisLive的功能分两个部分:
一个部分是redis-server状态数据的采集,通过src/redis-monitor.py来执行;
另外一部分功能是提供对状态数据的查询服务,通过src/redis-live.py来提供web服务。
在RedisServers中设置需要监控的redis-server;
整个配置实际上是一个json对象,RedisServers是redis服务器的信息,由于是数组类型所以配置多个redis实例。DataStoreType是监控信息的存储方式,有"redis"和" sqlite"两种方式,分别对应下面
RedisStatsServer和SqliteStatsStore,编辑完成后保存。
DataStoreType决定使用那种类型的数据存储,
如果是redis,使用RedisStatsServer作为数据存储的目标;
如果是sqlite,使用SqliteStatsStore作为数据存储的目标。
redis-live.py是用来启动web服务的,默认端口是8888 。redis-monitor.py就是redis监控的核心服务。
到此为止所有准备工作都完成了,最后来启动服务:
./redis-monitor.py --duration=30 //启动监控,duration是心跳时间
./redis-live.py //启动web服务,默认监听8888端口
然后在浏览器中打开 http://192.168.80.103:8888/index.html ,就可以看到监控信息了:
部署环境:
*/5 * * * * cd /data/Redis-Monitor/RedisLive/src; ./redis-monitor.py --duration 20 >/dev/null 2>&1
./redis-live.py &