diagnostic_logger v2.0.0
diagnostic_logger
A thread-safe, configurable logger for the Crystal Language. This shard is still under active development, and has not been used at scale, yet.
Installation
-
Add the dependency to your
shard.yml
:dependencies: diagnostic_logger: github: lbarasti/diagnostic_logger
-
Run
shards install
Usage
require "diagnostic_logger"
logger = DiagnosticLogger.new("my-component")
logger.info("hello world") # logs "2019-11-14 02:11:12 UTC [INFO] my-component:main> hello world"
Configuring your logger
By default, diagnostic_logger
uses the following configuration.
logger:
level: INFO
appender:
class: ConsoleAppender
pattern: "%{date} | [%{level}] %{pid}>%{fiber}>%{logger} | %{msg}"
To customise it, just create a config.yml
file in the root folder of your project, and populate it with your overrides.
level
level
specifies the severity of the messages that should be logged. For example, setting level
to WARN
will suppress any log at DEBUG
or INFO
level.
Severities are defined by the Crystal standard library as DEBUG
, INFO
, WARN
, ERROR
, FATAL
, UNKNOWN
.
Although level
is set globally based on the configuration above, its value can be overridden programmatically when initialising a logger:
logger = DiagnosticLogger.new("my-component", level: :warn)
logger.info("hello") # will not log
appender
The appender
determines the target IO for your logs, based on the class
field.
class
can take the following values:
- ConsoleAppender (default): will log to
STDOUT
- FileAppender: will log to a file specified in
file
For example, to log to a file named logs.txt
, your config.yml
should include the following.
logger:
appender:
class: FileAppender
file: logs.txt
pattern
Basic template-based formatting is supported. You can interpolate the following keywords in a template string, wrapped in %{}
.
- date: the timestamp of the message in UTC format - e.g.
2020-01-01 16:21:44 UTC
- level: the severity of the message - e.g.
WARN
- logger: the name of the
DiagnosticLogger
instance - set at initialisation time - fiber: the name of the fiber logging the message
- msg: the actual content of the log
- pid: the Process ID of the process logging the message.
For example, to only log date, message and level, your config could look like the following:
logger:
pattern: "%{date} [%{level}] %{msg}"
batch
You can tune the frequency and size of log writes by specifying a batch size
and interval
, where
- size is the number of messages to keep in memory before writing to IO
- interval (in seconds) is the amount of time after which logged messagges will be written to IO, whenever the number of messages doesn't hit the specified size in the current interval.
For example, to write to IO every 30 messages - or every 5 seconds, in case fewer than 30 messages were logged in the last 5 second interval - your config.yml
should include the following.
logger:
batch:
size: 30
interval: 5
Development
Run crystal spec
to run project's tests. You can also manually run the examples under /examples
- remember to cd
into an example's folder before doing so, so that the right config.yml
is picked up.
Contributing
- Fork it (https://github.com/lbarasti/diagnostic_logger/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
Contributors
- lbarasti - creator and maintainer
diagnostic_logger
- 7
- 1
- 0
- 2
- 0
- over 4 years ago
- November 16, 2019
MIT License
Tue, 21 Jan 2025 08:56:44 GMT