-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathstream-server-thread-pool.rb
48 lines (38 loc) · 1.13 KB
/
stream-server-thread-pool.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
require 'bundler/setup'
require 'bunny'
require 'json'
require 'thread/pool'
require 'logger'
require_relative 'rpc-helper'
thread_pool = Thread.pool(3)
amqp_conn = Bunny.new
amqp_conn.start
RPCHelper.serve(
end_point: 'integer-addition-with-progress',
amqp_conn: amqp_conn,
thread_pool: thread_pool,
subscribe_opts: {
block: true,
manual_ack: true
}) do |delivery_info, metadata, payload, publish_helper|
# simulate a long running task
max = 50 + rand(100)
current = 0
while current < max
sleep rand(500)/1000.0
current += rand(30)
current = max if current > max
# Progress report, it needs to be a string
publish_helper.publish({progress: {current: current, max: max}}.to_json)
# simulate failing requests
if rand > 0.95
# An Exception indicates task was not completed, it will be retried
raise RuntimeError, 'Not in a mood to process :)'
end
end
operands = JSON.parse(payload)
result = {result: operands['x'].to_i + operands['y'].to_i}
# Return value from this block will be the final result of processing
# It needs to be string
result.to_json
end