Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ixti/sidekiq-antidote
Sidekiq poison-pill instant remedy
https://github.com/ixti/sidekiq-antidote
sidekiq
Last synced: about 1 month ago
JSON representation
Sidekiq poison-pill instant remedy
- Host: GitHub
- URL: https://github.com/ixti/sidekiq-antidote
- Owner: ixti
- License: mit
- Created: 2023-11-26T21:20:04.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-01-20T03:10:29.000Z (10 months ago)
- Last Synced: 2024-04-20T13:13:08.246Z (7 months ago)
- Topics: sidekiq
- Language: Ruby
- Homepage:
- Size: 46.9 KB
- Stars: 0
- Watchers: 2
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.adoc
- Changelog: CHANGES.md
- License: LICENSE.txt
Awesome Lists containing this project
README
= Sidekiq::Antidote
:ci-url: https://github.com/ixti/sidekiq-antidote/actions/workflows/ci.yml?query=branch%3Amain
:ci-img: https://github.com/ixti/sidekiq-antidote/actions/workflows/ci.yml/badge.svg?branch=main
:codecov-url: https://codecov.io/gh/ixti/sidekiq-antidote/tree/main
:codecov-img: https://codecov.io/gh/ixti/sidekiq-antidote/graph/badge.svg?token=F5AAMPN35A{ci-url}[image:{ci-img}[CI]]
{codecov-url}[image:{codecov-img}[codecov]]== Installation
Add this line to your application's Gemfile:
$ bundle add sidekiq-antidote
Or install it yourself as:
$ gem install sidekiq-antidote
== Usage
[source, ruby]
----
require "sidekiq"
require "sidekiq/antidote"Sidekiq::Antidote.configure do |config|
# Set inhibitors cache refresh rate in seconds.
# Default: 5.0
config.refresh_rate = 10.0
end
----When running in forked environment (e.g., Puma web server), you also need to
call `Sidekiq::Antidote.startup` on fork:[source, ruby]
----
# file: config/puma.rb
on_worker_boot { Sidekiq::Antidote.startup }
----=== Web UI
Adding Antidote tab in Sidekiq web UI is as simple as:
[source, ruby]
----
require "sidekiq/web"
require "sidekiq/antidote/web"
----=== Middleware(s)
`Sidekiq::Antidote` relies on following bundled middlewares:
* `Sidekiq::Antidote::Middlewares::Client`
* `Sidekiq::Antidote::Middlewares::Server`The middleware is automatically injected when you require `sidekiq/antidote`.
In rare cases, when this causes an issue, you can change middleware order manually:[source,ruby]
----
Sidekiq.configure_client do |config|
# ...config.client_middleware do |chain|
chain.prepend(Sidekiq::Antidote::Middlewares::Client)
end
endSidekiq.configure_server do |config|
# ...config.client_middleware do |chain|
chain.prepend(Sidekiq::Antidote::Middlewares::Client)
endconfig.server_middleware do |chain|
chain.prepend(Sidekiq::Antidote::Middlewares::Server)
end
end
----See: https://github.com/sidekiq/sidekiq/blob/main/lib/sidekiq/middleware/chain.rb
== Inhibitors
=== Treatments
When adding antidote you must pick on of the treatments:
skip::
Skip the job (don't enqueue and/or perform)
kill::
Kill the job (send to the dead set instead of enqueueing and/or performing)=== Class Qualifiers
Class qualifier is the job class pattern. It may match the job class or the job
class and method name (when used with ActionMailer delayed deliveries):* `ExampleJob`
* `Namespaced::ExampleJob`
* `UserMailer#welcome`You can also use pattern matching:
*::
Matches any number of alpha-numeric characters and underscores:
* `*Job` matches: `ExampleJob`, but not `Namespaced::ExampleJob`, or `UserMailer#welcome`
* `UserMailer#*` matches any method of `UserMailer`
**::
Matches any number of components:
* `**` mathes any job or mailer method
* `A::**::Job` matches `A::B::Job`, `A::B::C::D::CJob`, etc.
* `A**::Job` matches `A::Job`, `Abc::Job`, `A::B::Job`, etc.
{}::
Matches any of the given literal:
* `{A,B,C}Job` matches `AJob`, `BJob`, and `CJob`== Compatibility
This library aims to support and is tested against:
* https://www.ruby-lang.org[Ruby]
** MRI 3.0.x
** MRI 3.1.x
** MRI 3.2.x
** MRI 3.3.x
* https://github.com/sidekiq/sidekiq[Sidekiq]
** 7.2.x
** 7.3.x
* https://redis.io[Redis]
** 6.2.x
** 7.0.x
** 7.2.xIf something doesn't work on one of these versions, it's a bug.
This library may inadvertently work (or seem to work) on other Ruby, Redis, and
Sidekiq versions, however support will only be provided for the versions listed
above.If you would like this library to support another Ruby, Redis, or Sidekiq
version, you may volunteer to be a maintainer. Being a maintainer entails making
sure all tests run and pass on that implementation. When something breaks on
your implementation, you will be responsible for providing patches in a timely
fashion. If critical issues for a particular implementation exist at the time of
a major release, support for that Ruby, Redis, and/or Sidekiq version may be
dropped.== Development
bundle install
bundle exec appraisal generate
bundle exec appraisal install
bundle exec rake== Contributing
* Fork sidekiq-antidote
* Make your changes
* Ensure all tests pass (`bundle exec rake`)
* Send a merge request
* If we like them we'll merge them
* If we've accepted a patch, feel free to ask for commit access!== Acknowledgement
* Inspired by https://github.com/square/sidekiq-killswitch[sidekiq-killswitch]