- #951: Parse environment variables in the config file.
- #948: Cleanup config file and make default package version include all plugins (but commented).
- #927: Adds parsing of tags to the statsd input when using DataDog's dogstatsd extension
- #863: AMQP output: allow external auth. Thanks @ekini!
- #707: Improved prometheus plugin. Thanks @titilambert!
- #878: Added json serializer. Thanks @ch3lo!
- #880: Add the ability to specify the bearer token to the prometheus plugin. Thanks @jchauncey!
- #882: Fixed SQL Server Plugin issues
- #849: Adding ability to parse single values as an input data type.
- #844: postgres_extensible plugin added. Thanks @menardorama!
- #866: couchbase input plugin. Thanks @ljosa!
- #789: Support multiple field specification and
field*
in graphite templates. Thanks @chrusty! - #762: Nagios parser for the exec plugin. Thanks @titilambert!
- #848: Provide option to omit host tag from telegraf agent.
- #928: Deprecating the statsd "convert_names" options, expose separator config.
- #919: ipmi_sensor input plugin. Thanks @ebookbug!
- #945: KAFKA output: codec, acks, and retry configuration. Thanks @framiere!
- #890: Create TLS config even if only ssl_ca is provided.
- #884: Do not call write method if there are 0 metrics to write.
- #898: Put database name in quotes, fixes special characters in the database name.
- #656: No longer run
lsof
on linux to get netstat data, fixes permissions issue. - #907: Fix prometheus invalid label/measurement name key.
- #841: Fix memcached unix socket panic.
- #873: Fix SNMP plugin sometimes not returning metrics. Thanks @titiliambert!
- #934: phpfpm: Fix fcgi uri path. Thanks @rudenkovk!
- #805: Kafka consumer stops gathering after i/o timeout.
- #959: reduce mongodb & prometheus collection timeouts. Thanks @PierreF!
- Primarily this release was cut to fix #859
- #747: Start telegraf on install & remove on uninstall. Thanks @pierref!
- #794: Add service reload ability. Thanks @entertainyou!
- #692: Support InfluxDB retention policies
- #771: Default timeouts for input plugns. Thanks @PierreF!
- #758: UDP Listener input plugin, thanks @whatyouhide!
- #769: httpjson plugin: allow specifying SSL configuration.
- #735: SNMP Table feature. Thanks @titilambert!
- #754: docker plugin: adding
docker info
metrics to output. Thanks @titilambert! - #788: -input-list and -output-list command-line options. Thanks @ebookbug!
- #778: Adding a TCP input listener.
- #797: Provide option for persistent MQTT consumer client sessions.
- #799: Add number of threads for procstat input plugin. Thanks @titilambert!
- #776: Add Zookeeper chroot option to kafka_consumer. Thanks @prune998!
- #811: Add processes plugin for classifying total procs on system. Thanks @titilambert!
- #235: Add number of users to the
system
input plugin. - #826: "kernel" linux plugin for /proc/stat metrics (context switches, interrupts, etc.)
- #847:
ntpq
: Input plugin for running ntp query executable and gathering metrics.
- #748: Fix sensor plugin split on ":"
- #722: Librato output plugin fixes. Thanks @chrusty!
- #745: Fix Telegraf toml parse panic on large config files. Thanks @titilambert!
- #781: Fix mqtt_consumer username not being set. Thanks @chaton78!
- #786: Fix mqtt output username not being set. Thanks @msangoi!
- #773: Fix duplicate measurements in snmp plugin. Thanks @titilambert!
- #708: packaging: build ARM package
- #713: packaging: insecure permissions error on log directory
- #816: Fix phpfpm panic if fcgi endpoint unreachable.
- #828: fix net_response plugin overwriting host tag.
- #821: Remove postgres password from server tag. Thanks @menardorama!
- Bug in the build script broke deb and rpm packages.
- The pass/drop parameters have been renamed to fielddrop/fieldpass parameters, to more accurately indicate their purpose.
- There are also now namedrop/namepass parameters for passing/dropping based on the metric name.
- Experimental windows builds now available.
- #727: riak input, thanks @jcoene!
- #694: DNS Query input, thanks @mjasion!
- #724: username matching for procstat input, thanks @zorel!
- #736: Ignore dummy filesystems from disk plugin. Thanks @PierreF!
- #737: Support multiple fields for statsd input. Thanks @mattheath!
- #701: output write count shouldnt print in quiet mode.
- #746: httpjson plugin: Fix HTTP GET parameters.
- Users of the
exec
andkafka_consumer
(and the newnats_consumer
andmqtt_consumer
plugins) can now specify the incoming data format that they would like to parse. Currently supports: "json", "influx", and "graphite" - Users of message broker and file output plugins can now choose what data format they would like to output. Currently supports: "influx" and "graphite"
- More info on parsing incoming data formats can be found here
- More info on serializing outgoing data formats can be found here
- Telegraf now has an option
flush_buffer_when_full
that will flush the metric buffer whenever it fills up for each output, rather than dropping points and only flushing on a set time interval. This will default totrue
and is in the[agent]
config section.
- #652: CouchDB Input Plugin. Thanks @codehate!
- #655: Support parsing arbitrary data formats. Currently limited to kafka_consumer and exec inputs.
- #671: Dovecot input plugin. Thanks @mikif70!
- #680: NATS consumer input plugin. Thanks @netixen!
- #676: MQTT consumer input plugin.
- #683: PostGRES input plugin: add pg_stat_bgwriter. Thanks @menardorama!
- #679: File/stdout output plugin.
- #679: Support for arbitrary output data formats.
- #695: raindrops input plugin. Thanks @burdandrei!
- #650: net_response input plugin. Thanks @titilambert!
- #699: Flush based on buffer size rather than time.
- #682: Mesos input plugin. Thanks @tripledes!
- #443: Fix Ping command timeout parameter on Linux.
- #662: Change
[tags]
to[global_tags]
to fix multiple-plugin tags bug. - #642: Riemann output plugin issues.
- #394: Support HTTP POST. Thanks @gabelev!
- #715: Fix influxdb precision config panic. Thanks @netixen!
- Statsd timing measurements are now aggregated into a single measurement with fields.
- Graphite output now inserts tags into the bucket in alphabetical order.
- Normalized TLS/SSL support for output plugins: MQTT, AMQP, Kafka
verify_ssl
config option was removed from Kafka because it was actually doing the opposite of what it claimed to do (yikes). It's been replaced byinsecure_skip_verify
- #575: Support for collecting Windows Performance Counters. Thanks @TheFlyingCorpse!
- #564: features for plugin writing simplification. Internal metric data type.
- #603: Aggregate statsd timing measurements into fields. Thanks @marcinbunsch!
- #601: Warn when overwriting cached metrics.
- #614: PowerDNS input plugin. Thanks @Kasen!
- #617: exec plugin: parse influx line protocol in addition to JSON.
- #628: Windows perf counters: pre-vista support
- #595: graphite output should include tags to separate duplicate measurements.
- #599: datadog plugin tags not working.
- #600: datadog measurement/field name parsing is wrong.
- #602: Fix statsd field name templating.
- #612: Docker input panic fix if stats received are nil.
- #634: Properly set host headers in httpjson. Thanks @reginaldosousa!
- Telegraf now keeps a fixed-length buffer of metrics per-output. This buffer defaults to 10,000 metrics, and is adjustable. The buffer is cleared when a successful write to that output occurs.
- The docker plugin has been significantly overhauled to add more metrics and allow for docker-machine (incl OSX) support. See the readme for the latest measurements, fields, and tags. There is also now support for specifying a docker endpoint to get metrics from.
- #509: Flatten JSON arrays with indices. Thanks @psilva261!
- #512: Python 3 build script, add lsof dep to package. Thanks @Ormod!
- #475: Add response time to httpjson plugin. Thanks @titilambert!
- #519: Added a sensors input based on lm-sensors. Thanks @md14454!
- #467: Add option to disable statsd measurement name conversion.
- #534: NSQ input plugin. Thanks @allingeek!
- #494: Graphite output plugin. Thanks @titilambert!
- AMQP SSL support. Thanks @ekini!
- #539: Reload config on SIGHUP. Thanks @titilambert!
- #522: Phusion passenger input plugin. Thanks @kureikain!
- #541: Kafka output TLS cert support. Thanks @Ormod!
- #551: Statsd UDP read packet size now defaults to 1500 bytes, and is configurable.
- #552: Support for collection interval jittering.
- #484: Include usage percent with procstat metrics.
- #553: Amazon CloudWatch output. thanks @skwong2!
- #503: Support docker endpoint configuration.
- #563: Docker plugin overhaul.
- #285: Fixed-size buffer of points.
- #546: SNMP Input plugin. Thanks @titilambert!
- #589: Microsoft SQL Server input plugin. Thanks @zensqlmonitor!
- #573: Github webhooks consumer input. Thanks @jackzampolin!
- #471: httpjson request headers. Thanks @asosso!
- #506: Ping input doesn't return response time metric when timeout. Thanks @titilambert!
- #508: Fix prometheus cardinality issue with the
net
plugin - #499 & #502: php fpm unix socket and other fixes, thanks @kureikain!
- #543: Statsd Packet size sometimes truncated.
- #440: Don't query filtered devices for disk stats.
- #463: Docker plugin not working on AWS Linux
- #568: Multiple output race condition.
- #585: Log stack trace and continue on Telegraf panic. Thanks @wutaizeng!
- Linux packages have been taken out of
opt
, the binary is now in/usr/bin
and configuration files are in/etc/telegraf
- breaking change
plugins
have been renamed toinputs
. This was done becauseplugins
is too generic, as there are now also "output plugins", and will likely be "aggregator plugins" and "filter plugins" in the future. Additionally,inputs/
andoutputs/
directories have been placed in the root-levelplugins/
directory. - breaking change the
io
plugin has been renameddiskio
- breaking change plugin measurements aggregated into a single measurement.
- breaking change
jolokia
plugin: must use global tag/drop/pass parameters for configuration. - breaking change
twemproxy
plugin:prefix
option removed. - breaking change
procstat
cpu measurements are now prepended withcpu_time_
instead of onlycpu_
- breaking change some command-line flags have been renamed to separate words.
-configdirectory
->-config-directory
,-filter
->-input-filter
,-outputfilter
->-output-filter
- The prometheus plugin schema has not been changed (measurements have not been aggregated).
RHEL/CentOS users upgrading from 0.2.x to 0.10.0 will probably have their configurations overwritten by the upgrade. There is a backup stored at /etc/telegraf/telegraf.conf.$(date +%s).backup.
- Plugin measurements aggregated into a single measurement.
- Added ability to specify per-plugin tags
- Added ability to specify per-plugin measurement suffix and prefix.
(
name_prefix
andname_suffix
) - Added ability to override base plugin measurement name. (
name_override
)
- #427: zfs plugin: pool stats added. Thanks @allenpetersen!
- #428: Amazon Kinesis output. Thanks @jimmystewpot!
- #449: influxdb plugin, thanks @mark-rushakoff
- #430: Network statistics removed in elasticsearch 2.1. Thanks @jipperinbham!
- #452: Elasticsearch open file handles error. Thanks @jipperinbham!
- #412: Additional memcached stats. Thanks @mgresser!
- #410: Additional redis metrics. Thanks @vlaadbrain!
- #414: Jolokia plugin auth parameters
- #415: memcached plugin: support unix sockets
- #418: memcached plugin additional unit tests.
- #408: MailChimp plugin.
- #382: Add system wide network protocol stats to
net
plugin. - #401: Support pass/drop/tagpass/tagdrop for outputs. Thanks @oldmantaiter!
- breaking change The
kafka
plugin has been renamed tokafka_consumer
. and most of the config option names have changed. This only affects the kafka consumer plugin (not the output). There were a number of problems with the kafka plugin that led to it only collecting data once at startup, so the kafka plugin was basically non- functional. - Plugins can now be specified as a list, and multiple plugin instances of the same type can be specified, like this:
[[inputs.cpu]]
percpu = false
totalcpu = true
[[inputs.cpu]]
percpu = true
totalcpu = false
drop = ["cpu_time"]
- Riemann output added
- Aerospike plugin: tag changed from
host
->aerospike_host
- #379: Riemann output, thanks @allenj!
- #375: kafka_consumer service plugin.
- #392: Procstat plugin can now accept pgrep -f pattern, thanks @ecarreras!
- #383: Specify plugins as a list.
- #354: Add ability to specify multiple metrics in one statsd line. Thanks @MerlinDMC!
- 0.2.1 has a bug where all lists within plugins get duplicated, this includes lists of servers/URLs. 0.2.2 is being released solely to fix that bug
- #377: Fix for duplicate slices in inputs.
- Telegraf will no longer use docker-compose for "long" unit test, it has been
changed to just run docker commands in the Makefile. See
make docker-run
andmake docker-kill
.make test
will still run all unit tests with docker. - Long unit tests are now run in CircleCI, with docker & race detector
- Redis plugin tag has changed from
host
toserver
- HAProxy plugin tag has changed from
host
toserver
- UDP output now supported
- Telegraf will now compile on FreeBSD
- Users can now specify outputs as lists, specifying multiple outputs of the same type.
- #325: NSQ output. Thanks @jrxFive!
- #318: Prometheus output. Thanks @oldmantaiter!
- #338: Restart Telegraf on package upgrade. Thanks @linsomniac!
- #337: Jolokia plugin, thanks @saiello!
- #350: Amon output.
- #365: Twemproxy plugin by @codeb2cc
- #317: ZFS plugin, thanks @cornerot!
- #364: Support InfluxDB UDP output.
- #370: Support specifying multiple outputs, as lists.
- #372: Remove gosigar and update go-dockerclient for FreeBSD support. Thanks @MerlinDMC!
- #331: Dont overwrite host tag in redis plugin.
- #336: Mongodb plugin should take 2 measurements.
- #351: Fix continual "CREATE DATABASE" in writes
- #360: Apply prefix before ShouldPass check. Thanks @sotfo!
- The -test flag will now only output 2 collections for plugins that need it
- There is a new agent configuration option:
flush_interval
. This option tells Telegraf how often to flush data to InfluxDB and other output sinks. For example, users can setinterval = "2s"
andflush_interval = "60s"
for Telegraf to collect data every 2 seconds, and flush every 60 seconds. precision
andutc
are no longer valid agent config values.precision
has moved to theinfluxdb
output config, where it will continue to default to "s"- debug and test output will now print the raw line-protocol string
- Telegraf will now, by default, round the collection interval to the nearest
even interval. This means that
interval="10s"
will collect every :00, :10, etc. To ease scale concerns, flushing will be "jittered" by a random amount so that all Telegraf instances do not flush at the same time. Both of these options can be controlled via theround_interval
andflush_jitter
config options. - Telegraf will now retry metric flushes twice
- #205: Include per-db redis keyspace info
- #226: Add timestamps to points in Kafka/AMQP outputs. Thanks @ekini
- #90: Add Docker labels to tags in docker plugin
- #223: Add port tag to nginx plugin. Thanks @neezgee!
- #227: Add command intervals to exec plugin. Thanks @jpalay!
- #241: MQTT Output. Thanks @shirou!
- Memory plugin: cached and buffered measurements re-added
- Logging: additional logging for each collection interval, track the number of metrics collected and from how many inputs.
- #240: procstat plugin, thanks @ranjib!
- #244: netstat plugin, thanks @shirou!
- #262: zookeeper plugin, thanks @jrxFive!
- #237: statsd service plugin, thanks @sparrc
- #273: puppet agent plugin, thats @jrxFive!
- #280: Use InfluxDB client v2.
- #281: Eliminate need to deep copy Batch Points.
- #286: bcache plugin, thanks @cornerot!
- #287: Batch AMQP output, thanks @ekini!
- #301: Collect on even intervals
- #298: Support retrying output writes
- #300: aerospike plugin. Thanks @oldmantaiter!
- #322: Librato output. Thanks @jipperinbham!
- #228: New version of package will replace old one. Thanks @ekini!
- #232: Fix bashism run during deb package installation. Thanks @yankcrime!
- #261: RabbitMQ panics if wrong credentials given. Thanks @ekini!
- #245: Document Exec plugin example. Thanks @ekini!
- #264: logrotate config file fixes. Thanks @linsomniac!
- #290: Fix some plugins sending their values as strings.
- #289: Fix accumulator panic on nil tags.
- #302: Fix
[tags]
getting applied, thanks @gotyaoi!
- InfluxDB output config change:
url
is nowurls
, and is a list. Config files will still be backwards compatible if onlyurl
is specified. - The -test flag will now output two metric collections
- Support for filtering telegraf outputs on the CLI -- Telegraf will now
allow filtering of output sinks on the command-line using the
-outputfilter
flag, much like how the-filter
flag works for inputs. - Support for filtering on config-file creation -- Telegraf now supports
filtering to -sample-config command. You can now run
telegraf -sample-config -filter cpu -outputfilter influxdb
to get a config file with only the cpu plugin defined, and the influxdb output defined. - Breaking Change: The CPU collection plugin has been refactored to fix some bugs and outdated dependency issues. At the same time, I also decided to fix a naming consistency issue, so cpu_percentageIdle will become cpu_usage_idle. Also, all CPU time measurements now have it indicated in their name, so cpu_idle will become cpu_time_idle. Additionally, cpu_time measurements are going to be dropped in the default config.
- Breaking Change: The memory plugin has been refactored and some measurements have been renamed for consistency. Some measurements have also been removed from being outputted. They are still being collected by gopsutil, and could easily be re-added in a "verbose" mode if there is demand for it.
- #143: InfluxDB clustering support
- #181: Makefile GOBIN support. Thanks @Vye!
- #203: AMQP output. Thanks @ekini!
- #182: OpenTSDB output. Thanks @rplessl!
- #187: Retry output sink connections on startup.
- #220: Add port tag to apache plugin. Thanks @neezgee!
- #217: Add filtering for output sinks and filtering when specifying a config file.
- #170: Systemd support
- #175: Set write precision before gathering metrics
- #178: redis plugin, multiple server thread hang bug
- Fix net plugin on darwin
- #84: Fix docker plugin on CentOS. Thanks @neezgee!
- #189: Fix mem_used_perc. Thanks @mced!
- #192: Increase compatibility of postgresql plugin. Now supports versions 8.1+
- #203: EL5 rpm support. Thanks @ekini!
- #206: CPU steal/guest values wrong on linux.
- #212: Add hashbang to postinstall script. Thanks @ekini!
- #212: Fix makefile warning. Thanks @ekini!
- Telegraf will now write data in UTC at second precision by default
- Now using Go 1.5 to build telegraf
- #150: Add Host Uptime metric to system plugin
- #158: Apache Plugin. Thanks @KPACHbIuLLIAnO4
- #159: Use second precision for InfluxDB writes
- #165: Add additional metrics to mysql plugin. Thanks @nickscript0
- #162: Write UTC by default, provide option
- #166: Upload binaries to S3
- #169: Ping plugin
- #38: Kafka output producer.
- #133: Add plugin.Gather error logging. Thanks @nickscript0!
- #136: Add a -usage flag for printing usage of a single plugin.
- #137: Memcached: fix when a value contains a space
- #138: MySQL server address tag.
- #142: Add Description and SampleConfig funcs to output interface
- Indent the toml config file for readability
- #128: system_load measurement missing.
- #129: Latest pkg url fix.
- #131: Fix memory reporting on linux & darwin. Thanks @subhachandrachandra!
- #140: Memory plugin prec->perc typo fix. Thanks @brunoqc!
- #112: Datadog output. Thanks @jipperinbham!
- #116: Use godep to vendor all dependencies
- #120: Httpjson plugin. Thanks @jpalay & @alvaromorales!
- #113: Update README with Telegraf/InfluxDB compatibility
- #118: Fix for disk usage stats in Windows. Thanks @srfraser!
- #122: Fix for DiskUsage segv fault. Thanks @srfraser!
- #126: Nginx plugin not catching net.SplitHostPort error
- #54: MongoDB plugin. Thanks @jipperinbham!
- #55: Elasticsearch plugin. Thanks @brocaar!
- #71: HAProxy plugin. Thanks @kureikain!
- #72: Adding TokuDB metrics to MySQL. Thanks vadimtk!
- #73: RabbitMQ plugin. Thanks @ianunruh!
- #77: Automatically create database.
- #79: Nginx plugin. Thanks @codeb2cc!
- #86: Lustre2 plugin. Thanks srfraser!
- #91: Unit testing
- #92: Exec plugin. Thanks @alvaromorales!
- #98: LeoFS plugin. Thanks @mocchira!
- #103: Filter by metric tags. Thanks @srfraser!
- #106: Options to filter plugins on startup. Thanks @zepouet!
- #107: Multiple outputs beyong influxdb. Thanks @jipperinbham!
- #108: Support setting per-CPU and total-CPU gathering.
- #111: Report CPU Usage in cpu plugin. Thanks @jpalay!
- #85: Fix GetLocalHost testutil function for mac users
- #89: go fmt fixes
- #94: Fix for issue #93, explicitly call sarama.v1 -> sarama
- #101: switch back from master branch if building locally
- #99: update integer output to new InfluxDB line protocol format
- #56: Update README for Kafka plugin. Thanks @EmilS!
- #50: Fix init.sh script to use telegraf directory. Thanks @jseriff!
- #52: Update CHANGELOG to reference updated directory. Thanks @benfb!
- #45: Skip disk tags that don't have a value. Thanks @jhofeditz!
- #43: Fix bug in MySQL plugin. Thanks @marcosnils!
- #12: Add Linux/ARM to the list of built binaries. Thanks @voxxit!
- #14: Clarify the S3 buckets that Telegraf is pushed to.
- #16: Convert Redis to use URI, support Redis AUTH. Thanks @jipperinbham!
- #21: Add memcached plugin. Thanks @Yukki!
- #13: Fix the packaging script.
- #19: Add host name to metric tags. Thanks @sherifzain!
- #20: Fix race condition with accumulator mutex. Thanks @nkatsaros!
- #23: Change name of folder for packages. Thanks @colinrymer!
- #32: Fix spelling of memoory -> memory. Thanks @tylernisonoff!
This is the initial release of Telegraf.