Class: LogStash::Inputs::Azuretopicthreadable

Inherits:
Base
  • Object
show all
Defined in:
lib/logstash/inputs/azuretopicthreadable.rb

Overview

Reads events from Azure topics

Defined Under Namespace

Classes: Interrupted

Instance Method Summary collapse

Constructor Details

#initialize(*args) ⇒ Azuretopicthreadable

Returns a new instance of Azuretopicthreadable.



26
27
28
# File 'lib/logstash/inputs/azuretopicthreadable.rb', line 26

def initialize(*args)
  super(*args)
end

Instance Method Details

#process(output_queue, pid) ⇒ Object

def register



39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
# File 'lib/logstash/inputs/azuretopicthreadable.rb', line 39

def process(output_queue, pid)
  # Get a new instance of a service

  azure_service_bus = Azure::ServiceBus::ServiceBusService.new
  while true
begin
   # check if we have a message in the subscription

message = azure_service_bus.receive_subscription_message(@topic ,@subscription, { :peek_lock => true, :timeout => 1 } )
if message
    # decoding returns a yield

  codec.decode(message.body) do |event|
    output_queue << event
  end # codec.decode

  # delete the message after reading it

  azure_service_bus.delete_subscription_message(message)
end
rescue LogStash::ShutdownSignal => e
  raise e
rescue => e
  @logger.error("Oh My, An error occurred. Thread id:" + pid.to_s, :exception => e)
  if message and message.delivery_count > @deliverycount
    azure_service_bus.delete_subscription_message(message)
  end
end
  sleep(@thread_sleep_time)
  end
end

#registerObject



31
32
33
34
35
36
37
# File 'lib/logstash/inputs/azuretopicthreadable.rb', line 31

def register
 # Configure credentials

 Azure.configure do |config|
   config.sb_namespace = @namespace
   config.sb_access_key = @access_key
  end
end

#run(output_queue) ⇒ Object



67
68
69
70
71
72
73
# File 'lib/logstash/inputs/azuretopicthreadable.rb', line 67

def run(output_queue)
  threads = []
  (0..(@threads-1)).each do |pid|
    threads << Thread.new { process(output_queue, pid) }
  end
  threads.each { |thr| thr.join }
end

#teardownObject



76
77
# File 'lib/logstash/inputs/azuretopicthreadable.rb', line 76

def teardown
end