Class: BasicJRPC::Server
- Inherits:
-
Object
- Object
- BasicJRPC::Server
- Defined in:
- lib/basicjrpc/server.rb
Instance Method Summary collapse
-
#initialize(queue, injected_class) ⇒ Server
constructor
A new instance of Server.
- #listen ⇒ Object
- #terminate ⇒ Object
Constructor Details
#initialize(queue, injected_class) ⇒ Server
4 5 6 7 8 9 |
# File 'lib/basicjrpc/server.rb', line 4 def initialize queue, injected_class @injected_class = injected_class @queue = queue #@nsq_consumer = Nsq::Consumer.new(nsqlookupd: 'dockerlb:4161', topic: @queue, channel: 'server') @redis = Redis.new(host: "redis") end |
Instance Method Details
#listen ⇒ Object
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
# File 'lib/basicjrpc/server.rb', line 11 def listen puts "Listening..." while true redis_response = @redis.brpop(@queue, { :timeout => 10 }) next if redis_response.nil? = redis_response[1] #message = @nsq_consumer.pop payload = Oj.load() puts "Processing message #{payload.message_id} #{payload.method_name} #{payload.method_arguments} #{payload.callers}" # Should always return a data object response = @injected_class.send(payload.method_name, *payload.method_arguments) @redis.rpush(payload., Oj.dump(response)) #message.finish end rescue Exception => e #message.finish #terminate raise e end |
#terminate ⇒ Object
35 36 37 |
# File 'lib/basicjrpc/server.rb', line 35 def terminate #@nsq_consumer.terminate end |