|
|
|
@ -1,11 +1,12 @@
|
|
|
|
|
go-log
|
|
|
|
|
================
|
|
|
|
|
|
|
|
|
|
[data:image/s3,"s3://crabby-images/c5c86/c5c86088f432a59743e964230ebb75bb0b5f1704" alt="GoDoc"](https://godoc.org/github.com/subchen/go-log)
|
|
|
|
|
[data:image/s3,"s3://crabby-images/bc1ee/bc1ee4d2264e58dc8e9fbf7252a5a80c29ddc54d" alt="Build Status"](https://travis-ci.org/subchen/go-log)
|
|
|
|
|
[data:image/s3,"s3://crabby-images/ddbd8/ddbd803859031efff1fba894f8e6058dcc29db78" alt="Coverage Status"](https://coveralls.io/github/subchen/go-log?branch=master)
|
|
|
|
|
[data:image/s3,"s3://crabby-images/ece71/ece7149507df5208fcd5eb2afe2c6ae7bc6e9aaf" alt="Go Report Card"](https://goreportcard.com/report/github.com/subchen/go-log)
|
|
|
|
|
<!--
|
|
|
|
|
[data:image/s3,"s3://crabby-images/76567/76567ee7a087b59807229519c240ea6da4ffeb19" alt="GoDoc"](https://godoc.org/github.com/fangdingjun/go-log)
|
|
|
|
|
[data:image/s3,"s3://crabby-images/ba9cf/ba9cfb369f49e1dc62a64d13c512db41562b7d43" alt="Build Status"](https://travis-ci.org/fangdingjun/go-log)
|
|
|
|
|
[data:image/s3,"s3://crabby-images/966b9/966b9e8350adc30a72ce064d25ae608709b6a046" alt="Coverage Status"](https://coveralls.io/github/fangdingjun/go-log?branch=master)
|
|
|
|
|
[data:image/s3,"s3://crabby-images/c4b94/c4b94e057e3e870c628a63b9cddd6b9ba50b9837" alt="Go Report Card"](https://goreportcard.com/report/github.com/fangdingjun/go-log)
|
|
|
|
|
[data:image/s3,"s3://crabby-images/82f91/82f9125f866408f18ef30bf2f4f3080feaadf7e3" alt="License"](http://www.apache.org/licenses/LICENSE-2.0)
|
|
|
|
|
-->
|
|
|
|
|
|
|
|
|
|
Logging package similar to log4j for the Golang.
|
|
|
|
|
|
|
|
|
@ -13,7 +14,7 @@ Logging package similar to log4j for the Golang.
|
|
|
|
|
- Support customized formatter
|
|
|
|
|
- TextFormatter
|
|
|
|
|
- JSONFormatter
|
|
|
|
|
- Support multiple rolling file writers
|
|
|
|
|
- Support multiple rolling file log
|
|
|
|
|
- FixedSizeFileWriter
|
|
|
|
|
- DailyFileWriter
|
|
|
|
|
- AlwaysNewFileWriter
|
|
|
|
@ -22,7 +23,7 @@ Installation
|
|
|
|
|
---------------
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
$ go get github.com/subchen/go-log
|
|
|
|
|
$ go get github.com/fangdingjun/go-log
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Usage
|
|
|
|
@ -34,7 +35,7 @@ package main
|
|
|
|
|
import (
|
|
|
|
|
"os"
|
|
|
|
|
"errors"
|
|
|
|
|
"github.com/subchen/go-log"
|
|
|
|
|
"github.com/fangdingjun/go-log"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
@ -55,23 +56,23 @@ Default log to console, you can set `Logger.Out` to set a file writer into log.
|
|
|
|
|
|
|
|
|
|
```go
|
|
|
|
|
import (
|
|
|
|
|
"github.com/subchen/go-log"
|
|
|
|
|
"github.com/subchen/go-log/writers"
|
|
|
|
|
"github.com/fangdingjun/go-log"
|
|
|
|
|
"github.com/fangdingjun/go-log/log"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
log.Default.Out = &writers.FixedSizeFileWriter{
|
|
|
|
|
log.Default.Out = &log.FixedSizeFileWriter{
|
|
|
|
|
Name: "/tmp/test.log",
|
|
|
|
|
MaxSize: 10 * 1024 * 1024, // 10m
|
|
|
|
|
MaxCount: 10,
|
|
|
|
|
})
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Three builtin writers for use
|
|
|
|
|
Three builtin log for use
|
|
|
|
|
|
|
|
|
|
```go
|
|
|
|
|
// Create log file if file size large than fixed size (10m)
|
|
|
|
|
// files: /tmp/test.log.0 .. test.log.10
|
|
|
|
|
&writers.FixedSizeFileWriter{
|
|
|
|
|
&log.FixedSizeFileWriter{
|
|
|
|
|
Name: "/tmp/test.log",
|
|
|
|
|
MaxSize: 10 * 1024 * 1024, // 10m
|
|
|
|
|
MaxCount: 10,
|
|
|
|
@ -79,14 +80,14 @@ Three builtin writers for use
|
|
|
|
|
|
|
|
|
|
// Create log file every day.
|
|
|
|
|
// files: /tmp/test.log.20160102
|
|
|
|
|
&writers.DailyFileWriter{
|
|
|
|
|
&log.DailyFileWriter{
|
|
|
|
|
Name: "/tmp/test.log",
|
|
|
|
|
MaxCount: 10,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Create log file every process.
|
|
|
|
|
// files: /tmp/test.log.20160102_150405
|
|
|
|
|
&writers.AlwaysNewFileWriter{
|
|
|
|
|
&log.AlwaysNewFileWriter{
|
|
|
|
|
Name: "/tmp/test.log",
|
|
|
|
|
MaxCount: 10,
|
|
|
|
|
}
|
|
|
|
@ -94,7 +95,7 @@ Three builtin writers for use
|
|
|
|
|
// Output to multiple writes
|
|
|
|
|
io.MultiWriter(
|
|
|
|
|
os.Stdout,
|
|
|
|
|
&writers.DailyFileWriter{
|
|
|
|
|
&log.DailyFileWriter{
|
|
|
|
|
Name: "/tmp/test.log",
|
|
|
|
|
MaxCount: 10,
|
|
|
|
|
}
|
|
|
|
@ -106,11 +107,10 @@ io.MultiWriter(
|
|
|
|
|
|
|
|
|
|
```go
|
|
|
|
|
import (
|
|
|
|
|
"github.com/subchen/go-log"
|
|
|
|
|
"github.com/subchen/go-log/formatters"
|
|
|
|
|
"github.com/fangdingjun/go-log"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
log.Default.Formatter = new(formatters.TextFormatter)
|
|
|
|
|
log.Default.Formatter = new(log.TextFormatter)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -118,13 +118,13 @@ log.Default.Formatter = new(formatters.TextFormatter)
|
|
|
|
|
|
|
|
|
|
```go
|
|
|
|
|
import (
|
|
|
|
|
"github.com/subchen/go-log"
|
|
|
|
|
"github.com/fangdingjun/go-log"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
|
logger := &log.Logger{
|
|
|
|
|
Level: log.INFO,
|
|
|
|
|
Formatter: new(formatters.JSONFormatter),
|
|
|
|
|
Formatter: new(log.JSONFormatter),
|
|
|
|
|
Out: os.Stdout,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|