Merged service.go into telegraf.go
Due to compilation issues on Windows, moved the code from service.go into telegraf.go and removed service.go entirely.
This commit is contained in:
parent
35f5e62a09
commit
101dbd22da
|
@ -1,53 +0,0 @@
|
||||||
// Run the telegraf data collector
|
|
||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"log"
|
|
||||||
|
|
||||||
"github.com/kardianos/service"
|
|
||||||
)
|
|
||||||
|
|
||||||
var logger service.Logger
|
|
||||||
|
|
||||||
var stop chan struct{}
|
|
||||||
|
|
||||||
var srvc service.Service
|
|
||||||
|
|
||||||
type program struct{}
|
|
||||||
|
|
||||||
func (p *program) Start(s service.Service) error {
|
|
||||||
srvc = s
|
|
||||||
go p.run()
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
func (p *program) run() {
|
|
||||||
stop = make(chan struct{})
|
|
||||||
reloadLoop(stop, srvc)
|
|
||||||
}
|
|
||||||
func (p *program) Stop(s service.Service) error {
|
|
||||||
close(stop)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
svcConfig := &service.Config{
|
|
||||||
Name: "telegraf",
|
|
||||||
DisplayName: "Telegraf Data Collector Service",
|
|
||||||
Description: "Collects data using a series of plugins and publishes it to" +
|
|
||||||
"another series of plugins.",
|
|
||||||
}
|
|
||||||
|
|
||||||
prg := &program{}
|
|
||||||
s, err := service.New(prg, svcConfig)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
|
||||||
logger, err = s.Logger(nil)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
|
||||||
err = s.Run()
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err)
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -104,6 +104,15 @@ Examples:
|
||||||
telegraf -config telegraf.conf -input-filter cpu:mem -output-filter influxdb
|
telegraf -config telegraf.conf -input-filter cpu:mem -output-filter influxdb
|
||||||
`
|
`
|
||||||
|
|
||||||
|
var logger service.Logger
|
||||||
|
|
||||||
|
var stop chan struct{}
|
||||||
|
|
||||||
|
var srvc service.Service
|
||||||
|
|
||||||
|
type program struct{}
|
||||||
|
|
||||||
|
|
||||||
func reloadLoop(stop chan struct{}, s service.Service) {
|
func reloadLoop(stop chan struct{}, s service.Service) {
|
||||||
defer func() {
|
defer func() {
|
||||||
if service.Interactive() {
|
if service.Interactive() {
|
||||||
|
@ -301,3 +310,40 @@ func usageExit(rc int) {
|
||||||
fmt.Println(usage)
|
fmt.Println(usage)
|
||||||
os.Exit(rc)
|
os.Exit(rc)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (p *program) Start(s service.Service) error {
|
||||||
|
srvc = s
|
||||||
|
go p.run()
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func (p *program) run() {
|
||||||
|
stop = make(chan struct{})
|
||||||
|
reloadLoop(stop, srvc)
|
||||||
|
}
|
||||||
|
func (p *program) Stop(s service.Service) error {
|
||||||
|
close(stop)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
svcConfig := &service.Config{
|
||||||
|
Name: "telegraf",
|
||||||
|
DisplayName: "Telegraf Data Collector Service",
|
||||||
|
Description: "Collects data using a series of plugins and publishes it to" +
|
||||||
|
"another series of plugins.",
|
||||||
|
}
|
||||||
|
|
||||||
|
prg := &program{}
|
||||||
|
s, err := service.New(prg, svcConfig)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
logger, err = s.Logger(nil)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
err = s.Run()
|
||||||
|
if err != nil {
|
||||||
|
logger.Error(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue