mirror of
https://github.com/kataras/iris.git
synced 2025-01-23 18:51:03 +01:00
84 lines
1.9 KiB
Go
84 lines
1.9 KiB
Go
package main
|
|
|
|
import (
|
|
"github.com/kataras/iris/v12"
|
|
"github.com/kataras/iris/v12/middleware/requestid"
|
|
|
|
"github.com/kataras/golog"
|
|
)
|
|
|
|
func main() {
|
|
app := iris.New()
|
|
app.Logger().SetLevel("debug")
|
|
app.Logger().SetFormat("json", " ")
|
|
// to register a custom Formatter:
|
|
// app.Logger().RegisterFormatter(golog.Formatter...)
|
|
|
|
// Also, see app.Logger().SetLevelOutput(level string, w io.Writer)
|
|
// to set a custom writer for a specific level.
|
|
|
|
app.Use(requestid.New())
|
|
|
|
/* Example Output:
|
|
{
|
|
"timestamp": 1591422944,
|
|
"level": "debug",
|
|
"message": "This is a message with data",
|
|
"fields": {
|
|
"username": "kataras"
|
|
},
|
|
"stacktrace": [
|
|
{
|
|
"function": "main.main",
|
|
"source": "C:/mygopath/src/github.com/kataras/iris/_examples/logging/json-logger/main.go:16"
|
|
}
|
|
]
|
|
}
|
|
*/
|
|
app.Logger().Debugf("This is a %s with data (debug prints the stacktrace too)", "message", golog.Fields{
|
|
"username": "kataras",
|
|
})
|
|
|
|
/* Example Output:
|
|
{
|
|
"timestamp": 1591422944,
|
|
"level": "info",
|
|
"message": "An info message",
|
|
"fields": {
|
|
"home": "https://iris-go.com"
|
|
}
|
|
}
|
|
*/
|
|
app.Logger().Infof("An info message", golog.Fields{"home": "https://iris-go.com"})
|
|
|
|
app.Get("/ping", ping)
|
|
|
|
// Navigate to http://localhost:8080/ping.
|
|
app.Listen(":8080" /*, iris.WithoutBanner*/)
|
|
}
|
|
|
|
func ping(ctx iris.Context) {
|
|
/* Example Output:
|
|
{
|
|
"timestamp": 1591423046,
|
|
"level": "debug",
|
|
"message": "Request path: /ping",
|
|
"fields": {
|
|
"request_id": "fc12d88a-a338-4bb9-aa5e-126f2104365c"
|
|
},
|
|
"stacktrace": [
|
|
{
|
|
"function": "main.ping",
|
|
"source": "C:/mygopath/src/github.com/kataras/iris/_examples/logging/json-logger/main.go:82"
|
|
},
|
|
...
|
|
]
|
|
}
|
|
*/
|
|
ctx.Application().Logger().Debugf("Request path: %s", ctx.Path(), golog.Fields{
|
|
"request_id": ctx.GetID(),
|
|
})
|
|
|
|
ctx.WriteString("pong")
|
|
}
|