async_request_reply 1.3.0 → 1.4.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
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6eb4a2de7e2244e31844ecff8a54d4a9cc01122b9b6ba49e8bfb58e82892cecd
|
4
|
+
data.tar.gz: fd2e18c90fa031042ee59ec84e374a42698f2262fb9118aaaf5d07c0d9703a13
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 5fad7cccbf40ec282a6aae77a5e31404efd6b312cabaac4a4e3a7dbdd6f81977673e4d1599567298cdf8b62d9145f42be23e65b247fe26fb12027d0bfe37cb74
|
7
|
+
data.tar.gz: 389043837f77f7b0212664ca10cb95acf77d786755b4e120bb978f9742d521c43ac6859d44eb11925c7fe5321b9070b3c02eb835d2fef27c8a29a2dcb2bb7d20
|
@@ -5,9 +5,9 @@ require 'logger'
|
|
5
5
|
module AsyncRequestReply
|
6
6
|
class Config
|
7
7
|
DEFAULTS = {
|
8
|
-
repository_adapter: :
|
8
|
+
repository_adapter: :io,
|
9
9
|
redis_url_conection: 'redis://localhost:6379',
|
10
|
-
async_engine: :
|
10
|
+
async_engine: :simple_thread_pool,
|
11
11
|
logger: Logger.new(STDOUT)
|
12
12
|
}
|
13
13
|
|
@@ -34,6 +34,7 @@ module AsyncRequestReply
|
|
34
34
|
|
35
35
|
def repository_adapter
|
36
36
|
return AsyncRequestReply::RepositoryAdapters::RedisRepositoryAdapter if config.repository_adapter == :redis
|
37
|
+
return AsyncRequestReply::RepositoryAdapters::IORepositoryAdapter if config.repository_adapter == :io
|
37
38
|
config.repository_adapter
|
38
39
|
end
|
39
40
|
|
@@ -42,7 +43,7 @@ module AsyncRequestReply
|
|
42
43
|
end
|
43
44
|
|
44
45
|
def async_engine
|
45
|
-
return AsyncRequestReply::WorkersEngine::
|
46
|
+
return AsyncRequestReply::WorkersEngine::SimpleThreadPool if config.async_engine == :simple_thread_pool
|
46
47
|
return AsyncRequestReply::WorkersEngine::Sidekiq if config.async_engine == :sidekiq
|
47
48
|
|
48
49
|
config.async_engine
|
@@ -0,0 +1,32 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
require_relative '../config'
|
3
|
+
require_relative 'abstract_repository_adapter'
|
4
|
+
require 'tmpdir'
|
5
|
+
|
6
|
+
module AsyncRequestReply
|
7
|
+
module RepositoryAdapters
|
8
|
+
class IORepositoryAdapter < AbstractRepositoryAdapter
|
9
|
+
@@prefix = ".async_request_reply".freeze
|
10
|
+
class << self
|
11
|
+
def get(uuid)
|
12
|
+
begin
|
13
|
+
IO.binread("#{@@prefix}/#{uuid}")
|
14
|
+
rescue StandardError => e
|
15
|
+
return nil if e.is_a?(Errno::ENOENT)
|
16
|
+
raise e
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
def del(uuid)
|
21
|
+
File.delete("#{@@prefix}/#{uuid}")
|
22
|
+
end
|
23
|
+
|
24
|
+
def setex(uuid, ttl = nil, payload)
|
25
|
+
Dir.mkdir(@@prefix) unless Dir.exist?(@@prefix)
|
26
|
+
IO.binwrite("#{@@prefix}/#{uuid}", payload)
|
27
|
+
self.get(uuid)
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
module AsyncRequestReply
|
2
|
+
module WorkersEngine
|
3
|
+
class SimpleThreadPool
|
4
|
+
MAX_THREADS = 2
|
5
|
+
@@jobs = Queue.new
|
6
|
+
@@workers = Array.new(MAX_THREADS) do
|
7
|
+
Thread.new do
|
8
|
+
loop do
|
9
|
+
job = @@jobs.pop
|
10
|
+
job.perform
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
def self.perform_async(async_request_id)
|
16
|
+
@@jobs.push(::AsyncRequestReply::Worker.find(async_request_id))
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
data/lib/async_request_reply.rb
CHANGED
@@ -9,7 +9,9 @@ module AsyncRequestReply
|
|
9
9
|
autoload :Worker, "async_request_reply/worker"
|
10
10
|
autoload :WorkerInBatch, "async_request_reply/worker_in_batch"
|
11
11
|
require "async_request_reply/repository_adapters/redis_repository_adapter"
|
12
|
+
require "async_request_reply/repository_adapters/i_o_repository_adapter"
|
12
13
|
require "async_request_reply/workers_engine/sidekiq"
|
14
|
+
require "async_request_reply/workers_engine/simple_thread_pool"
|
13
15
|
|
14
16
|
# Load default configs
|
15
17
|
AsyncRequestReply::Config.instance
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: async_request_reply
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.
|
4
|
+
version: 1.4.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Luiz Filipe Neves Costa, Rafael Pinheiro
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2025-
|
11
|
+
date: 2025-05-30 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: connection_pool
|
@@ -107,10 +107,12 @@ files:
|
|
107
107
|
- lib/async_request_reply/config.rb
|
108
108
|
- lib/async_request_reply/methods_chain.rb
|
109
109
|
- lib/async_request_reply/repository_adapters/abstract_repository_adapter.rb
|
110
|
+
- lib/async_request_reply/repository_adapters/i_o_repository_adapter.rb
|
110
111
|
- lib/async_request_reply/repository_adapters/redis_repository_adapter.rb
|
111
112
|
- lib/async_request_reply/worker.rb
|
112
113
|
- lib/async_request_reply/worker_in_batch.rb
|
113
114
|
- lib/async_request_reply/workers_engine/sidekiq.rb
|
115
|
+
- lib/async_request_reply/workers_engine/simple_thread_pool.rb
|
114
116
|
homepage: https://github.com/prosas/async_request_reply
|
115
117
|
licenses:
|
116
118
|
- MIT
|