Graphite & Statsd can be complex to setup. This image will have you running & collecting stats in just a few minutes.
sudo docker run -d \
--name graphite \
--restart=always \
-p 80:80 \
-p 2003:2003 \
-p 8125:8125/udp \
-p 8126:8126 \
hopsoft/graphite-statsd
This starts a Docker container named: graphite
That's it, you're done ... almost.
- Nginx - reverse proxies the graphite dashboard
- Graphite - front-end dashboard
- Carbon - back-end
- Statsd - UDP based back-end proxy
Host | Container | Service |
---|---|---|
80 | 80 | nginx |
2003 | 2003 | carbon |
8125 | 8125 | statsd |
8126 | 8126 | admin |
Host | Container | Notes |
---|---|---|
DOCKER ASSIGNED | /opt/graphite | graphite config & stats storage |
DOCKER ASSIGNED | /etc/nginx | nginx config |
DOCKER ASSIGNED | /opt/statsd | statsd config |
DOCKER ASSIGNED | /etc/logrotate.d | logrotate config |
DOCKER ASSIGNED | /var/log | log files |
Built using Phusion's base image.
- All Graphite related processes are run as daemons & monitored with runit.
- Includes additional services such as logrotate.
Let's fake some stats with a random counter to prove things are working.
while true
do
echo -n "example.statsd.counter.changed:$(((RANDOM % 10) + 1))|c" | nc -w 1 -u localhost 8125
done
<CTL-C>
Open Graphite in a browser at http://localhost/dashboard.
Update the default Django admin user account. The default is insecure.
- username: root
- password: root
- email: [email protected]
First login at: http://localhost/account/login Then update the root user's profile at: http://localhost/admin/auth/user/1/
Read up on Graphite's post-install tasks. Focus on the storage-schemas.conf
- Stop the container
docker stop graphite
. - Find the configuration files on the host by inspecting the container
docker inspect graphite
. - Update the desired config files.
- Restart the container
docker start graphite
.
Note: If you change settings in /opt/graphite/conf/storage-schemas.conf
be sure to delete the old whisper files under /opt/graphite/storage/whisper/
.
Important: Ensure your Statsd flush interval is at least as long as the highest-resolution retention.
For example, if /opt/statsd/config.js
looks like this.
flushInterval: 10000
Ensure that storage-schemas.conf
retentions are no finer grained than 10 seconds.
[all]
pattern = .*
retentions = 5s:12h # WRONG
retentions = 10s:12h # OK
retentions = 60s:12h # OK
A management interface (default on port 8126) allows you to manage statsd and retrieve stats
# show all current counters
echo counters | nc localhost 8126
more info and additional commands: admin_interface
If running this image on cloud infrastructure such as AWS,
you should consider mounting /opt/graphite
& /var/log
on a larger volume.
-
Configure the host to mount a large EBS volume.
-
Specify the volume mounts when starting the container.
sudo docker run -d \ --name graphite \ --restart=always \ -v /path/to/ebs/graphite:/opt/graphite \ -v /path/to/ebs/log:/var/log \ -p 80:80 \ -p 2003:2003 \ -p 8125:8125/udp \ hopsoft/graphite-statsd
- Introduction to Docker
- Official Statsd Documentation
- Practical Guide to StatsD/Graphite Monitoring
- Configuring Graphite for StatsD
Build the image yourself.
git clone https://github.com/hopsoft/docker-graphite-statsd.git
cd docker-graphite-statsd
vagrant up
vagrant ssh
sudo docker build -t hopsoft/graphite-statsd /vagrant
Note: Pay attention to the forwarded ports in the Vagrantfile.
git clone https://github.com/hopsoft/docker-graphite-statsd.git
sudo docker build -t hopsoft/graphite-statsd ./docker-graphite-statsd