2019-01-10 17:39:37 +00:00
|
|
|
# How to use this package
|
|
|
|
|
|
|
|
## Make sure nats is running. Both publisher and subscriber are open
|
|
|
|
|
|
|
|
```go
|
|
|
|
// NATS streaming server
|
|
|
|
m.natsServer = nats.NewServer(nats.Config{FilestoreDir: m.natsPath})
|
|
|
|
if err := m.natsServer.Open(); err != nil {
|
2019-12-04 23:10:23 +00:00
|
|
|
m.logger.Error("Failed to start nats streaming server", zap.Error(err))
|
2019-01-10 17:39:37 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
publisher := nats.NewAsyncPublisher("nats-publisher")
|
|
|
|
if err := publisher.Open(); err != nil {
|
2019-12-04 23:10:23 +00:00
|
|
|
m.logger.Error("Failed to connect to streaming server", zap.Error(err))
|
2019-01-10 17:39:37 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
subscriber := nats.NewQueueSubscriber("nats-subscriber")
|
|
|
|
if err := subscriber.Open(); err != nil {
|
2019-12-04 23:10:23 +00:00
|
|
|
m.logger.Error("Failed to connect to streaming server", zap.Error(err))
|
2019-01-10 17:39:37 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
## Make sure the scraperTargetStorageService is accessible
|
|
|
|
|
|
|
|
```go
|
|
|
|
scraperTargetSvc influxdb.ScraperTargetStoreService = m.boltClient
|
|
|
|
```
|
|
|
|
|
|
|
|
## Setup recorder, Make sure subscriber subscribes use the correct recorder with the correct write service
|
|
|
|
|
|
|
|
```go
|
|
|
|
recorder := gather.PlatformWriter{
|
|
|
|
Timeout: time.Millisecond * 30,
|
|
|
|
Writer: writer,
|
|
|
|
}
|
|
|
|
subscriber.Subscribe(MetricsSubject, "", &RecorderHandler{
|
|
|
|
Logger: logger,
|
|
|
|
Recorder: recorder,
|
|
|
|
})
|
|
|
|
```
|
|
|
|
|
|
|
|
## Start the scheduler
|
|
|
|
|
|
|
|
```go
|
|
|
|
scraperScheduler, err := gather.NewScheduler(10, m.logger, scraperTargetSvc, publisher, subscriber, 0, 0)
|
|
|
|
if err != nil {
|
2019-12-04 23:10:23 +00:00
|
|
|
m.logger.Error("Failed to create scraper subscriber", zap.Error(err))
|
2019-01-10 17:39:37 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
```
|