fleck 2.2.1 → 2.2.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +11 -11
- data/Gemfile +6 -6
- data/examples/actions.rb +60 -60
- data/examples/blocking_consumer.rb +42 -42
- data/examples/consumer_initialization.rb +44 -44
- data/examples/deprecation.rb +50 -50
- data/examples/example.rb +76 -76
- data/examples/expired.rb +72 -72
- data/examples/fanout.rb +62 -62
- data/lib/fleck/client.rb +147 -124
- data/lib/fleck/configuration.rb +147 -147
- data/lib/fleck/core/consumer/configuration.rb +69 -69
- data/lib/fleck/core/consumer/helpers_definers.rb +56 -56
- data/lib/fleck/core/consumer/logger.rb +88 -88
- data/lib/fleck/core/consumer/request.rb +100 -100
- data/lib/fleck/core/consumer/response.rb +77 -77
- data/lib/fleck/core/consumer/response_helpers.rb +81 -81
- data/lib/fleck/core/consumer.rb +1 -1
- data/lib/fleck/loggable.rb +15 -15
- data/lib/fleck/utilities/host_rating.rb +102 -102
- data/lib/fleck/version.rb +1 -1
- data/lib/fleck.rb +82 -82
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 12549351b1fbd3d7cc3aac011b2949ed7c75d45cc00627ebce98ba87e5ffc3fd
|
4
|
+
data.tar.gz: d1c254ae75c7510c6d0436a4b10610e0002478d4405c5a80034583f5b04a8b4f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3b94e6339c1aa8151c94d473eac81c918d67e2da6c805d20725a62f044bccc41c6456dd34c3e0fa16c6559c66d208196f9ae7423ed527ad891f953edccd1f6cf
|
7
|
+
data.tar.gz: 531c4ef36f289ab36dc796f24ec26a81de57bab049a9d4349372226416bcdb45b5e856d85ac528abbdf1e422351d1bbcddee24359065d61e72379fbf2975a122
|
data/.gitignore
CHANGED
@@ -1,11 +1,11 @@
|
|
1
|
-
/.bundle/
|
2
|
-
/.yardoc
|
3
|
-
/Gemfile.lock
|
4
|
-
/_yardoc/
|
5
|
-
/coverage/
|
6
|
-
/doc/
|
7
|
-
/pkg/
|
8
|
-
/spec/reports/
|
9
|
-
/tmp/
|
10
|
-
/*.gem
|
11
|
-
/.rubocop.yml
|
1
|
+
/.bundle/
|
2
|
+
/.yardoc
|
3
|
+
/Gemfile.lock
|
4
|
+
/_yardoc/
|
5
|
+
/coverage/
|
6
|
+
/doc/
|
7
|
+
/pkg/
|
8
|
+
/spec/reports/
|
9
|
+
/tmp/
|
10
|
+
/*.gem
|
11
|
+
/.rubocop.yml
|
data/Gemfile
CHANGED
@@ -1,6 +1,6 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
source 'https://rubygems.org'
|
4
|
-
|
5
|
-
# Specify your gem's dependencies in fleck.gemspec
|
6
|
-
gemspec
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
source 'https://rubygems.org'
|
4
|
+
|
5
|
+
# Specify your gem's dependencies in fleck.gemspec
|
6
|
+
gemspec
|
data/examples/actions.rb
CHANGED
@@ -1,60 +1,60 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
# frozen_string_literal: true
|
3
|
-
|
4
|
-
require 'fleck'
|
5
|
-
|
6
|
-
user = ENV['USER'] || 'guest'
|
7
|
-
pass = ENV['PASS'] || 'guest'
|
8
|
-
|
9
|
-
CONCURRENCY = (ENV['CONCURRENCY'] || 2).to_i
|
10
|
-
SAMPLES = (ENV['SAMPLES'] || 10).to_i
|
11
|
-
QUEUE = 'actions.example.queue'
|
12
|
-
|
13
|
-
Fleck.configure do |config|
|
14
|
-
config.default_user = user
|
15
|
-
config.default_pass = pass
|
16
|
-
config.loglevel = Logger::DEBUG
|
17
|
-
end
|
18
|
-
|
19
|
-
connection = Fleck.connection(host: '127.0.0.1', port: 5672, user: user, pass: pass, vhost: '/')
|
20
|
-
client = Fleck::Client.new(connection, QUEUE, concurrency: CONCURRENCY.to_i)
|
21
|
-
|
22
|
-
class MyConsumer < Fleck::Consumer
|
23
|
-
configure queue: QUEUE, concurrency: CONCURRENCY.to_i
|
24
|
-
|
25
|
-
action 'hello', "An action which returns 'Hello'"
|
26
|
-
def hello
|
27
|
-
ok! result: 'Hello', message: 'Ciao'
|
28
|
-
end
|
29
|
-
|
30
|
-
action 'ciao', "An action which returns 'Ciao'"
|
31
|
-
param :world, type: 'boolean', required: true, default: false
|
32
|
-
def my_custom_method
|
33
|
-
ok! params[:world] ? 'Ciao, Mondo!' : 'Ciao!'
|
34
|
-
end
|
35
|
-
|
36
|
-
action :aloha
|
37
|
-
param :number, type: 'integer', clamp: [1, 10], required: true
|
38
|
-
param :name, type: 'string', default: 'John Doe', required: true
|
39
|
-
def my_aloha
|
40
|
-
ok! "#{params[:number]}. Aloha, #{params[:name]}!"
|
41
|
-
end
|
42
|
-
|
43
|
-
def not_an_action
|
44
|
-
logger.warn("I'm not an action, so you should not be able to call me!")
|
45
|
-
end
|
46
|
-
end
|
47
|
-
|
48
|
-
actions = %i[hello ciao aloha not_an_action]
|
49
|
-
|
50
|
-
SAMPLES.to_i.times do |num|
|
51
|
-
action = actions.sample
|
52
|
-
name = ['John Doe', 'Willie Wonka', 'Billie Smith'].sample
|
53
|
-
client.request(action: action, params: { num: num, name: name, number: rand * 100, world: %w[yes no].sample }, timeout: 5) do |_, response|
|
54
|
-
if response.status == 200
|
55
|
-
Fleck.logger.info "ACTION: (#{action.inspect}) #{response.body.inspect}"
|
56
|
-
else
|
57
|
-
Fleck.logger.error "ACTION: (#{action.inspect}) #{response.errors.join(', ')} --- #{response.body.inspect}"
|
58
|
-
end
|
59
|
-
end
|
60
|
-
end
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# frozen_string_literal: true
|
3
|
+
|
4
|
+
require 'fleck'
|
5
|
+
|
6
|
+
user = ENV['USER'] || 'guest'
|
7
|
+
pass = ENV['PASS'] || 'guest'
|
8
|
+
|
9
|
+
CONCURRENCY = (ENV['CONCURRENCY'] || 2).to_i
|
10
|
+
SAMPLES = (ENV['SAMPLES'] || 10).to_i
|
11
|
+
QUEUE = 'actions.example.queue'
|
12
|
+
|
13
|
+
Fleck.configure do |config|
|
14
|
+
config.default_user = user
|
15
|
+
config.default_pass = pass
|
16
|
+
config.loglevel = Logger::DEBUG
|
17
|
+
end
|
18
|
+
|
19
|
+
connection = Fleck.connection(host: '127.0.0.1', port: 5672, user: user, pass: pass, vhost: '/')
|
20
|
+
client = Fleck::Client.new(connection, QUEUE, concurrency: CONCURRENCY.to_i)
|
21
|
+
|
22
|
+
class MyConsumer < Fleck::Consumer
|
23
|
+
configure queue: QUEUE, concurrency: CONCURRENCY.to_i
|
24
|
+
|
25
|
+
action 'hello', "An action which returns 'Hello'"
|
26
|
+
def hello
|
27
|
+
ok! result: 'Hello', message: 'Ciao'
|
28
|
+
end
|
29
|
+
|
30
|
+
action 'ciao', "An action which returns 'Ciao'"
|
31
|
+
param :world, type: 'boolean', required: true, default: false
|
32
|
+
def my_custom_method
|
33
|
+
ok! params[:world] ? 'Ciao, Mondo!' : 'Ciao!'
|
34
|
+
end
|
35
|
+
|
36
|
+
action :aloha
|
37
|
+
param :number, type: 'integer', clamp: [1, 10], required: true
|
38
|
+
param :name, type: 'string', default: 'John Doe', required: true
|
39
|
+
def my_aloha
|
40
|
+
ok! "#{params[:number]}. Aloha, #{params[:name]}!"
|
41
|
+
end
|
42
|
+
|
43
|
+
def not_an_action
|
44
|
+
logger.warn("I'm not an action, so you should not be able to call me!")
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
48
|
+
actions = %i[hello ciao aloha not_an_action]
|
49
|
+
|
50
|
+
SAMPLES.to_i.times do |num|
|
51
|
+
action = actions.sample
|
52
|
+
name = ['John Doe', 'Willie Wonka', 'Billie Smith'].sample
|
53
|
+
client.request(action: action, params: { num: num, name: name, number: rand * 100, world: %w[yes no].sample }, timeout: 5) do |_, response|
|
54
|
+
if response.status == 200
|
55
|
+
Fleck.logger.info "ACTION: (#{action.inspect}) #{response.body.inspect}"
|
56
|
+
else
|
57
|
+
Fleck.logger.error "ACTION: (#{action.inspect}) #{response.errors.join(', ')} --- #{response.body.inspect}"
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
@@ -1,42 +1,42 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
# encoding: utf-8
|
3
|
-
|
4
|
-
require 'fleck'
|
5
|
-
|
6
|
-
user = ENV['USER'] || 'guest'
|
7
|
-
pass = ENV['PASS'] || 'guest'
|
8
|
-
|
9
|
-
CONCURRENCY = (ENV['CONCURRENCY'] || 2).to_i
|
10
|
-
SAMPLES = (ENV['SAMPLES'] || 10).to_i
|
11
|
-
|
12
|
-
Fleck.configure do |config|
|
13
|
-
config.default_user = user
|
14
|
-
config.default_pass = pass
|
15
|
-
config.loglevel = Logger::DEBUG
|
16
|
-
end
|
17
|
-
|
18
|
-
connection = Fleck.connection(host: "127.0.0.1", port: 5672, user: user, pass: pass, vhost: "/")
|
19
|
-
client = Fleck::Client.new(connection, "blocking.consumer.example.queue")
|
20
|
-
|
21
|
-
class MyConsumer < Fleck::Consumer
|
22
|
-
configure queue: 'blocking.consumer.example.queue', autostart: false
|
23
|
-
actions :quit
|
24
|
-
|
25
|
-
initialize do
|
26
|
-
@value = "MY CONSUMER :) #{object_id}"
|
27
|
-
end
|
28
|
-
|
29
|
-
def quit
|
30
|
-
logger.debug "Quit message received, but I'm goint to sleep for 2 seconds ..."
|
31
|
-
sleep 2
|
32
|
-
logger.debug "Let's terminate this example!"
|
33
|
-
Ztimer.async { self.class.terminate }
|
34
|
-
end
|
35
|
-
end
|
36
|
-
|
37
|
-
client.request(action: 'quit', timeout: 5, async: true)
|
38
|
-
|
39
|
-
MyConsumer.start(block: true)
|
40
|
-
|
41
|
-
puts "We did it :)"
|
42
|
-
sleep 0.01 # Give some time to Bunny to cancel subscribtions and to close channels and connections
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# encoding: utf-8
|
3
|
+
|
4
|
+
require 'fleck'
|
5
|
+
|
6
|
+
user = ENV['USER'] || 'guest'
|
7
|
+
pass = ENV['PASS'] || 'guest'
|
8
|
+
|
9
|
+
CONCURRENCY = (ENV['CONCURRENCY'] || 2).to_i
|
10
|
+
SAMPLES = (ENV['SAMPLES'] || 10).to_i
|
11
|
+
|
12
|
+
Fleck.configure do |config|
|
13
|
+
config.default_user = user
|
14
|
+
config.default_pass = pass
|
15
|
+
config.loglevel = Logger::DEBUG
|
16
|
+
end
|
17
|
+
|
18
|
+
connection = Fleck.connection(host: "127.0.0.1", port: 5672, user: user, pass: pass, vhost: "/")
|
19
|
+
client = Fleck::Client.new(connection, "blocking.consumer.example.queue")
|
20
|
+
|
21
|
+
class MyConsumer < Fleck::Consumer
|
22
|
+
configure queue: 'blocking.consumer.example.queue', autostart: false
|
23
|
+
actions :quit
|
24
|
+
|
25
|
+
initialize do
|
26
|
+
@value = "MY CONSUMER :) #{object_id}"
|
27
|
+
end
|
28
|
+
|
29
|
+
def quit
|
30
|
+
logger.debug "Quit message received, but I'm goint to sleep for 2 seconds ..."
|
31
|
+
sleep 2
|
32
|
+
logger.debug "Let's terminate this example!"
|
33
|
+
Ztimer.async { self.class.terminate }
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
client.request(action: 'quit', timeout: 5, async: true)
|
38
|
+
|
39
|
+
MyConsumer.start(block: true)
|
40
|
+
|
41
|
+
puts "We did it :)"
|
42
|
+
sleep 0.01 # Give some time to Bunny to cancel subscribtions and to close channels and connections
|
@@ -1,44 +1,44 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
# frozen_string_literal: true
|
3
|
-
|
4
|
-
require 'fleck'
|
5
|
-
|
6
|
-
user = ENV['USER'] || 'guest'
|
7
|
-
pass = ENV['PASS'] || 'guest'
|
8
|
-
|
9
|
-
CONCURRENCY = (ENV['CONCURRENCY'] || 2).to_i
|
10
|
-
SAMPLES = (ENV['SAMPLES'] || 10).to_i
|
11
|
-
QUEUE = 'consumer.initialization.example.queue'
|
12
|
-
|
13
|
-
Fleck.configure do |config|
|
14
|
-
config.default_user = user
|
15
|
-
config.default_pass = pass
|
16
|
-
config.loglevel = Logger::DEBUG
|
17
|
-
end
|
18
|
-
|
19
|
-
connection = Fleck.connection(host: '127.0.0.1', port: 5672, user: user, pass: pass, vhost: '/')
|
20
|
-
client = Fleck::Client.new(connection, QUEUE, concurrency: CONCURRENCY.to_i)
|
21
|
-
|
22
|
-
class MyConsumer < Fleck::Consumer
|
23
|
-
configure queue: QUEUE, concurrency: CONCURRENCY.to_i
|
24
|
-
actions :hello
|
25
|
-
|
26
|
-
initialize do
|
27
|
-
@value = "MY CONSUMER :) #{object_id}"
|
28
|
-
end
|
29
|
-
|
30
|
-
def hello
|
31
|
-
logger.info '---------------- HELLO ----------------'
|
32
|
-
ok! "#{@value} Hello!"
|
33
|
-
end
|
34
|
-
end
|
35
|
-
|
36
|
-
SAMPLES.to_i.times do |num|
|
37
|
-
client.request(action: 'hello', params: {num: num}, timeout: 5) do |_, response|
|
38
|
-
if response.status == 200
|
39
|
-
Fleck.logger.info response.body
|
40
|
-
else
|
41
|
-
Fleck.logger.error response.errors.join(', ')
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# frozen_string_literal: true
|
3
|
+
|
4
|
+
require 'fleck'
|
5
|
+
|
6
|
+
user = ENV['USER'] || 'guest'
|
7
|
+
pass = ENV['PASS'] || 'guest'
|
8
|
+
|
9
|
+
CONCURRENCY = (ENV['CONCURRENCY'] || 2).to_i
|
10
|
+
SAMPLES = (ENV['SAMPLES'] || 10).to_i
|
11
|
+
QUEUE = 'consumer.initialization.example.queue'
|
12
|
+
|
13
|
+
Fleck.configure do |config|
|
14
|
+
config.default_user = user
|
15
|
+
config.default_pass = pass
|
16
|
+
config.loglevel = Logger::DEBUG
|
17
|
+
end
|
18
|
+
|
19
|
+
connection = Fleck.connection(host: '127.0.0.1', port: 5672, user: user, pass: pass, vhost: '/')
|
20
|
+
client = Fleck::Client.new(connection, QUEUE, concurrency: CONCURRENCY.to_i)
|
21
|
+
|
22
|
+
class MyConsumer < Fleck::Consumer
|
23
|
+
configure queue: QUEUE, concurrency: CONCURRENCY.to_i
|
24
|
+
actions :hello
|
25
|
+
|
26
|
+
initialize do
|
27
|
+
@value = "MY CONSUMER :) #{object_id}"
|
28
|
+
end
|
29
|
+
|
30
|
+
def hello
|
31
|
+
logger.info '---------------- HELLO ----------------'
|
32
|
+
ok! "#{@value} Hello!"
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
SAMPLES.to_i.times do |num|
|
37
|
+
client.request(action: 'hello', params: {num: num}, timeout: 5) do |_, response|
|
38
|
+
if response.status == 200
|
39
|
+
Fleck.logger.info response.body
|
40
|
+
else
|
41
|
+
Fleck.logger.error response.errors.join(', ')
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
data/examples/deprecation.rb
CHANGED
@@ -1,50 +1,50 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
# encoding: utf-8
|
3
|
-
|
4
|
-
require 'fleck'
|
5
|
-
|
6
|
-
user = ENV['USER'] || 'guest'
|
7
|
-
pass = ENV['PASS'] || 'guest'
|
8
|
-
|
9
|
-
CONCURRENCY = (ENV['CONCURRENCY'] || 2).to_i
|
10
|
-
SAMPLES = (ENV['SAMPLES'] || 10).to_i
|
11
|
-
|
12
|
-
Fleck.configure do |config|
|
13
|
-
config.default_user = user
|
14
|
-
config.default_pass = pass
|
15
|
-
config.loglevel = Logger::DEBUG
|
16
|
-
end
|
17
|
-
|
18
|
-
connection = Fleck.connection(host: "127.0.0.1", port: 5672, user: user, pass: pass, vhost: "/")
|
19
|
-
client = Fleck::Client.new(connection, "deprecation.example.queue", concurrency: CONCURRENCY.to_i)
|
20
|
-
|
21
|
-
class MyConsumer < Fleck::Consumer
|
22
|
-
configure queue: 'deprecation.example.queue', concurrency: CONCURRENCY.to_i
|
23
|
-
|
24
|
-
action :hello
|
25
|
-
def hello
|
26
|
-
version = request.version || 'v1'
|
27
|
-
case version.to_s
|
28
|
-
when 'v1' then hello_v1
|
29
|
-
when 'v2' then hello_v2
|
30
|
-
else
|
31
|
-
not_found!
|
32
|
-
end
|
33
|
-
end
|
34
|
-
|
35
|
-
private
|
36
|
-
|
37
|
-
def hello_v1
|
38
|
-
deprecated!
|
39
|
-
ok! "#{request.params[:num]}. Hello V1!"
|
40
|
-
end
|
41
|
-
|
42
|
-
def hello_v2
|
43
|
-
ok! "#{request.params[:num] + 1}. Hello V2!"
|
44
|
-
end
|
45
|
-
end
|
46
|
-
|
47
|
-
SAMPLES.to_i.times do |num|
|
48
|
-
response = client.request(action: 'hello', version: (rand >= 0.5 ? 'v2' : 'v1'), params: {num: num}, timeout: 5)
|
49
|
-
puts (response.deprecated? ? "DEPRECATED: #{response.body}" : response.body)
|
50
|
-
end
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# encoding: utf-8
|
3
|
+
|
4
|
+
require 'fleck'
|
5
|
+
|
6
|
+
user = ENV['USER'] || 'guest'
|
7
|
+
pass = ENV['PASS'] || 'guest'
|
8
|
+
|
9
|
+
CONCURRENCY = (ENV['CONCURRENCY'] || 2).to_i
|
10
|
+
SAMPLES = (ENV['SAMPLES'] || 10).to_i
|
11
|
+
|
12
|
+
Fleck.configure do |config|
|
13
|
+
config.default_user = user
|
14
|
+
config.default_pass = pass
|
15
|
+
config.loglevel = Logger::DEBUG
|
16
|
+
end
|
17
|
+
|
18
|
+
connection = Fleck.connection(host: "127.0.0.1", port: 5672, user: user, pass: pass, vhost: "/")
|
19
|
+
client = Fleck::Client.new(connection, "deprecation.example.queue", concurrency: CONCURRENCY.to_i)
|
20
|
+
|
21
|
+
class MyConsumer < Fleck::Consumer
|
22
|
+
configure queue: 'deprecation.example.queue', concurrency: CONCURRENCY.to_i
|
23
|
+
|
24
|
+
action :hello
|
25
|
+
def hello
|
26
|
+
version = request.version || 'v1'
|
27
|
+
case version.to_s
|
28
|
+
when 'v1' then hello_v1
|
29
|
+
when 'v2' then hello_v2
|
30
|
+
else
|
31
|
+
not_found!
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
private
|
36
|
+
|
37
|
+
def hello_v1
|
38
|
+
deprecated!
|
39
|
+
ok! "#{request.params[:num]}. Hello V1!"
|
40
|
+
end
|
41
|
+
|
42
|
+
def hello_v2
|
43
|
+
ok! "#{request.params[:num] + 1}. Hello V2!"
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
SAMPLES.to_i.times do |num|
|
48
|
+
response = client.request(action: 'hello', version: (rand >= 0.5 ? 'v2' : 'v1'), params: {num: num}, timeout: 5)
|
49
|
+
puts (response.deprecated? ? "DEPRECATED: #{response.body}" : response.body)
|
50
|
+
end
|
data/examples/example.rb
CHANGED
@@ -1,76 +1,76 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
# frozen_string_literal: true
|
3
|
-
|
4
|
-
require 'fleck'
|
5
|
-
|
6
|
-
user = ENV['USER'] || 'guest'
|
7
|
-
pass = ENV['PASS'] || 'guest'
|
8
|
-
|
9
|
-
CONCURRENCY = (ENV['CONCURRENCY'] || 10).to_i
|
10
|
-
SAMPLES = (ENV['SAMPLES'] || 10_000).to_i
|
11
|
-
QUEUE = 'example.queue'
|
12
|
-
|
13
|
-
Fleck.configure do |config|
|
14
|
-
config.default_user = user
|
15
|
-
config.default_pass = pass
|
16
|
-
config.loglevel = Logger::DEBUG
|
17
|
-
end
|
18
|
-
|
19
|
-
client = Fleck::Client.new(Fleck.connection, QUEUE, concurrency: CONCURRENCY.to_i)
|
20
|
-
|
21
|
-
count = 0
|
22
|
-
success = 0
|
23
|
-
failure = 0
|
24
|
-
|
25
|
-
mutex = Mutex.new
|
26
|
-
lock = Mutex.new
|
27
|
-
condition = ConditionVariable.new
|
28
|
-
|
29
|
-
class First < Fleck::Consumer
|
30
|
-
configure queue: QUEUE, concurrency: CONCURRENCY.to_i
|
31
|
-
|
32
|
-
action :incr, 'Returns a message with incremented number'
|
33
|
-
param :num, type: 'number', required: true
|
34
|
-
def incr
|
35
|
-
if rand > 0.1
|
36
|
-
not_found! if request.action != 'incr'
|
37
|
-
|
38
|
-
ok! "#{params[:num].to_i + 1}. Hello, World!"
|
39
|
-
else
|
40
|
-
logger.warn "REJECTING REQUEST {headers: #{headers}, params: #{params}"
|
41
|
-
request.reject!(requeue: true)
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|
45
|
-
|
46
|
-
Thread.new do
|
47
|
-
SAMPLES.times do |i|
|
48
|
-
client.request(
|
49
|
-
action: 'incr',
|
50
|
-
params: { num: i, secret: 'supersecret' },
|
51
|
-
async: true,
|
52
|
-
timeout: 1,
|
53
|
-
rmq_options: { priority: (rand * 9).round(0), mandatory: false }
|
54
|
-
) do |request, response|
|
55
|
-
if response.status == 200
|
56
|
-
request.logger.debug response.body
|
57
|
-
else
|
58
|
-
request.logger.error "#{response.status} #{response.errors.join(', ')}"
|
59
|
-
end
|
60
|
-
mutex.synchronize do
|
61
|
-
count += 1
|
62
|
-
if response.status == 200
|
63
|
-
success += 1
|
64
|
-
else
|
65
|
-
failure += 1
|
66
|
-
end
|
67
|
-
|
68
|
-
lock.synchronize { condition.signal } if count >= SAMPLES
|
69
|
-
end
|
70
|
-
end
|
71
|
-
end
|
72
|
-
end
|
73
|
-
|
74
|
-
lock.synchronize { condition.wait(lock) }
|
75
|
-
|
76
|
-
puts "Total: #{count}, Success: #{success}, Failure: #{failure}"
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# frozen_string_literal: true
|
3
|
+
|
4
|
+
require 'fleck'
|
5
|
+
|
6
|
+
user = ENV['USER'] || 'guest'
|
7
|
+
pass = ENV['PASS'] || 'guest'
|
8
|
+
|
9
|
+
CONCURRENCY = (ENV['CONCURRENCY'] || 10).to_i
|
10
|
+
SAMPLES = (ENV['SAMPLES'] || 10_000).to_i
|
11
|
+
QUEUE = 'example.queue'
|
12
|
+
|
13
|
+
Fleck.configure do |config|
|
14
|
+
config.default_user = user
|
15
|
+
config.default_pass = pass
|
16
|
+
config.loglevel = Logger::DEBUG
|
17
|
+
end
|
18
|
+
|
19
|
+
client = Fleck::Client.new(Fleck.connection, QUEUE, concurrency: CONCURRENCY.to_i)
|
20
|
+
|
21
|
+
count = 0
|
22
|
+
success = 0
|
23
|
+
failure = 0
|
24
|
+
|
25
|
+
mutex = Mutex.new
|
26
|
+
lock = Mutex.new
|
27
|
+
condition = ConditionVariable.new
|
28
|
+
|
29
|
+
class First < Fleck::Consumer
|
30
|
+
configure queue: QUEUE, concurrency: CONCURRENCY.to_i
|
31
|
+
|
32
|
+
action :incr, 'Returns a message with incremented number'
|
33
|
+
param :num, type: 'number', required: true
|
34
|
+
def incr
|
35
|
+
if rand > 0.1
|
36
|
+
not_found! if request.action != 'incr'
|
37
|
+
|
38
|
+
ok! "#{params[:num].to_i + 1}. Hello, World!"
|
39
|
+
else
|
40
|
+
logger.warn "REJECTING REQUEST {headers: #{headers}, params: #{params}"
|
41
|
+
request.reject!(requeue: true)
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
Thread.new do
|
47
|
+
SAMPLES.times do |i|
|
48
|
+
client.request(
|
49
|
+
action: 'incr',
|
50
|
+
params: { num: i, secret: 'supersecret' },
|
51
|
+
async: true,
|
52
|
+
timeout: 1,
|
53
|
+
rmq_options: { priority: (rand * 9).round(0), mandatory: false }
|
54
|
+
) do |request, response|
|
55
|
+
if response.status == 200
|
56
|
+
request.logger.debug response.body
|
57
|
+
else
|
58
|
+
request.logger.error "#{response.status} #{response.errors.join(', ')}"
|
59
|
+
end
|
60
|
+
mutex.synchronize do
|
61
|
+
count += 1
|
62
|
+
if response.status == 200
|
63
|
+
success += 1
|
64
|
+
else
|
65
|
+
failure += 1
|
66
|
+
end
|
67
|
+
|
68
|
+
lock.synchronize { condition.signal } if count >= SAMPLES
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
lock.synchronize { condition.wait(lock) }
|
75
|
+
|
76
|
+
puts "Total: #{count}, Success: #{success}, Failure: #{failure}"
|