https://github.com/influxdata/telegraf Go The plugin-driven server agent for collecting & reporting metrics.
Telegraf
Telegraf is an agent for collecting, processing, aggregating, and writing metrics.
Design goals are to have a minimal memory footprint with a plugin system so
that developers in the community can easily add support for collecting
metrics.
Telegraf is plugin-driven and has the concept of 4 distinct plugin types:
Input Plugins collect metrics from the system, services, or 3rd party APIs
Processor Plugins transform, decorate, and/or filter metrics
Aggregator Plugins create aggregate metrics (e.g. mean, min, max, quantiles, etc.)
Output Plugins write metrics to various destinations
New plugins are designed to be easy to contribute, pull requests are welcomed
and we work to incorporate as many pull requests as possible.
Try in Browser 🚀
You can try Telegraf right in your browser in the Telegraf playground .
Contributing
There are many ways to contribute:
Minimum Requirements
Telegraf shares the same minimum requirements as Go:
Linux kernel version 2.6.23 or later
Windows 7 or later
FreeBSD 11.2 or later
MacOS 10.11 El Capitan or later
Installation:
You can download the binaries directly from the downloads page
or from the releases section.
Ansible Role:
Ansible role: https://github.com/rossmcdonald/telegraf
From Source:
Telegraf requires golang version 1.12 or newer, the Makefile requires GNU make.
Install Go >=1.12 (1.13 recommended)
Install dep ==v0.5.0
Download Telegraf source:
go get -d github.com/influxdata/telegraf
Run make from the source directory
cd "$HOME/go/src/github.com/influxdata/telegraf"
make
Changelog
View the changelog for the latest updates and changes by
version.
Nightly Builds
These builds are generated from the master branch:
How to use it:
See usage with:
telegraf --help
Generate a telegraf config file:
telegraf config > telegraf.conf
Generate config with only cpu input & influxdb output plugins defined:
telegraf --input-filter cpu --output-filter influxdb config
Run a single telegraf collection, outputing metrics to stdout:
telegraf --config telegraf.conf --test
Run telegraf with all plugins defined in config file:
telegraf --config telegraf.conf
Run telegraf, enabling the cpu & memory input, and influxdb output plugins:
telegraf --config telegraf.conf --input-filter cpu:mem --output-filter influxdb
Documentation
Latest Release Documentation .
For documentation on the latest development code see the documentation index .
Input Plugins
activemq
aerospike
amqp_consumer (rabbitmq)
apache
apcupsd
aurora
aws cloudwatch (Amazon Cloudwatch)
azure_storage_queue
bcache
beanstalkd
bind
bond
burrow
cassandra (deprecated, use jolokia2 )
ceph
cgroup
chrony
cisco_telemetry_gnmi
cisco_telemetry_mdt
cloud_pubsub Google Cloud Pub/Sub
cloud_pubsub_push Google Cloud Pub/Sub push endpoint
conntrack
consul
couchbase
couchdb
cpu
DC/OS
diskio
disk
disque
dmcache
dns query time
docker
docker_log
dovecot
aws ecs (Amazon Elastic Container Service, Fargate)
elasticsearch
ethtool
exec (generic executable plugin, support JSON, influx, graphite and nagios)
fail2ban
fibaro
file
filestat
filecount
fireboard
fluentd
github
graylog
haproxy
hddtemp
httpjson (generic JSON-emitting http service plugin)
http_listener (deprecated, renamed to influxdb_listener )
http_listener_v2
http (generic HTTP plugin, supports using input data formats)
http_response
icinga2
influxdb
influxdb_listener
internal
interrupts
ipmi_sensor
ipset
iptables
ipvs
jenkins
jolokia2 (java, cassandra, kafka)
jolokia (deprecated, use jolokia2 )
jti_openconfig_telemetry
kafka_consumer
kapacitor
aws kinesis (Amazon Kinesis)
kernel
kernel_vmstat
kibana
kubernetes
kube_inventory
leofs
linux_sysctl_fs
logparser
logstash
lustre2
mailchimp
marklogic
mcrouter
memcached
mem
mesos
minecraft
mongodb
mqtt_consumer
multifile
mysql
nats_consumer
nats
neptune_apex
net
net_response
netstat
nginx
nginx_plus_api
nginx_plus
nginx_upstream_check
nginx_vts
nsq_consumer
nsq
nstat
ntpq
nvidia_smi
openldap
openntpd
opensmtpd
openweathermap
pf
pgbouncer
phpfpm
phusion passenger
ping
postfix
postgresql_extensible
postgresql
powerdns
powerdns_recursor
processes
procstat
prometheus (can be used for Caddy server )
puppetagent
rabbitmq
raindrops
redis
rethinkdb
riak
salesforce
sensors
smart
snmp_legacy
snmp
snmp_trap
socket_listener
solr
sql server (microsoft)
stackdriver
statsd
suricata
swap
synproxy
syslog
sysstat
systemd_units
system
tail
temp
tcp_listener
teamspeak
tengine
tomcat
twemproxy
udp_listener
unbound
uswgi
varnish
vsphere VMware vSphere
webhooks
win_perf_counters (windows performance counters)
win_services
wireless
x509_cert
zfs
zipkin
zookeeper
Parsers
Serializers
Processor Plugins
Aggregator Plugins
Output Plugins