worker.go 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. // Copyright 2017 Frédéric Guillot. All rights reserved.
  2. // Use of this source code is governed by the Apache 2.0
  3. // license that can be found in the LICENSE file.
  4. package worker // import "miniflux.app/worker"
  5. import (
  6. "time"
  7. "miniflux.app/config"
  8. "miniflux.app/logger"
  9. "miniflux.app/metric"
  10. "miniflux.app/model"
  11. feedHandler "miniflux.app/reader/handler"
  12. "miniflux.app/storage"
  13. )
  14. // Worker refreshes a feed in the background.
  15. type Worker struct {
  16. id int
  17. store *storage.Storage
  18. }
  19. // Run wait for a job and refresh the given feed.
  20. func (w *Worker) Run(c chan model.Job) {
  21. logger.Debug("[Worker] #%d started", w.id)
  22. for {
  23. job := <-c
  24. logger.Debug("[Worker #%d] Received feed #%d for user #%d", w.id, job.FeedID, job.UserID)
  25. startTime := time.Now()
  26. refreshErr := feedHandler.RefreshFeed(w.store, job.UserID, job.FeedID)
  27. if config.Opts.HasMetricsCollector() {
  28. status := "success"
  29. if refreshErr != nil {
  30. status = "error"
  31. }
  32. metric.BackgroundFeedRefreshDuration.WithLabelValues(status).Observe(time.Since(startTime).Seconds())
  33. }
  34. if refreshErr != nil {
  35. logger.Error("[Worker] Refreshing the feed #%d returned this error: %v", job.FeedID, refreshErr)
  36. }
  37. }
  38. }