Class: Ocular::Logging::KafkaLogger
- Inherits:
-
Object
- Object
- Ocular::Logging::KafkaLogger
- Defined in:
- lib/ocular/logging/kafka_logger.rb
Overview
Most of the Logger class is copied from the Ruby Logger class source code.
Defined Under Namespace
Classes: Formatter
Instance Method Summary collapse
- #add(severity, message = nil, run_id = nil, &block) ⇒ Object
- #debug(message = nil, &block) ⇒ Object (also: #log)
- #error(message = nil, &block) ⇒ Object
- #fatal(message = nil, &block) ⇒ Object
- #info(message = nil, &block) ⇒ Object
-
#initialize(settings = nil, kafka = nil) ⇒ KafkaLogger
constructor
A new instance of KafkaLogger.
- #log_cause(type, environment, run_id = nil) ⇒ Object
- #log_event(property, value, run_id = nil) ⇒ Object
- #log_timing(key, value, run_id = nil) ⇒ Object
- #reconnect ⇒ Object
- #warn(message = nil, &block) ⇒ Object
Constructor Details
#initialize(settings = nil, kafka = nil) ⇒ KafkaLogger
Returns a new instance of KafkaLogger.
10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
# File 'lib/ocular/logging/kafka_logger.rb', line 10 def initialize(settings=nil, kafka=nil) @level = Severity::DEBUG @formatter = Formatter.new if kafka != nil @kafka = kafka else pp settings @kafka = Kafka.new(settings[:client]) end @settings = settings @producer = @kafka.producer end |
Instance Method Details
#add(severity, message = nil, run_id = nil, &block) ⇒ Object
50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 |
# File 'lib/ocular/logging/kafka_logger.rb', line 50 def add(severity, = nil, run_id = nil, &block) severity ||= Severity::UNKNOWN if severity < @level return true end if .nil? if block_given? = yield else = progname end end begin @producer.produce(@formatter.(severity, Time.now, run_id, ), topic: @settings[:topic], partition_key: run_id) @producer. rescue StandardError => e STDERR.puts "Error on producing kafka message: #{e}" STDERR.puts "Message was #{}, stacktrace: #{e.backtrace.join("\n")}" end end |
#debug(message = nil, &block) ⇒ Object Also known as: log
29 30 31 |
# File 'lib/ocular/logging/kafka_logger.rb', line 29 def debug( = nil, &block) add(Severity::DEBUG, , @run_id, &block) end |
#error(message = nil, &block) ⇒ Object
42 43 44 |
# File 'lib/ocular/logging/kafka_logger.rb', line 42 def error( = nil, &block) add(Severity::ERROR, , @run_id, &block) end |
#fatal(message = nil, &block) ⇒ Object
46 47 48 |
# File 'lib/ocular/logging/kafka_logger.rb', line 46 def fatal( = nil, &block) add(Severity::FATAL, , @run_id, &block) end |
#info(message = nil, &block) ⇒ Object
34 35 36 |
# File 'lib/ocular/logging/kafka_logger.rb', line 34 def info( = nil, &block) add(Severity::INFO, , @run_id, &block) end |
#log_cause(type, environment, run_id = nil) ⇒ Object
83 84 85 86 87 88 89 90 91 92 |
# File 'lib/ocular/logging/kafka_logger.rb', line 83 def log_cause(type, environment, run_id = nil) begin @producer.produce(@formatter.format_cause(type, environment, Time.now, run_id), topic: @settings[:topic], partition_key: run_id) @producer. rescue StandardError => e STDERR.puts "Error on producing kafka log_cause: #{e}" STDERR.puts "type: #{type}, stacktrace: #{e.backtrace.join("\n")}" end end |
#log_event(property, value, run_id = nil) ⇒ Object
73 74 75 76 77 78 79 80 81 |
# File 'lib/ocular/logging/kafka_logger.rb', line 73 def log_event(property, value, run_id = nil) begin @producer.produce(@formatter.format_event(property, value, Time.now, run_id), topic: @settings[:topic], partition_key: run_id) @producer. rescue StandardError => e STDERR.puts "Error on producing kafka log_event: #{e}" STDERR.puts "#{property} => #{value}, stacktrace: #{e.backtrace.join("\n")}" end end |
#log_timing(key, value, run_id = nil) ⇒ Object
94 95 96 97 98 99 100 101 102 103 104 |
# File 'lib/ocular/logging/kafka_logger.rb', line 94 def log_timing(key, value, run_id = nil) begin @producer.produce(@formatter.format_event("timing:" + key, value, Time.now, run_id), topic: @settings[:topic], partition_key: run_id) @producer. rescue StandardError => e STDERR.puts "Error on producing kafka log_timing: #{e}" STDERR.puts "Timing: #{key} => #{value}, stacktrace: #{e.backtrace.join("\n")}" end end |
#reconnect ⇒ Object
25 26 27 |
# File 'lib/ocular/logging/kafka_logger.rb', line 25 def reconnect() @kafka = Kafka.new(@settings[:client]) end |