2017-03-11 18:05:03 +08:00
|
|
|
graphite
|
|
|
|
========
|
|
|
|
|
|
|
|
[Graphite][1] does three things:
|
|
|
|
|
|
|
|
- Kick ass.
|
|
|
|
- Chew bubblegum.
|
|
|
|
- Make it easy to store and graph metrics.
|
|
|
|
|
2017-03-11 18:31:59 +08:00
|
|
|
## docker-compose.yml
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
graphite:
|
|
|
|
image: vimagick/graphite
|
|
|
|
ports:
|
2017-06-28 18:03:57 +08:00
|
|
|
- "2003:2003"
|
2018-11-05 18:17:37 +08:00
|
|
|
- "2003:2003/udp"
|
2017-06-28 18:03:57 +08:00
|
|
|
- "2004:2004"
|
2018-11-05 18:17:37 +08:00
|
|
|
- "2023:2023"
|
|
|
|
- "2024:2024"
|
2017-06-28 18:03:57 +08:00
|
|
|
- "7002:7002"
|
|
|
|
- "8080:8080"
|
|
|
|
- "9001:9001"
|
2017-03-11 18:31:59 +08:00
|
|
|
volumes:
|
2018-01-24 15:30:34 +08:00
|
|
|
- ./data/conf:/opt/graphite/conf
|
|
|
|
- ./data/storage:/opt/graphite/storage
|
2017-03-11 18:31:59 +08:00
|
|
|
restart: always
|
|
|
|
```
|
|
|
|
|
|
|
|
## Up and Running
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ cd ~/fig/graphite
|
2018-01-24 15:30:34 +08:00
|
|
|
$ mkdir -p data/storage/log/webapp
|
2017-03-11 18:31:59 +08:00
|
|
|
$ docker-compose up -d
|
2017-03-12 07:20:49 +08:00
|
|
|
$ docker-compose exec graphite sh
|
2017-05-15 09:54:23 +08:00
|
|
|
>>> vi conf/storage-schemas.conf
|
2017-03-11 18:31:59 +08:00
|
|
|
>>> python webapp/manage.py migrate --run-syncdb --noinput
|
2018-01-27 15:24:28 +08:00
|
|
|
>>> python webapp/manage.py createsuperuser
|
|
|
|
>>> python webapp/manage.py changepassword
|
2018-11-05 18:17:37 +08:00
|
|
|
>>> supervisorctl status
|
|
|
|
carbon-aggregator RUNNING pid 9, uptime 0:00:13
|
|
|
|
carbon-cache RUNNING pid 8, uptime 0:00:22
|
|
|
|
graphite-webapp RUNNING pid 7, uptime 0:00:24
|
2017-03-11 18:31:59 +08:00
|
|
|
>>> exit
|
2018-01-24 15:30:34 +08:00
|
|
|
$ tree -F -L 4
|
2017-03-11 18:31:59 +08:00
|
|
|
├── data/
|
2018-01-24 15:30:34 +08:00
|
|
|
│ ├── conf/
|
2018-11-05 18:17:37 +08:00
|
|
|
│ │ ├── aggregation-rules.conf
|
2018-01-24 15:30:34 +08:00
|
|
|
│ │ ├── carbon.conf
|
2018-11-05 18:17:37 +08:00
|
|
|
│ │ ├── rewrite-rules.conf
|
2018-01-24 15:30:34 +08:00
|
|
|
│ │ └── storage-schemas.conf
|
|
|
|
│ └── storage/
|
|
|
|
│ ├── carbon-cache-a.pid
|
|
|
|
│ ├── graphite.db
|
|
|
|
│ ├── log/
|
|
|
|
│ │ └── webapp/
|
|
|
|
│ └── whisper/
|
|
|
|
│ └── carbon/
|
2017-03-11 18:31:59 +08:00
|
|
|
└── docker-compose.yml
|
|
|
|
$ curl http://localhost:8080
|
|
|
|
```
|
|
|
|
|
2017-05-15 09:54:23 +08:00
|
|
|
## storage-schemas.conf
|
|
|
|
|
|
|
|
```ini
|
|
|
|
[carbon]
|
|
|
|
pattern = ^carbon\.
|
|
|
|
retentions = 60:90d
|
|
|
|
|
2018-01-24 15:30:34 +08:00
|
|
|
[test_1day_for_1year]
|
2017-05-15 09:54:23 +08:00
|
|
|
pattern = ^test\.
|
|
|
|
retentions = 1d:1y
|
|
|
|
|
|
|
|
[default_1min_for_1day]
|
|
|
|
pattern = .*
|
|
|
|
retentions = 60s:1d
|
|
|
|
```
|
|
|
|
|
|
|
|
## Resize Whisper
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ docker-compose exec graphite sh
|
|
|
|
>>> cd storage/whisper/test
|
|
|
|
>>> find . -type f -name '*.wsp' -exec whisper-resize.py --nobackup {} 1d:1y \;
|
|
|
|
```
|
|
|
|
|
2017-03-11 18:05:03 +08:00
|
|
|
[1]: http://graphiteapp.org/
|