annotate vendor/github.com/sirupsen/logrus/README.md @ 68:4b79810863f6 draft

Ready to release 0.6.0 Signed-off-by: Izuru Yakumo <yakumo.izuru@chaotic.ninja>
author yakumo.izuru
date Wed, 13 Sep 2023 10:49:50 +0000
parents 787b5ee0289d
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
66
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
1 # Logrus <img src="http://i.imgur.com/hTeVwmJ.png" width="40" height="40" alt=":walrus:" class="emoji" title=":walrus:"/> [![Build Status](https://github.com/sirupsen/logrus/workflows/CI/badge.svg)](https://github.com/sirupsen/logrus/actions?query=workflow%3ACI) [![Build Status](https://travis-ci.org/sirupsen/logrus.svg?branch=master)](https://travis-ci.org/sirupsen/logrus) [![Go Reference](https://pkg.go.dev/badge/github.com/sirupsen/logrus.svg)](https://pkg.go.dev/github.com/sirupsen/logrus)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
2
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
3 Logrus is a structured logger for Go (golang), completely API compatible with
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
4 the standard library logger.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
5
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
6 **Logrus is in maintenance-mode.** We will not be introducing new features. It's
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
7 simply too hard to do in a way that won't break many people's projects, which is
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
8 the last thing you want from your Logging library (again...).
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
9
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
10 This does not mean Logrus is dead. Logrus will continue to be maintained for
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
11 security, (backwards compatible) bug fixes, and performance (where we are
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
12 limited by the interface).
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
13
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
14 I believe Logrus' biggest contribution is to have played a part in today's
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
15 widespread use of structured logging in Golang. There doesn't seem to be a
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
16 reason to do a major, breaking iteration into Logrus V2, since the fantastic Go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
17 community has built those independently. Many fantastic alternatives have sprung
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
18 up. Logrus would look like those, had it been re-designed with what we know
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
19 about structured logging in Go today. Check out, for example,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
20 [Zerolog][zerolog], [Zap][zap], and [Apex][apex].
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
21
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
22 [zerolog]: https://github.com/rs/zerolog
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
23 [zap]: https://github.com/uber-go/zap
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
24 [apex]: https://github.com/apex/log
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
25
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
26 **Seeing weird case-sensitive problems?** It's in the past been possible to
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
27 import Logrus as both upper- and lower-case. Due to the Go package environment,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
28 this caused issues in the community and we needed a standard. Some environments
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
29 experienced problems with the upper-case variant, so the lower-case was decided.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
30 Everything using `logrus` will need to use the lower-case:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
31 `github.com/sirupsen/logrus`. Any package that isn't, should be changed.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
32
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
33 To fix Glide, see [these
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
34 comments](https://github.com/sirupsen/logrus/issues/553#issuecomment-306591437).
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
35 For an in-depth explanation of the casing issue, see [this
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
36 comment](https://github.com/sirupsen/logrus/issues/570#issuecomment-313933276).
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
37
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
38 Nicely color-coded in development (when a TTY is attached, otherwise just
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
39 plain text):
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
40
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
41 ![Colored](http://i.imgur.com/PY7qMwd.png)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
42
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
43 With `log.SetFormatter(&log.JSONFormatter{})`, for easy parsing by logstash
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
44 or Splunk:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
45
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
46 ```json
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
47 {"animal":"walrus","level":"info","msg":"A group of walrus emerges from the
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
48 ocean","size":10,"time":"2014-03-10 19:57:38.562264131 -0400 EDT"}
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
49
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
50 {"level":"warning","msg":"The group's number increased tremendously!",
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
51 "number":122,"omg":true,"time":"2014-03-10 19:57:38.562471297 -0400 EDT"}
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
52
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
53 {"animal":"walrus","level":"info","msg":"A giant walrus appears!",
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
54 "size":10,"time":"2014-03-10 19:57:38.562500591 -0400 EDT"}
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
55
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
56 {"animal":"walrus","level":"info","msg":"Tremendously sized cow enters the ocean.",
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
57 "size":9,"time":"2014-03-10 19:57:38.562527896 -0400 EDT"}
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
58
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
59 {"level":"fatal","msg":"The ice breaks!","number":100,"omg":true,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
60 "time":"2014-03-10 19:57:38.562543128 -0400 EDT"}
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
61 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
62
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
63 With the default `log.SetFormatter(&log.TextFormatter{})` when a TTY is not
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
64 attached, the output is compatible with the
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
65 [logfmt](http://godoc.org/github.com/kr/logfmt) format:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
66
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
67 ```text
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
68 time="2015-03-26T01:27:38-04:00" level=debug msg="Started observing beach" animal=walrus number=8
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
69 time="2015-03-26T01:27:38-04:00" level=info msg="A group of walrus emerges from the ocean" animal=walrus size=10
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
70 time="2015-03-26T01:27:38-04:00" level=warning msg="The group's number increased tremendously!" number=122 omg=true
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
71 time="2015-03-26T01:27:38-04:00" level=debug msg="Temperature changes" temperature=-4
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
72 time="2015-03-26T01:27:38-04:00" level=panic msg="It's over 9000!" animal=orca size=9009
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
73 time="2015-03-26T01:27:38-04:00" level=fatal msg="The ice breaks!" err=&{0x2082280c0 map[animal:orca size:9009] 2015-03-26 01:27:38.441574009 -0400 EDT panic It's over 9000!} number=100 omg=true
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
74 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
75 To ensure this behaviour even if a TTY is attached, set your formatter as follows:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
76
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
77 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
78 log.SetFormatter(&log.TextFormatter{
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
79 DisableColors: true,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
80 FullTimestamp: true,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
81 })
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
82 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
83
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
84 #### Logging Method Name
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
85
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
86 If you wish to add the calling method as a field, instruct the logger via:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
87 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
88 log.SetReportCaller(true)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
89 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
90 This adds the caller as 'method' like so:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
91
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
92 ```json
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
93 {"animal":"penguin","level":"fatal","method":"github.com/sirupsen/arcticcreatures.migrate","msg":"a penguin swims by",
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
94 "time":"2014-03-10 19:57:38.562543129 -0400 EDT"}
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
95 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
96
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
97 ```text
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
98 time="2015-03-26T01:27:38-04:00" level=fatal method=github.com/sirupsen/arcticcreatures.migrate msg="a penguin swims by" animal=penguin
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
99 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
100 Note that this does add measurable overhead - the cost will depend on the version of Go, but is
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
101 between 20 and 40% in recent tests with 1.6 and 1.7. You can validate this in your
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
102 environment via benchmarks:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
103 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
104 go test -bench=.*CallerTracing
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
105 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
106
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
107
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
108 #### Case-sensitivity
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
109
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
110 The organization's name was changed to lower-case--and this will not be changed
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
111 back. If you are getting import conflicts due to case sensitivity, please use
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
112 the lower-case import: `github.com/sirupsen/logrus`.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
113
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
114 #### Example
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
115
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
116 The simplest way to use Logrus is simply the package-level exported logger:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
117
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
118 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
119 package main
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
120
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
121 import (
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
122 log "github.com/sirupsen/logrus"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
123 )
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
124
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
125 func main() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
126 log.WithFields(log.Fields{
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
127 "animal": "walrus",
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
128 }).Info("A walrus appears")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
129 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
130 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
131
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
132 Note that it's completely api-compatible with the stdlib logger, so you can
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
133 replace your `log` imports everywhere with `log "github.com/sirupsen/logrus"`
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
134 and you'll now have the flexibility of Logrus. You can customize it all you
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
135 want:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
136
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
137 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
138 package main
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
139
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
140 import (
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
141 "os"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
142 log "github.com/sirupsen/logrus"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
143 )
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
144
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
145 func init() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
146 // Log as JSON instead of the default ASCII formatter.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
147 log.SetFormatter(&log.JSONFormatter{})
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
148
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
149 // Output to stdout instead of the default stderr
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
150 // Can be any io.Writer, see below for File example
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
151 log.SetOutput(os.Stdout)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
152
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
153 // Only log the warning severity or above.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
154 log.SetLevel(log.WarnLevel)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
155 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
156
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
157 func main() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
158 log.WithFields(log.Fields{
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
159 "animal": "walrus",
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
160 "size": 10,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
161 }).Info("A group of walrus emerges from the ocean")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
162
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
163 log.WithFields(log.Fields{
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
164 "omg": true,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
165 "number": 122,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
166 }).Warn("The group's number increased tremendously!")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
167
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
168 log.WithFields(log.Fields{
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
169 "omg": true,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
170 "number": 100,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
171 }).Fatal("The ice breaks!")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
172
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
173 // A common pattern is to re-use fields between logging statements by re-using
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
174 // the logrus.Entry returned from WithFields()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
175 contextLogger := log.WithFields(log.Fields{
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
176 "common": "this is a common field",
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
177 "other": "I also should be logged always",
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
178 })
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
179
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
180 contextLogger.Info("I'll be logged with common and other field")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
181 contextLogger.Info("Me too")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
182 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
183 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
184
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
185 For more advanced usage such as logging to multiple locations from the same
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
186 application, you can also create an instance of the `logrus` Logger:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
187
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
188 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
189 package main
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
190
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
191 import (
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
192 "os"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
193 "github.com/sirupsen/logrus"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
194 )
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
195
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
196 // Create a new instance of the logger. You can have any number of instances.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
197 var log = logrus.New()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
198
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
199 func main() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
200 // The API for setting attributes is a little different than the package level
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
201 // exported logger. See Godoc.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
202 log.Out = os.Stdout
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
203
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
204 // You could set this to any `io.Writer` such as a file
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
205 // file, err := os.OpenFile("logrus.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
206 // if err == nil {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
207 // log.Out = file
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
208 // } else {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
209 // log.Info("Failed to log to file, using default stderr")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
210 // }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
211
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
212 log.WithFields(logrus.Fields{
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
213 "animal": "walrus",
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
214 "size": 10,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
215 }).Info("A group of walrus emerges from the ocean")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
216 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
217 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
218
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
219 #### Fields
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
220
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
221 Logrus encourages careful, structured logging through logging fields instead of
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
222 long, unparseable error messages. For example, instead of: `log.Fatalf("Failed
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
223 to send event %s to topic %s with key %d")`, you should log the much more
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
224 discoverable:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
225
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
226 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
227 log.WithFields(log.Fields{
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
228 "event": event,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
229 "topic": topic,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
230 "key": key,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
231 }).Fatal("Failed to send event")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
232 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
233
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
234 We've found this API forces you to think about logging in a way that produces
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
235 much more useful logging messages. We've been in countless situations where just
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
236 a single added field to a log statement that was already there would've saved us
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
237 hours. The `WithFields` call is optional.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
238
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
239 In general, with Logrus using any of the `printf`-family functions should be
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
240 seen as a hint you should add a field, however, you can still use the
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
241 `printf`-family functions with Logrus.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
242
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
243 #### Default Fields
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
244
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
245 Often it's helpful to have fields _always_ attached to log statements in an
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
246 application or parts of one. For example, you may want to always log the
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
247 `request_id` and `user_ip` in the context of a request. Instead of writing
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
248 `log.WithFields(log.Fields{"request_id": request_id, "user_ip": user_ip})` on
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
249 every line, you can create a `logrus.Entry` to pass around instead:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
250
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
251 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
252 requestLogger := log.WithFields(log.Fields{"request_id": request_id, "user_ip": user_ip})
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
253 requestLogger.Info("something happened on that request") # will log request_id and user_ip
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
254 requestLogger.Warn("something not great happened")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
255 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
256
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
257 #### Hooks
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
258
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
259 You can add hooks for logging levels. For example to send errors to an exception
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
260 tracking service on `Error`, `Fatal` and `Panic`, info to StatsD or log to
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
261 multiple places simultaneously, e.g. syslog.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
262
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
263 Logrus comes with [built-in hooks](hooks/). Add those, or your custom hook, in
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
264 `init`:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
265
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
266 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
267 import (
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
268 log "github.com/sirupsen/logrus"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
269 "gopkg.in/gemnasium/logrus-airbrake-hook.v2" // the package is named "airbrake"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
270 logrus_syslog "github.com/sirupsen/logrus/hooks/syslog"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
271 "log/syslog"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
272 )
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
273
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
274 func init() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
275
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
276 // Use the Airbrake hook to report errors that have Error severity or above to
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
277 // an exception tracker. You can create custom hooks, see the Hooks section.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
278 log.AddHook(airbrake.NewHook(123, "xyz", "production"))
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
279
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
280 hook, err := logrus_syslog.NewSyslogHook("udp", "localhost:514", syslog.LOG_INFO, "")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
281 if err != nil {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
282 log.Error("Unable to connect to local syslog daemon")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
283 } else {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
284 log.AddHook(hook)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
285 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
286 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
287 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
288 Note: Syslog hook also support connecting to local syslog (Ex. "/dev/log" or "/var/run/syslog" or "/var/run/log"). For the detail, please check the [syslog hook README](hooks/syslog/README.md).
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
289
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
290 A list of currently known service hooks can be found in this wiki [page](https://github.com/sirupsen/logrus/wiki/Hooks)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
291
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
292
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
293 #### Level logging
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
294
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
295 Logrus has seven logging levels: Trace, Debug, Info, Warning, Error, Fatal and Panic.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
296
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
297 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
298 log.Trace("Something very low level.")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
299 log.Debug("Useful debugging information.")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
300 log.Info("Something noteworthy happened!")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
301 log.Warn("You should probably take a look at this.")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
302 log.Error("Something failed but I'm not quitting.")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
303 // Calls os.Exit(1) after logging
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
304 log.Fatal("Bye.")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
305 // Calls panic() after logging
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
306 log.Panic("I'm bailing.")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
307 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
308
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
309 You can set the logging level on a `Logger`, then it will only log entries with
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
310 that severity or anything above it:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
311
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
312 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
313 // Will log anything that is info or above (warn, error, fatal, panic). Default.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
314 log.SetLevel(log.InfoLevel)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
315 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
316
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
317 It may be useful to set `log.Level = logrus.DebugLevel` in a debug or verbose
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
318 environment if your application has that.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
319
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
320 #### Entries
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
321
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
322 Besides the fields added with `WithField` or `WithFields` some fields are
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
323 automatically added to all logging events:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
324
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
325 1. `time`. The timestamp when the entry was created.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
326 2. `msg`. The logging message passed to `{Info,Warn,Error,Fatal,Panic}` after
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
327 the `AddFields` call. E.g. `Failed to send event.`
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
328 3. `level`. The logging level. E.g. `info`.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
329
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
330 #### Environments
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
331
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
332 Logrus has no notion of environment.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
333
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
334 If you wish for hooks and formatters to only be used in specific environments,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
335 you should handle that yourself. For example, if your application has a global
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
336 variable `Environment`, which is a string representation of the environment you
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
337 could do:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
338
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
339 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
340 import (
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
341 log "github.com/sirupsen/logrus"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
342 )
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
343
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
344 func init() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
345 // do something here to set environment depending on an environment variable
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
346 // or command-line flag
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
347 if Environment == "production" {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
348 log.SetFormatter(&log.JSONFormatter{})
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
349 } else {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
350 // The TextFormatter is default, you don't actually have to do this.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
351 log.SetFormatter(&log.TextFormatter{})
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
352 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
353 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
354 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
355
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
356 This configuration is how `logrus` was intended to be used, but JSON in
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
357 production is mostly only useful if you do log aggregation with tools like
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
358 Splunk or Logstash.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
359
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
360 #### Formatters
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
361
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
362 The built-in logging formatters are:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
363
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
364 * `logrus.TextFormatter`. Logs the event in colors if stdout is a tty, otherwise
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
365 without colors.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
366 * *Note:* to force colored output when there is no TTY, set the `ForceColors`
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
367 field to `true`. To force no colored output even if there is a TTY set the
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
368 `DisableColors` field to `true`. For Windows, see
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
369 [github.com/mattn/go-colorable](https://github.com/mattn/go-colorable).
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
370 * When colors are enabled, levels are truncated to 4 characters by default. To disable
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
371 truncation set the `DisableLevelTruncation` field to `true`.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
372 * When outputting to a TTY, it's often helpful to visually scan down a column where all the levels are the same width. Setting the `PadLevelText` field to `true` enables this behavior, by adding padding to the level text.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
373 * All options are listed in the [generated docs](https://godoc.org/github.com/sirupsen/logrus#TextFormatter).
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
374 * `logrus.JSONFormatter`. Logs fields as JSON.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
375 * All options are listed in the [generated docs](https://godoc.org/github.com/sirupsen/logrus#JSONFormatter).
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
376
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
377 Third party logging formatters:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
378
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
379 * [`FluentdFormatter`](https://github.com/joonix/log). Formats entries that can be parsed by Kubernetes and Google Container Engine.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
380 * [`GELF`](https://github.com/fabienm/go-logrus-formatters). Formats entries so they comply to Graylog's [GELF 1.1 specification](http://docs.graylog.org/en/2.4/pages/gelf.html).
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
381 * [`logstash`](https://github.com/bshuster-repo/logrus-logstash-hook). Logs fields as [Logstash](http://logstash.net) Events.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
382 * [`prefixed`](https://github.com/x-cray/logrus-prefixed-formatter). Displays log entry source along with alternative layout.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
383 * [`zalgo`](https://github.com/aybabtme/logzalgo). Invoking the Power of Zalgo.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
384 * [`nested-logrus-formatter`](https://github.com/antonfisher/nested-logrus-formatter). Converts logrus fields to a nested structure.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
385 * [`powerful-logrus-formatter`](https://github.com/zput/zxcTool). get fileName, log's line number and the latest function's name when print log; Sava log to files.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
386 * [`caption-json-formatter`](https://github.com/nolleh/caption_json_formatter). logrus's message json formatter with human-readable caption added.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
387
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
388 You can define your formatter by implementing the `Formatter` interface,
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
389 requiring a `Format` method. `Format` takes an `*Entry`. `entry.Data` is a
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
390 `Fields` type (`map[string]interface{}`) with all your fields as well as the
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
391 default ones (see Entries section above):
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
392
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
393 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
394 type MyJSONFormatter struct {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
395 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
396
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
397 log.SetFormatter(new(MyJSONFormatter))
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
398
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
399 func (f *MyJSONFormatter) Format(entry *Entry) ([]byte, error) {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
400 // Note this doesn't include Time, Level and Message which are available on
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
401 // the Entry. Consult `godoc` on information about those fields or read the
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
402 // source of the official loggers.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
403 serialized, err := json.Marshal(entry.Data)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
404 if err != nil {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
405 return nil, fmt.Errorf("Failed to marshal fields to JSON, %w", err)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
406 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
407 return append(serialized, '\n'), nil
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
408 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
409 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
410
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
411 #### Logger as an `io.Writer`
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
412
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
413 Logrus can be transformed into an `io.Writer`. That writer is the end of an `io.Pipe` and it is your responsibility to close it.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
414
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
415 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
416 w := logger.Writer()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
417 defer w.Close()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
418
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
419 srv := http.Server{
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
420 // create a stdlib log.Logger that writes to
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
421 // logrus.Logger.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
422 ErrorLog: log.New(w, "", 0),
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
423 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
424 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
425
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
426 Each line written to that writer will be printed the usual way, using formatters
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
427 and hooks. The level for those entries is `info`.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
428
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
429 This means that we can override the standard library logger easily:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
430
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
431 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
432 logger := logrus.New()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
433 logger.Formatter = &logrus.JSONFormatter{}
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
434
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
435 // Use logrus for standard log output
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
436 // Note that `log` here references stdlib's log
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
437 // Not logrus imported under the name `log`.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
438 log.SetOutput(logger.Writer())
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
439 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
440
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
441 #### Rotation
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
442
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
443 Log rotation is not provided with Logrus. Log rotation should be done by an
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
444 external program (like `logrotate(8)`) that can compress and delete old log
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
445 entries. It should not be a feature of the application-level logger.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
446
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
447 #### Tools
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
448
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
449 | Tool | Description |
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
450 | ---- | ----------- |
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
451 |[Logrus Mate](https://github.com/gogap/logrus_mate)|Logrus mate is a tool for Logrus to manage loggers, you can initial logger's level, hook and formatter by config file, the logger will be generated with different configs in different environments.|
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
452 |[Logrus Viper Helper](https://github.com/heirko/go-contrib/tree/master/logrusHelper)|An Helper around Logrus to wrap with spf13/Viper to load configuration with fangs! And to simplify Logrus configuration use some behavior of [Logrus Mate](https://github.com/gogap/logrus_mate). [sample](https://github.com/heirko/iris-contrib/blob/master/middleware/logrus-logger/example) |
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
453
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
454 #### Testing
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
455
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
456 Logrus has a built in facility for asserting the presence of log messages. This is implemented through the `test` hook and provides:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
457
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
458 * decorators for existing logger (`test.NewLocal` and `test.NewGlobal`) which basically just adds the `test` hook
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
459 * a test logger (`test.NewNullLogger`) that just records log messages (and does not output any):
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
460
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
461 ```go
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
462 import(
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
463 "github.com/sirupsen/logrus"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
464 "github.com/sirupsen/logrus/hooks/test"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
465 "github.com/stretchr/testify/assert"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
466 "testing"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
467 )
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
468
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
469 func TestSomething(t*testing.T){
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
470 logger, hook := test.NewNullLogger()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
471 logger.Error("Helloerror")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
472
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
473 assert.Equal(t, 1, len(hook.Entries))
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
474 assert.Equal(t, logrus.ErrorLevel, hook.LastEntry().Level)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
475 assert.Equal(t, "Helloerror", hook.LastEntry().Message)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
476
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
477 hook.Reset()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
478 assert.Nil(t, hook.LastEntry())
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
479 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
480 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
481
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
482 #### Fatal handlers
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
483
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
484 Logrus can register one or more functions that will be called when any `fatal`
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
485 level message is logged. The registered handlers will be executed before
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
486 logrus performs an `os.Exit(1)`. This behavior may be helpful if callers need
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
487 to gracefully shutdown. Unlike a `panic("Something went wrong...")` call which can be intercepted with a deferred `recover` a call to `os.Exit(1)` can not be intercepted.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
488
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
489 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
490 ...
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
491 handler := func() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
492 // gracefully shutdown something...
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
493 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
494 logrus.RegisterExitHandler(handler)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
495 ...
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
496 ```
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
497
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
498 #### Thread safety
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
499
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
500 By default, Logger is protected by a mutex for concurrent writes. The mutex is held when calling hooks and writing logs.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
501 If you are sure such locking is not needed, you can call logger.SetNoLock() to disable the locking.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
502
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
503 Situation when locking is not needed includes:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
504
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
505 * You have no hooks registered, or hooks calling is already thread-safe.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
506
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
507 * Writing to logger.Out is already thread-safe, for example:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
508
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
509 1) logger.Out is protected by locks.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
510
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
511 2) logger.Out is an os.File handler opened with `O_APPEND` flag, and every write is smaller than 4k. (This allows multi-thread/multi-process writing)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
512
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
513 (Refer to http://www.notthewizard.com/2014/06/17/are-files-appends-really-atomic/)