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
- #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 |
# 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 @kafka = Kafka.new(settings[:client]) end @settings = settings @producer = @kafka.producer end |
Instance Method Details
#add(severity, message = nil, run_id = nil, &block) ⇒ Object
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'lib/ocular/logging/kafka_logger.rb', line 45 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 @producer.produce(@formatter.(severity, Time.now, run_id, ), topic: @settings[:topic], partition_key: run_id) @producer. end |
#debug(message = nil, &block) ⇒ Object Also known as: log
24 25 26 |
# File 'lib/ocular/logging/kafka_logger.rb', line 24 def debug( = nil, &block) add(Severity::DEBUG, , @run_id, &block) end |
#error(message = nil, &block) ⇒ Object
37 38 39 |
# File 'lib/ocular/logging/kafka_logger.rb', line 37 def error( = nil, &block) add(Severity::ERROR, , @run_id, &block) end |
#fatal(message = nil, &block) ⇒ Object
41 42 43 |
# File 'lib/ocular/logging/kafka_logger.rb', line 41 def fatal( = nil, &block) add(Severity::FATAL, , @run_id, &block) end |
#info(message = nil, &block) ⇒ Object
29 30 31 |
# File 'lib/ocular/logging/kafka_logger.rb', line 29 def info( = nil, &block) add(Severity::INFO, , @run_id, &block) end |
#log_cause(type, environment, run_id = nil) ⇒ Object
68 69 70 71 |
# File 'lib/ocular/logging/kafka_logger.rb', line 68 def log_cause(type, environment, run_id = nil) @producer.produce(@formatter.format_cause(type, environment, Time.now, run_id), topic: @settings[:topic], partition_key: run_id) @producer. end |
#log_event(property, value, run_id = nil) ⇒ Object
63 64 65 66 |
# File 'lib/ocular/logging/kafka_logger.rb', line 63 def log_event(property, value, run_id = nil) @producer.produce(@formatter.format_event(property, value, Time.now, run_id), topic: @settings[:topic], partition_key: run_id) @producer. end |
#log_timing(key, value, run_id = nil) ⇒ Object
73 74 75 76 |
# File 'lib/ocular/logging/kafka_logger.rb', line 73 def log_timing(key, value, run_id = nil) @producer.produce(@formatter.format_event("timing:" + key, value, Time.now, run_id), topic: @settings[:topic], partition_key: run_id) @producer. end |