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 &