Class: Fluent::Plugin::SQSInput

Inherits:
Input
  • Object
show all
Defined in:
lib/fluent/plugin/in_sqs.rb

Instance Method Summary collapse

Instance Method Details

#clientObject



38
39
40
# File 'lib/fluent/plugin/in_sqs.rb', line 38

def client
  @client ||= Aws::SQS::Client.new(stub_responses: @stub_responses)
end

#configure(conf) ⇒ Object



22
23
24
25
26
27
28
29
30
# File 'lib/fluent/plugin/in_sqs.rb', line 22

def configure(conf)
  super

  Aws.config = {
    access_key_id: @aws_key_id,
    secret_access_key: @aws_sec_key,
    region: @region
  }
end

#queueObject



42
43
44
# File 'lib/fluent/plugin/in_sqs.rb', line 42

def queue
  @queue ||= Aws::SQS::Resource.new(client: client).queue(@sqs_url)
end

#runObject



50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
# File 'lib/fluent/plugin/in_sqs.rb', line 50

def run
  queue.receive_messages(
    max_number_of_messages: @max_number_of_messages,
    wait_time_seconds: @wait_time_seconds,
    visibility_timeout: @visibility_timeout
  ).each do |message|
    record = parse_message(message)

    message.delete if @delete_message

    router.emit(@tag, Fluent::Engine.now, record)
  end
rescue
  log.error 'failed to emit or receive', error: $ERROR_INFO.to_s, error_class: $ERROR_INFO.class.to_s
  log.warn_backtrace $ERROR_INFO.backtrace
end

#shutdownObject



46
47
48
# File 'lib/fluent/plugin/in_sqs.rb', line 46

def shutdown
  super
end

#startObject



32
33
34
35
36
# File 'lib/fluent/plugin/in_sqs.rb', line 32

def start
  super

  timer_execute(:in_sqs_run_periodic_timer, @receive_interval, &method(:run))
end