From 271d8b7a09675d676d19af1ffa8fd126b1f250e9 Mon Sep 17 00:00:00 2001 From: pytimer Date: Tue, 11 Sep 2018 02:52:15 +0800 Subject: [PATCH] Add temp input plugin (#4411) --- plugins/inputs/all/all.go | 1 + plugins/inputs/system/mock_PS.go | 10 +++++++ plugins/inputs/system/ps.go | 6 +++++ plugins/inputs/temp/README.md | 32 ++++++++++++++++++++++ plugins/inputs/temp/temp.go | 46 ++++++++++++++++++++++++++++++++ plugins/inputs/temp/temp_test.go | 38 ++++++++++++++++++++++++++ 6 files changed, 133 insertions(+) create mode 100644 plugins/inputs/temp/README.md create mode 100644 plugins/inputs/temp/temp.go create mode 100644 plugins/inputs/temp/temp_test.go diff --git a/plugins/inputs/all/all.go b/plugins/inputs/all/all.go index 8e101f755194e..655ebaf37ac69 100644 --- a/plugins/inputs/all/all.go +++ b/plugins/inputs/all/all.go @@ -121,6 +121,7 @@ import ( _ "github.com/influxdata/telegraf/plugins/inputs/tail" _ "github.com/influxdata/telegraf/plugins/inputs/tcp_listener" _ "github.com/influxdata/telegraf/plugins/inputs/teamspeak" + _ "github.com/influxdata/telegraf/plugins/inputs/temp" _ "github.com/influxdata/telegraf/plugins/inputs/tengine" _ "github.com/influxdata/telegraf/plugins/inputs/tomcat" _ "github.com/influxdata/telegraf/plugins/inputs/trig" diff --git a/plugins/inputs/system/mock_PS.go b/plugins/inputs/system/mock_PS.go index 323332f3ebaf3..b3cf2c1707f5d 100644 --- a/plugins/inputs/system/mock_PS.go +++ b/plugins/inputs/system/mock_PS.go @@ -7,6 +7,7 @@ import ( "github.com/shirou/gopsutil/cpu" "github.com/shirou/gopsutil/disk" + "github.com/shirou/gopsutil/host" "github.com/shirou/gopsutil/load" "github.com/shirou/gopsutil/mem" @@ -100,6 +101,15 @@ func (m *MockPS) SwapStat() (*mem.SwapMemoryStat, error) { return r0, r1 } +func (m *MockPS) Temperature() ([]host.TemperatureStat, error) { + ret := m.Called() + + r0 := ret.Get(0).([]host.TemperatureStat) + r1 := ret.Error(1) + + return r0, r1 +} + func (m *MockPS) NetConnections() ([]net.ConnectionStat, error) { ret := m.Called() diff --git a/plugins/inputs/system/ps.go b/plugins/inputs/system/ps.go index 038e2a0a89e56..256aca0596040 100644 --- a/plugins/inputs/system/ps.go +++ b/plugins/inputs/system/ps.go @@ -10,6 +10,7 @@ import ( "github.com/shirou/gopsutil/cpu" "github.com/shirou/gopsutil/disk" + "github.com/shirou/gopsutil/host" "github.com/shirou/gopsutil/mem" "github.com/shirou/gopsutil/net" ) @@ -23,6 +24,7 @@ type PS interface { VMStat() (*mem.VirtualMemoryStat, error) SwapStat() (*mem.SwapMemoryStat, error) NetConnections() ([]net.ConnectionStat, error) + Temperature() ([]host.TemperatureStat, error) } type PSDiskDeps interface { @@ -168,6 +170,10 @@ func (s *SystemPS) SwapStat() (*mem.SwapMemoryStat, error) { return mem.SwapMemory() } +func (s *SystemPS) Temperature() ([]host.TemperatureStat, error) { + return host.SensorsTemperatures() +} + func (s *SystemPSDisk) Partitions(all bool) ([]disk.PartitionStat, error) { return disk.Partitions(all) } diff --git a/plugins/inputs/temp/README.md b/plugins/inputs/temp/README.md new file mode 100644 index 0000000000000..87f365ca0730b --- /dev/null +++ b/plugins/inputs/temp/README.md @@ -0,0 +1,32 @@ +# Temp Input plugin + +This input plugin collect temperature. + +### Configuration: + +``` +[[inputs.temp]] +``` + +### Measurements & Fields: + +All fields are float64. + +- temp ( unit: °Celsius) + +### Tags: + +- All measurements have the following tags: + - host + - sensor + +### Example Output: + +``` +$ ./telegraf --config telegraf.conf --input-filter temp --test +* Plugin: temp, Collection 1 +> temp,host=localhost,sensor=coretemp_physicalid0_crit temp=100 1531298763000000000 +> temp,host=localhost,sensor=coretemp_physicalid0_critalarm temp=0 1531298763000000000 +> temp,host=localhost,sensor=coretemp_physicalid0_input temp=100 1531298763000000000 +> temp,host=localhost,sensor=coretemp_physicalid0_max temp=100 1531298763000000000 +``` diff --git a/plugins/inputs/temp/temp.go b/plugins/inputs/temp/temp.go new file mode 100644 index 0000000000000..10e61673d517f --- /dev/null +++ b/plugins/inputs/temp/temp.go @@ -0,0 +1,46 @@ +package temp + +import ( + "fmt" + + "github.com/influxdata/telegraf" + "github.com/influxdata/telegraf/plugins/inputs" + "github.com/influxdata/telegraf/plugins/inputs/system" +) + +type Temperature struct { + ps system.PS +} + +func (t *Temperature) Description() string { + return "Read metrics about temperature" +} + +const sampleConfig = "" + +func (t *Temperature) SampleConfig() string { + return sampleConfig +} + +func (t *Temperature) Gather(acc telegraf.Accumulator) error { + temps, err := t.ps.Temperature() + if err != nil { + return fmt.Errorf("error getting temperatures info: %s", err) + } + for _, temp := range temps { + tags := map[string]string{ + "sensor": temp.SensorKey, + } + fields := map[string]interface{}{ + "temp": temp.Temperature, + } + acc.AddFields("temp", fields, tags) + } + return nil +} + +func init() { + inputs.Add("temp", func() telegraf.Input { + return &Temperature{ps: system.NewSystemPS()} + }) +} diff --git a/plugins/inputs/temp/temp_test.go b/plugins/inputs/temp/temp_test.go new file mode 100644 index 0000000000000..080ff66ac1848 --- /dev/null +++ b/plugins/inputs/temp/temp_test.go @@ -0,0 +1,38 @@ +package temp + +import ( + "testing" + + "github.com/shirou/gopsutil/host" + "github.com/stretchr/testify/require" + + "github.com/influxdata/telegraf/plugins/inputs/system" + "github.com/influxdata/telegraf/testutil" +) + +func TestTemperature(t *testing.T) { + var mps system.MockPS + var err error + defer mps.AssertExpectations(t) + var acc testutil.Accumulator + + ts := host.TemperatureStat{ + SensorKey: "coretemp_sensor1_crit", + Temperature: 60.5, + } + + mps.On("Temperature").Return([]host.TemperatureStat{ts}, nil) + + err = (&Temperature{ps: &mps}).Gather(&acc) + require.NoError(t, err) + + expectedFields := map[string]interface{}{ + "temp": float64(60.5), + } + + expectedTags := map[string]string{ + "sensor": "coretemp_sensor1_crit", + } + acc.AssertContainsTaggedFields(t, "temp", expectedFields, expectedTags) + +}