依赖关系解决

sudo yum -y install bitmap bitmap-fonts Django pycairo python-devel python-ldap python-memcached mod_wsgi mod_python python-sqlite2 glibc-devel gcc gcc-c++ git openssl-devel  httpd memcached python-hashlib django-tagging  python-simplejson pip

安装Twisted和zope.interface

Twisted需要配合zope.interface 3.6以上版本使用

wget --no-check-certificate https://pypi.python.org/packages/source/z/zope.interface/zope.interface-4.1.1.tar.gz
 tar xvf zope.interface-4.1.1.tar.gz -C ../src/
 cd ../src/zope.interface-4.1.1/
 sudo python setup.py install
wget --no-check-certificate https://pypi.python.org/packages/source/T/Twisted/Twisted-14.0.1.tar.bz2
 tar xvf Twisted-14.0.1.tar.bz2 -C ../src/
 cd ../src/Twisted-14.0.1/
 sudo python setup.py install

安装步骤

mkdir /home/test/graphite
cd /home/test/graphite
sudo pip install https://github.com/graphite-project/ceres/tarball/master
sudo pip install carbon --install-option="--prefix=/home/test/graphite" --install-option="--install-lib=/home/test/graphite/lib"
sudo pip install whisper (后面千万不要添加参数,否则会导致whisper安装失败的)
sudo pip install graphite-web --install-option="--prefix=/home/test/graphite" --install-option="--install-lib=/home/test/graphite/webapp"

sudo pip install daemonize
vi /home/test/graphite/lib/carbon/util.py
  改from twisted.scripts._twistd_unix import daemonize 变成 import daemonize

初始化配置

cd /home/test/graphite/conf
cp carbon.conf.example carbon.conf
cp storage-schemas.conf.example storage-schemas.conf
cp graphite.wsgi.example graphite.wsgi
cp /home/test/graphite/examples/example-graphite-vhost.conf /etc/httpd/conf.d/graphite-vhost.conf
vi  /etc/httpd/conf.d/graphite-vhost.conf
  WSGISocketPrefix /home/test/graphite/wsgi
  同时修改所有opt为home/test,并修改User和Group都为test
chown -R test.test /var/run/httpd/
mkdir /home/test/graphite/wsgi
vi /home/test/graphite/conf/graphite.wsgi
  修改为sys.path.append('/home/test/graphite/webapp')
vi /home/test/graphite/conf/storage-schemas.conf
  配置数据存储的时间点及数据保存时长

为了防止whisper的产生数据过多,占用/分区的磁盘空间,需要转移至/data目录下

cd /home/test/graphite/storage/
mkdir -pv /data/whisper_new/
ln -s /data/whisper_new/  whisper

初始化数据库并启动服务:

sudo chown -R test.test /home/test/graphite
cd /home/test/graphite/webapp/graphite/
cp local_settings.py.example local_settings.py
vi local_settings.py
  # 修改GRAPHITE_ROOT、WHISPER_DIR、DATABASES等参数
 GRAPHITE_ROOT = '/home/test/graphite'
 WHISPER_DIR = '/home/test/graphite/storage/whisper'
 DATABASES = {
    'default': {
        'NAME': '/home/test/graphite/storage/graphite.db',
        'ENGINE': 'django.db.backends.sqlite3',
        'USER': '',
        'PASSWORD': '',
        'HOST': '',
        'PORT': ''
    }
}

python manage.py syncdb # 注:初始化数据库时设定用户test,邮箱jie.yu@test100.com,密码test12345,这也是web界面的登录账号和密码

sudo /etc/init.d/httpd restart
cd /home/test/graphite/
./bin/carbon-cache.py start

测试

手动生成数据

echo "local.random.diceroll 4 `date +%s`" | nc -q0 127.0.0.1 2003

测试程序生成数据:

cd /home/test/graphite/examples/
python example-client.py

启动多个carbon-cache,并使用carbon-relay调度metrics至各carbon-cache

vi /home/test/graphite/conf/carbon.conf
  添加instance-b和instance-c
 [cache:b]
 LINE_RECEIVER_PORT = 2103
 PICKLE_RECEIVER_PORT = 2104
 CACHE_QUERY_PORT = 7102

 [cache:c]
 LINE_RECEIVER_PORT = 2203
 PICKLE_RECEIVER_PORT = 2204
 CACHE_QUERY_PORT = 7202

分别启动instance-b和instance-c

cd /home/test/graphite
bin/carbon-cache.py --instance=b start
bin/carbon-cache.py --instance=c start

配置relay并启动

vi /home/test/graphite/conf/carbon.conf # 修改relay配置
[relay]
LINE_RECEIVER_INTERFACE = 0.0.0.0
LINE_RECEIVER_PORT = 2013
PICKLE_RECEIVER_INTERFACE = 0.0.0.0
PICKLE_RECEIVER_PORT = 2014
DESTINATIONS = 127.0.0.1:2004:a, 127.0.0.1:2104:b, 127.0.0.1:2204:c
同时可定义relay规则:
vi /home/test/graphite/conf/relay-rules.conf
[servers]
pattern = ^servers\.
destinations = 127.0.0.1:2004:a, 127.0.0.1:2104:b, 127.0.0.1:2204:c
[default]
default = true
destinations = 127.0.0.1:2004:a, 127.0.0.1:2104:b, 127.0.0.1:2204:c
启动relay程序:
cd /home/test/graphite
./bin/carbon-relay.py start
然后修改各diamond.conf的配置文件中连接carbon的端口号为carbon-relay的端口2013和2014

其它

检查graphite的依赖关系

wget http://launchpad.net/graphite/0.9/0.9.9/+download/graphite-web-0.9.9.tar.gz
tar zxvf graphite-web-0.9.9.tar.gz -C ../src
cd /home/test/software/src/graphite-web-0.9.9/
python check-dependencies.py