Class: Sidekiq::TransactionAwareClient
- Inherits:
-
Object
- Object
- Sidekiq::TransactionAwareClient
- Defined in:
- lib/sidekiq/transaction_aware_client.rb
Instance Method Summary collapse
- #batching? ⇒ Boolean
-
#initialize(pool: nil, config: nil) ⇒ TransactionAwareClient
constructor
A new instance of TransactionAwareClient.
- #push(item) ⇒ Object
-
#push_bulk(items) ⇒ Object
We don’t provide transactionality for push_bulk because we don’t want to hold potentially hundreds of thousands of job records in memory due to a long running enqueue process.
Constructor Details
#initialize(pool: nil, config: nil) ⇒ TransactionAwareClient
Returns a new instance of TransactionAwareClient.
8 9 10 |
# File 'lib/sidekiq/transaction_aware_client.rb', line 8 def initialize(pool: nil, config: nil) @redis_client = Client.new(pool: pool, config: config) end |
Instance Method Details
#batching? ⇒ Boolean
12 13 14 |
# File 'lib/sidekiq/transaction_aware_client.rb', line 12 def batching? Thread.current[:sidekiq_batch] end |
#push(item) ⇒ Object
16 17 18 19 20 21 22 23 24 25 |
# File 'lib/sidekiq/transaction_aware_client.rb', line 16 def push(item) # 6160 we can't support both Sidekiq::Batch and transactions. return @redis_client.push(item) if batching? # pre-allocate the JID so we can return it immediately and # save it to the database as part of the transaction. item["jid"] ||= SecureRandom.hex(12) AfterCommitEverywhere.after_commit { @redis_client.push(item) } item["jid"] end |
#push_bulk(items) ⇒ Object
We don’t provide transactionality for push_bulk because we don’t want to hold potentially hundreds of thousands of job records in memory due to a long running enqueue process.
31 32 33 |
# File 'lib/sidekiq/transaction_aware_client.rb', line 31 def push_bulk(items) @redis_client.push_bulk(items) end |