Add temp input plugin (#4411)
This commit is contained in:
parent
69100f60b8
commit
25f9cc0b8d
|
@ -120,6 +120,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"
|
||||
|
|
|
@ -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()
|
||||
|
||||
|
|
|
@ -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)
|
||||
}
|
||||
|
|
|
@ -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
|
||||
```
|
|
@ -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()}
|
||||
})
|
||||
}
|
|
@ -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)
|
||||
|
||||
}
|
Loading…
Reference in New Issue