hi all,
I am trying to separate each of the components of graphite engines into a small pieces such that it is agile and easy to duplicate when you need to scale out. I have built my first graphite-web container and contributed to github. I will continue to work on the carbon-cache Dockerfile and others components.
Graphite-web: https://github.com/yenonn/docker-graphite
Monday, June 13, 2016
Thursday, June 9, 2016
Setting up a graphite service in CENTOS 7.2
hi all,
I just want list down the steps of graphite installation on CENTOS7.2.
First you have to install the pre-requisite of the packages.
1. yum -y install epel-release python-pip python-devel gcc libev libev-devel pycairo rrdtool-python mod_wsgi git httpd libffi-devel
2. pip install django carbon whisper graphite-web django-tagging pytz
3. pip install Twisted==16.0.0
Here are the packages that I used
Django==1.11.4
whisper==1.0.2
django-tagging==0.4.3
pytz==2017.2
Twisted==16.0.0
4. chmod a+w /opt/graphite/storage
Start copying the conf files and make changes.
5. cp /opt/graphite/conf/carbon.conf.example /opt/graphite/conf/carbon.conf
6. cp /opt/graphite/conf/graphite.wsgi.example /opt/graphite/conf/graphite.wsgi
7. cp /opt/graphite/conf/storage-schemas.conf.example /opt/graphite/conf/storage-schemas.conf
8. cp /opt/graphite/webapp/graphite/local_settings.py.example /opt/graphite/webapp/graphite/local_settings.py
Once you are done with the copying local_settings.py, please update that TIME_ZONE and SECRET_KEY. please use the tzselect if you don't know how to set your time zone. Secret key can be any strings that you can think of.
Now you are start working on your apache setting.
9. cp /opt/graphite/examples/example-graphite-vhost.conf /etc/httpd/conf.d/graphite-vhost.conf
Here is how the lines in graphite-vhost.conf should look like in Alias /content/ and Directory of /opt/graphite/conf
Comment out the extra mod_wsgi mod from another conf file.
10. cat /etc/httpd/conf.modules.d/10-wsgi.conf
#LoadModule wsgi_module modules/mod_wsgi.so
On the default /etc/httpd/conf/httpd.conf, you have to update the ServerName. After all you can start your web server service.
11. ServerName localhost:80
12. setenforce 0; systemctl enable httpd.service; systemctl start httpd.service
Now you can start initialise your django framework. Please complete all the questions asked during the initial setup. Put in your admin credential and email.
13. python /opt/graphite/webapp/graphite/manage.py migrate auth
14. python /opt/graphite/webapp/graphite/manage.py syncdb
13. PYTHONPATH=/opt/graphite/webapp django-admin.py migrate --settings=graphite.settings auth
14. PYTHONPATH=/opt/graphite/webapp django-admin.py syncdb
Please refer more updated information here on the webapp database setup. Now you can start working on the carbon daemon and start it.
15. python /opt/graphite/bin/carbon-cache.py start
[root@ip-172-31-24-138 ~]# python /opt/graphite/bin/carbon-cache.py start
Starting carbon-cache (instance a)
[root@ip-172-31-24-138 ~]# python /opt/graphite/bin/carbon-cache.py stop
Sending kill signal to pid 25259
[root@ip-172-31-24-138 graphite]# netstat -atun |grep 2003
tcp 0 0 0.0.0.0:2003 0.0.0.0:* LISTEN
Next you will need to verify your carbon port is listening and your web port is running.
16. netstat -atun | grep 2003
tcp 0 0 0.0.0.0:2003 0.0.0.0:* LISTEN
17. netstat -atun | grep 80
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN
Wait for a while, after you have started the services. You need to look into your graphite storage for any new whisper file been created. Keep prompt the directory for any new created whisper files.
18. [root@localhost ~]# find /opt/graphite/storage/ -name *.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/cache/size.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/cache/queries.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/cache/bulk_queries.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/cache/queues.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/cache/overflow.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/memUsage.wsp
I just want list down the steps of graphite installation on CENTOS7.2.
First you have to install the pre-requisite of the packages.
1. yum -y install epel-release python-pip python-devel gcc libev libev-devel pycairo rrdtool-python mod_wsgi git httpd libffi-devel
2. pip install django carbon whisper graphite-web django-tagging pytz
3. pip install Twisted==16.0.0
Here are the packages that I used
Django==1.11.4
whisper==1.0.2
django-tagging==0.4.3
pytz==2017.2
Twisted==16.0.0
4. chmod a+w /opt/graphite/storage
Start copying the conf files and make changes.
5. cp /opt/graphite/conf/carbon.conf.example /opt/graphite/conf/carbon.conf
6. cp /opt/graphite/conf/graphite.wsgi.example /opt/graphite/conf/graphite.wsgi
7. cp /opt/graphite/conf/storage-schemas.conf.example /opt/graphite/conf/storage-schemas.conf
8. cp /opt/graphite/webapp/graphite/local_settings.py.example /opt/graphite/webapp/graphite/local_settings.py
Once you are done with the copying local_settings.py, please update that TIME_ZONE and SECRET_KEY. please use the tzselect if you don't know how to set your time zone. Secret key can be any strings that you can think of.
Now you are start working on your apache setting.
9. cp /opt/graphite/examples/example-graphite-vhost.conf /etc/httpd/conf.d/graphite-vhost.conf
Here is how the lines in graphite-vhost.conf should look like in Alias /content/ and Directory of /opt/graphite/conf
Comment out the extra mod_wsgi mod from another conf file.
10. cat /etc/httpd/conf.modules.d/10-wsgi.conf
#LoadModule wsgi_module modules/mod_wsgi.so
On the default /etc/httpd/conf/httpd.conf, you have to update the ServerName. After all you can start your web server service.
11. ServerName localhost:80
12. setenforce 0; systemctl enable httpd.service; systemctl start httpd.service
Now you can start initialise your django framework. Please complete all the questions asked during the initial setup. Put in your admin credential and email.
14. python /opt/graphite/webapp/graphite/manage.py syncdb
14. PYTHONPATH=/opt/graphite/webapp django-admin.py syncdb
Please refer more updated information here on the webapp database setup. Now you can start working on the carbon daemon and start it.
15. python /opt/graphite/bin/carbon-cache.py start
[root@ip-172-31-24-138 ~]# python /opt/graphite/bin/carbon-cache.py start
Starting carbon-cache (instance a)
[root@ip-172-31-24-138 ~]# python /opt/graphite/bin/carbon-cache.py stop
Sending kill signal to pid 25259
[root@ip-172-31-24-138 graphite]# netstat -atun |grep 2003
tcp 0 0 0.0.0.0:2003 0.0.0.0:* LISTEN
Next you will need to verify your carbon port is listening and your web port is running.
16. netstat -atun | grep 2003
tcp 0 0 0.0.0.0:2003 0.0.0.0:* LISTEN
17. netstat -atun | grep 80
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN
Wait for a while, after you have started the services. You need to look into your graphite storage for any new whisper file been created. Keep prompt the directory for any new created whisper files.
18. [root@localhost ~]# find /opt/graphite/storage/ -name *.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/cache/size.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/cache/queries.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/cache/bulk_queries.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/cache/queues.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/cache/overflow.wsp
/opt/graphite/storage/whisper/carbon/agents/localhost_localdomain-a/memUsage.wsp
Once all done, your graphite should be up and running. you can open your browser and go to your graphite web service to verify it is running. At this moment, you should not seeing any data injection from any servers yet. you need to continue working on collectd installation on the client nodes.
Subscribe to:
Posts (Atom)