loggers define an abstract and common logging interface in three flavors.
If you have been using Go for a while, you've probably been asking yourself: "Why, oh why, wasn't the standard library logger made an interface!?" Often was I faced with having to decide about what kind of logger I needed before I was ready to, wondering:
- Where's Golang's answer to log4j ?
- Is there a log4go or log4golang ?
Well this package should help. Install and call log.Info("Log all my stuff")
and you're off and you can easily switch out loggers later with only a single line of code.
All loggers are interfaces and should be declared and used as such. The actual implementations can vary and are easily switched out. The main packages should have no external dependencies. See here.
Standard interface is the same as used by the Go standard library log
package.
A common pattern for level discrete loggers using debug
, info
, warn
and error
levels, along with those defined by the standard interface.
A superset of Advanced, adds contextual logging, such that lines can have a number of additional parameters set to provide clearer separation of message and context.
go get gopkg.in/birkirb/loggers.v1
You can choose between declaring one of the three interfaces above that best suits your needs, or use the built in Contextual interface directly with a default standard library logger implementation to do your bidding. You can switch out all the loggers later as long as they satisfy the right interface.
You can use the loggers interface as a drop in replacement for the standard library logger.
Just change your import statement from "log"
to "gopkg.in/birkirb/loggers.v1/log"
.
It should work just the same and you can make use of advanced and contextual methods only if you so decide.
You can then easily switch out the log package implementation later with your own logger as long as it implements the Contextual interface.
log.Infof("Logger is started") // Defaults to stdout.
log.Logger = stdlib.NewLogger(fileWriter, "", log.LstdFlags)
log.Infof("Now logging to fileWriter") // writes to fileWriter
Declare your own project logging interface.
import (
"log"
"gopkg.in/birkirb/loggers.v1"
)
var Logger loggers.Standard
func init() {
Logger = log.New(writer, "myapp", log.LstdFlags)
Logger.Println("Logger is started")
}
A few loggers have been mapped to the above interfaces and could thus be used with any of them. Instead of the using the Standard logger as above, we could use the standard logger much like a leveled logger.
import (
"gopkg.in/birkirb/loggers.v1"
"gopkg.in/birkirb/loggers.v1/mappers/stdlib"
)
var Logger loggers.Advanced
func init() {
Logger = stdlib.NewDefaultLogger()
Logger.Info("Logger is started")
}
A level mapper exist to ease with implementing plugins/mappers for other loggers that don't naturally implement any of the designed interfaces. This can be found in the mappers package.
Any new mappers for different Go logging solutions would be most welcome.