@@ -221,8 +221,12 @@ def register
221221
222222 public
223223 def run ( logstash_queue )
224- @runner_consumers = consumer_threads . times . map { |i | create_consumer ( "#{ client_id } -#{ i } " ) }
225- @runner_threads = @runner_consumers . map { |consumer | thread_runner ( logstash_queue , consumer ) }
224+ @runner_consumers = consumer_threads . times . map do |index |
225+ create_consumer ( "#{ client_id } -#{ index } " )
226+ end
227+ @runner_threads = @runner_consumers . map . with_index do |consumer , index |
228+ thread_runner ( logstash_queue , consumer , index )
229+ end
226230 @runner_threads . each { |t | t . join }
227231 end # def run
228232
@@ -237,9 +241,11 @@ def kafka_consumers
237241 end
238242
239243 private
240- def thread_runner ( logstash_queue , consumer )
244+ def thread_runner ( logstash_queue , consumer , consumer_index )
245+ consumer_identifier = "#{ client_id } -#{ consumer_index } "
241246 Thread . new do
242247 begin
248+ logger . info ( "opening consumer #{ consumer_identifier } " )
243249 unless @topics_pattern . nil?
244250 nooplistener = org . apache . kafka . clients . consumer . internals . NoOpConsumerRebalanceListener . new
245251 pattern = java . util . regex . Pattern . compile ( @topics_pattern )
@@ -270,8 +276,15 @@ def thread_runner(logstash_queue, consumer)
270276 end
271277 end
272278 rescue org . apache . kafka . common . errors . WakeupException => e
273- raise e if !stop?
279+ unless stop?
280+ logger . error ( "wakeup exception in consumer #{ consumer_identifier } : #{ e } " )
281+ raise e
282+ end
283+ rescue => e
284+ logger . error ( "uncaught exception in consumer #{ consumer_identifier } : #{ e } " )
285+ raise e
274286 ensure
287+ logger . info ( "closing consumer #{ consumer_identifier } " )
275288 consumer . close
276289 end
277290 end
0 commit comments