-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Ongoing work to getting the logger to a point where I am happy, this
commit has been re-thinking how the logger does things like formatting and reducing the object allocations that are required throughout the logging pipeline. I also introduced things like an LRU cache for templates, and did ALOT of cleanup.
- Loading branch information
1 parent
b4cd0eb
commit a9aa9ae
Showing
27 changed files
with
308 additions
and
230 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,4 +7,4 @@ | |
/pkg/ | ||
/spec/reports/ | ||
/tmp/ | ||
/.tags | ||
/.tags* |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,2 @@ | ||
require 'semlogr/version' | ||
require 'semlogr/log_configurator' | ||
require 'semlogr/logger' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
require 'json' | ||
|
||
module Semlogr | ||
module Formatters | ||
class JsonFormatter | ||
def format(log_event) | ||
entry = { | ||
timestamp: log_event.timestamp, | ||
level: log_event.level, | ||
message: render_message(log_event) | ||
} | ||
|
||
if log_event.error | ||
entry[:error] = { | ||
type: log_event.error.class, | ||
message: log_event.error.message, | ||
backtrace: log_event.error.backtrace | ||
} | ||
end | ||
|
||
if log_event.properties.any? | ||
entry[:properties] = log_event.properties | ||
end | ||
|
||
"#{entry.to_json}\n" | ||
end | ||
|
||
private | ||
|
||
def render_message(log_event) | ||
output = String.new | ||
|
||
log_event.render(output) | ||
|
||
output | ||
end | ||
end | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
module Semlogr | ||
module Formatters | ||
class PropertyValueFormatter | ||
QUOTE = "\"" | ||
|
||
def self.format(output, property_value) | ||
return unless property_value | ||
|
||
case property_value | ||
when String | ||
output << QUOTE | ||
output << property_value | ||
output << QUOTE | ||
when StandardError | ||
output << "#{property_value.class}: #{property_value.message}" | ||
|
||
if property_value.backtrace | ||
output << "\n\s\s#{property_value.backtrace.join("\n\s\s")}\n" | ||
else | ||
output << "\n" | ||
end | ||
else | ||
output << property_value.to_s | ||
end | ||
end | ||
end | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
require 'semlogr/templates/parser' | ||
require 'semlogr/properties/output_properties' | ||
require 'semlogr/templates/property_token' | ||
|
||
module Semlogr | ||
module Formatters | ||
class TextFormatter | ||
DEFAULT_TEMPLATE = "[{timestamp}] {level}: {message}\n{error}" | ||
|
||
def initialize(template: DEFAULT_TEMPLATE) | ||
@template = Templates::Parser.parse(template) | ||
end | ||
|
||
def format(log_event) | ||
output = String.new | ||
properties = Properties::OutputProperties.create(log_event) | ||
|
||
@template.tokens.each do |token| | ||
case token | ||
when Templates::PropertyToken | ||
if token.property_name == :message | ||
log_event.render(output) | ||
else | ||
next unless properties[token.property_name] | ||
|
||
token.render(output, properties) | ||
end | ||
else | ||
token.render(output, properties) | ||
end | ||
end | ||
|
||
output | ||
end | ||
end | ||
end | ||
end |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
module Semlogr | ||
class LogLevel | ||
include Comparable | ||
|
||
attr_reader :level | ||
|
||
def initialize(level, level_string) | ||
@level = level | ||
@level_string = level_string | ||
end | ||
|
||
def <=>(log_level) | ||
@level <=> log_level.level | ||
end | ||
|
||
def to_s | ||
@level_string | ||
end | ||
|
||
DEBUG = LogLevel.new(::Logger::DEBUG, 'DEBUG') | ||
INFO = LogLevel.new(::Logger::INFO, 'INFO') | ||
WARN = LogLevel.new(::Logger::WARN, 'WARN') | ||
ERROR = LogLevel.new(::Logger::ERROR, 'ERROR') | ||
FATAL = LogLevel.new(::Logger::FATAL, 'FATAL') | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
module Semlogr | ||
class LoggerConfiguration | ||
attr_reader :level | ||
attr_reader :sinks | ||
|
||
def initialize | ||
@level = ::Logger::DEBUG | ||
@sinks = [] | ||
end | ||
|
||
def min_level(level) | ||
@level = level | ||
end | ||
|
||
def write_to(sink) | ||
@sinks << sink | ||
end | ||
end | ||
end |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.