项目作者: davydovanton

项目描述 :
See statistic about your workers
高级语言: Ruby
项目地址: git://github.com/davydovanton/sidekiq-statistic.git
创建时间: 2015-03-03T20:42:33Z
项目社区:https://github.com/davydovanton/sidekiq-statistic

开源协议:MIT License

下载


Sidekiq::Statistic

Build Status Code Climate Gitter

Improved display of statistics for your Sidekiq workers and jobs.

Screenshots

Index page:

sidekiq-history_index

Worker page with table (per day):

sidekiq-history_worker

Installation

Add this line to your application’s Gemfile:

  1. gem 'sidekiq-statistic'

And then execute:

  1. $ bundle

Usage

Using Rails

Read Sidekiq documentation to configure Sidekiq Web UI in your routes.rb.

When Sidekiq Web UI is active you’re going be able to see the option Statistic on the menu.

Using a standalone application

Read Sidekiq documentation to configure Sidekiq in your Rack server.

Next add require 'sidekiq-statistic' to your config.ru.

  1. # config.ru
  2. require 'sidekiq/web'
  3. require 'sidekiq-statistic'
  4. use Rack::Session::Cookie, secret: 'some unique secret string here'
  5. run Sidekiq::Web

Configuration

The Statistic configuration is an initializer that GEM uses to configure itself. The option max_timelist_length
is used to avoid memory leak, in practice, whenever the cache size reaches that number, the GEM is going
to remove 25% of the key values, avoiding inflating memory.

  1. Sidekiq::Statistic.configure do |config|
  2. config.max_timelist_length = 250_000
  3. end

Supported Sidekiq versions

Statistic support the following Sidekiq versions:

  • Sidekiq 6.
  • Sidekiq 5.
  • Sidekiq 4.
  • Sidekiq 3.5.

JSON API

/api/statistic.json

Returns statistic for each worker.

Params:

  • dateFrom - Date start (format: yyyy-mm-dd)
  • dateTo - Date end (format: yyyy-mm-dd)

Example:

  1. $ curl http://example.com/sidekiq/api/statistic.json?dateFrom=2015-07-30&dateTo=2015-07-31
  2. # =>
  3. {
  4. "workers": [
  5. {
  6. "name": "Worker",
  7. "last_job_status": "passed",
  8. "number_of_calls": {
  9. "success": 1,
  10. "failure": 0,
  11. "total": 1
  12. },
  13. "runtime": {
  14. "last": "2015-07-31 10:42:13 UTC",
  15. "max": 4.002,
  16. "min": 4.002,
  17. "average": 4.002,
  18. "total": 4.002
  19. }
  20. },
  21. ...
  22. ]
  23. }

/api/statistic/:worker_name.json

Returns worker statistic for each day in range.

Params:

  • dateFrom - Date start (format: yyyy-mm-dd)
  • dateTo - Date end (format: yyyy-mm-dd)

Example:

  1. $ curl http://example.com/sidekiq/api/statistic/Worker.json?dateFrom=2015-07-30&dateTo=2015-07-31
  2. # =>
  3. {
  4. "days": [
  5. {
  6. "date": "2015-07-31",
  7. "failure": 0,
  8. "success": 1,
  9. "total": 1,
  10. "last_job_status": "passed",
  11. "runtime": {
  12. "last": null,
  13. "max": 0,
  14. "min": 0,
  15. "average": 0,
  16. "total": 0
  17. }
  18. },
  19. ...
  20. ]
  21. }

Update statistic inside middleware

You can update your worker statistic inside middleware. For this you should to update sidekiq:statistic redis hash.
This hash has the following structure:

  • sidekiq:statistic - redis hash with all statistic
    • yyyy-mm-dd:WorkerName:passed - count of passed jobs for Worker name on yyyy-mm-dd
    • yyyy-mm-dd:WorkerName:failed - count of failed jobs for Worker name on yyyy-mm-dd
    • yyyy-mm-dd:WorkerName:last_job_status - string with status (passed or failed) for last job
    • yyyy-mm-dd:WorkerName:last_time - date of last job performing
    • yyyy-mm-dd:WorkerName:queue - name of job queue (default by default)

For time information you should push the runtime value to yyyy-mm-dd:WorkerName:timeslist redis list.

How it works


Big image ‘how it works’

how-it-works

Contributing

  1. Fork it ( https://github.com/davydovanton/sidekiq-statistic/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request