From e2e15a9c08d839bf6718acccc1e01d51855ad1f2 Mon Sep 17 00:00:00 2001 From: Cameron Sparr Date: Thu, 3 Dec 2015 12:08:01 -0700 Subject: [PATCH] memcached plugin: support unix sockets closes #415 --- CHANGELOG.md | 1 + plugins/memcached/memcached.go | 48 ++++++++++++++++++++++++---------- 2 files changed, 35 insertions(+), 14 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 08a390994ebdb..d7e7485c9b925 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,6 +3,7 @@ ### Features - [#412](https://github.com/influxdb/telegraf/pull/412): Additional memcached stats. Thanks @mgresser! - [#410](https://github.com/influxdb/telegraf/pull/410): Additional redis metrics. Thanks @vlaadbrain! +- [#415](https://github.com/influxdb/telegraf/issues/415): memcached plugin: support unix sockets ### Bugfixes - [#405](https://github.com/influxdb/telegraf/issues/405): Prometheus output cardinality issue diff --git a/plugins/memcached/memcached.go b/plugins/memcached/memcached.go index 7186b1aaef953..e364b681f384d 100644 --- a/plugins/memcached/memcached.go +++ b/plugins/memcached/memcached.go @@ -13,7 +13,8 @@ import ( // Memcached is a memcached plugin type Memcached struct { - Servers []string + Servers []string + UnixSockets []string } var sampleConfig = ` @@ -21,7 +22,8 @@ var sampleConfig = ` # with optional port. ie localhost, 10.0.0.1:11211, etc. # # If no servers are specified, then localhost is used as the host. - servers = ["localhost"] + servers = ["localhost:11211"] + # unix_sockets = ["/var/run/memcached.sock"] ` var defaultTimeout = 5 * time.Second @@ -68,12 +70,18 @@ func (m *Memcached) Description() string { // Gather reads stats from all configured servers accumulates stats func (m *Memcached) Gather(acc plugins.Accumulator) error { - if len(m.Servers) == 0 { + if len(m.Servers) == 0 && len(m.UnixSockets) == 0 { return m.gatherServer(":11211", acc) } for _, serverAddress := range m.Servers { - if err := m.gatherServer(serverAddress, acc); err != nil { + if err := m.gatherServer(serverAddress, false, acc); err != nil { + return err + } + } + + for _, unixAddress := range m.UnixSockets { + if err := m.gatherServer(unixAddress, true, acc); err != nil { return err } } @@ -81,18 +89,30 @@ func (m *Memcached) Gather(acc plugins.Accumulator) error { return nil } -func (m *Memcached) gatherServer(address string, acc plugins.Accumulator) error { - _, _, err := net.SplitHostPort(address) - if err != nil { - address = address + ":11211" - } +func (m *Memcached) gatherServer( + address string, + unix bool, + acc plugins.Accumulator, +) error { + var conn net.Conn + if unix { + conn, err := net.DialTimeout("unix", address, defaultTimeout) + if err != nil { + return err + } + defer conn.Close() + } else { + _, _, err := net.SplitHostPort(address) + if err != nil { + address = address + ":11211" + } - // Connect - conn, err := net.DialTimeout("tcp", address, defaultTimeout) - if err != nil { - return err + conn, err = net.DialTimeout("tcp", address, defaultTimeout) + if err != nil { + return err + } + defer conn.Close() } - defer conn.Close() // Extend connection conn.SetDeadline(time.Now().Add(defaultTimeout))