async-job-adapter-active_job 0.13.0 → 0.14.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data/bin/async-job-adapter-active_job-server +1 -6
- data/lib/async/job/adapter/active_job/dispatcher.rb +4 -0
- data/lib/async/job/adapter/active_job/environment.rb +14 -2
- data/lib/async/job/adapter/active_job/service.rb +21 -2
- data/lib/async/job/adapter/active_job/thread_local_dispatcher.rb +5 -0
- data/lib/async/job/adapter/active_job/version.rb +1 -1
- data.tar.gz.sig +0 -0
- metadata +1 -1
- metadata.gz.sig +0 -0
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 2dd9f7593bc4e508c98ca5cff8a163fc594872625467667138213a3ab8f2ed78
|
4
|
+
data.tar.gz: 78d52a6b38482a80ee4c227d8f753baa2662d313d6a59e284f35de2e00b84e32
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f205bafb6e23f4eed08575db38d96ec18e4f7e9bad444830b03b6e5a33fac62d91749f0e2ab4bf0328a2fa5192ee19bbdcf182c792de83464555871112674e26
|
7
|
+
data.tar.gz: e239ac52ec5e7bfae69347c3dcedd4cb0d6dffae60114bcdad4e3c3528c66a49b1bf2c2e4b940ea447b631abb028192336aab1e81b6806fdb7a3539118b532c8
|
checksums.yaml.gz.sig
CHANGED
Binary file
|
@@ -7,13 +7,8 @@ require 'async/service/controller'
|
|
7
7
|
require 'async/job/adapter/active_job/environment'
|
8
8
|
|
9
9
|
configuration = Async::Service::Configuration.build do
|
10
|
-
service "async-job-server" do
|
10
|
+
service "async-job-adapter-active_job-server" do
|
11
11
|
include Async::Job::Adapter::ActiveJob::Environment
|
12
|
-
|
13
|
-
root {ENV.fetch('RAILS_ROOT', Dir.pwd)}
|
14
|
-
|
15
|
-
# If you have multiple queues, you may want to run a separate server for each queue.
|
16
|
-
queue_name ENV.fetch('ASYNC_JOB_ADAPTER_ACTIVE_JOB_QUEUE_NAME', 'default')
|
17
12
|
end
|
18
13
|
end
|
19
14
|
|
@@ -16,9 +16,21 @@ module Async
|
|
16
16
|
Service
|
17
17
|
end
|
18
18
|
|
19
|
+
def root
|
20
|
+
ENV.fetch('RAILS_ROOT', Dir.pwd)
|
21
|
+
end
|
22
|
+
|
23
|
+
def dispatcher
|
24
|
+
Railtie.dispatcher
|
25
|
+
end
|
26
|
+
|
19
27
|
# The name of the queue to use.
|
20
|
-
def
|
21
|
-
|
28
|
+
def queue_names
|
29
|
+
if queue_names = ENV['ASYNC_JOB_ADAPTER_ACTIVE_JOB_QUEUE_NAMES']
|
30
|
+
queue_names.split(',')
|
31
|
+
else
|
32
|
+
dispatcher.keys
|
33
|
+
end
|
22
34
|
end
|
23
35
|
end
|
24
36
|
end
|
@@ -4,6 +4,8 @@
|
|
4
4
|
# Copyright, 2024, by Samuel Williams.
|
5
5
|
|
6
6
|
require 'async/service/generic'
|
7
|
+
require 'console/event/failure'
|
8
|
+
require 'async/barrier'
|
7
9
|
|
8
10
|
module Async
|
9
11
|
module Job
|
@@ -15,12 +17,29 @@ module Async
|
|
15
17
|
def setup(container)
|
16
18
|
container.run(name: self.name, restart: true) do |instance|
|
17
19
|
evaluator = @environment.evaluator
|
20
|
+
|
18
21
|
require File.expand_path('config/environment', evaluator.root)
|
19
22
|
|
23
|
+
dispatcher = evaluator.dispatcher
|
24
|
+
|
20
25
|
instance.ready!
|
21
26
|
|
22
|
-
Sync do
|
23
|
-
|
27
|
+
Sync do |task|
|
28
|
+
barrier = Async::Barrier.new
|
29
|
+
|
30
|
+
# Start all the named queues:
|
31
|
+
evaluator.queue_names.each do |queue_name|
|
32
|
+
barrier.async do
|
33
|
+
Console.debug(self, "Starting queue...", queue_name: queue_name)
|
34
|
+
dispatcher.start(queue_name)
|
35
|
+
rescue => error
|
36
|
+
Console::Event::Failure.for(error).emit(self, "Queue failed!")
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
barrier.wait
|
41
|
+
ensure
|
42
|
+
barrier.stop
|
24
43
|
end
|
25
44
|
end
|
26
45
|
end
|
data.tar.gz.sig
CHANGED
Binary file
|
metadata
CHANGED
metadata.gz.sig
CHANGED
Binary file
|