The logging
package provides a simple, flexible, and color-coded logging system for Golang. Below are the main features and methods of the package:
NewLogger(prefix string, minLevel LogLevel, output io.Writer) *Logger
:
Creates a new logger instance.prefix
: A string prefix added to all log messages.minLevel
: The minimum log level to output (DEBUG
,INFO
,WARN
,ERROR
). Messages below this level are ignored.output
: The destination for log output (e.g.,os.Stdout
,os.Stderr
, or anyio.Writer
). Defaults toos.Stdout
ifnil
.
- DEBUG: Used for detailed debug information.
- INFO: General informational messages.
- WARN: Warnings about potential issues.
- ERROR: Critical errors.
-
Info(message string)
:
Logs an informational message with the log level INFO. -
Debug(message string)
:
Logs a debug message with the log level DEBUG. -
Warn(message string)
:
Logs a warning message with the log level WARN. -
Error(message string)
:
Logs an error message with the log level ERROR.
-
Color-Coded Logs:
Log messages are color-coded based on the log level:- DEBUG: Green
- INFO: Blue
- WARN: Yellow
- ERROR: Red
-
Timestamped Logs:
Each log message includes a timestamp in the formatYYYY-MM-DD HH:MM:SS
. -
Log Filtering by Level:
Logs below the specified minimum level (minLevel
) are ignored. -
Custom Output:
Logs can be directed to anyio.Writer
, allowing flexible output destinations (e.g., files, network connections). -
Disable Colors:
ThedisableColors
field in theLogger
struct can be set totrue
to disable color codes (useful for testing or plain-text logs).
- If the
minLevel
is set toDEBUG
, all log messages will be displayed. - Logs are automatically flushed to the configured output as soon as they're written.
- To log without colors (e.g., for testing), set the
disableColors
field totrue
in theLogger
instance.
For examples of each function, please checkout EXAMPLES.md