“Golang Gin 日志”的版本间差异
本页内容
第62行: | 第62行: | ||
} | } | ||
</sample> | |||
== 控制日志输出颜色 == | |||
根据检测到的 TTY,控制台的日志输出默认是有颜色的。 | |||
禁止日志高亮显示: | |||
<sample title="" desc=""> | |||
func main() { | |||
// 禁止日志的颜色 | |||
gin.DisableConsoleColor() | |||
// 用默认中间件创建一个 gin 路由: | |||
// 日志和恢复(无崩溃)中间件 | |||
router := gin.Default() | |||
router.GET("/ping", func(c *gin.Context) { | |||
c.String(200, "pong") | |||
}) | |||
router.Run(":8080") | |||
} | |||
</sample> | |||
=== 日志高亮显示: === | |||
<sample title="" desc=""> | |||
func main() { | |||
// 强制日志颜色化 | |||
gin.ForceConsoleColor() | |||
// 用默认中间件创建一个 gin 路由: | |||
// 日志和恢复(无崩溃)中间件 | |||
router := gin.Default() | |||
router.GET("/ping", func(c *gin.Context) { | |||
c.String(200, "pong") | |||
}) | |||
router.Run(":8080") | |||
} | |||
</sample> | </sample> |
2022年9月28日 (三) 11:37的版本
开发的应用程序记录日志是一个非常好的习惯,便于我们观察应用程序运行的情况,方便排查分析问题,Gin提供了简单高效的记录日志方法。
如何记录日志
示例
func main() {
// 禁用控制台颜色,将日志写入文件时不需要控制台颜色。
gin.DisableConsoleColor()
// 记录到文件。
f, _ := os.Create("gin.log")
gin.DefaultWriter = io.MultiWriter(f)
// 如果需要同时将日志写入文件和控制台,请使用以下代码。
// gin.DefaultWriter = io.MultiWriter(f, os.Stdout)
router := gin.Default()
router.GET("/ping", func(c *gin.Context) {
c.String(200, "pong")
})
router.Run(":8080")
}
定义路由日志的格式
默认的路由日志格式:
[GIN-debug] POST /foo --> main.main.func1 (3 handlers) [GIN-debug] GET /bar --> main.main.func2 (3 handlers) [GIN-debug] GET /status --> main.main.func3 (3 handlers)
如果你想要以指定的格式(例如 JSON,key values 或其他格式)记录信息,则可以使用 gin.DebugPrintRouteFunc 指定格式。 在下面的示例中,我们使用标准日志包记录所有路由,但你可以使用其他满足你需求的日志工具。
示例
import (
"log"
"net/http"
"github.com/gin-gonic/gin"
)
func main() {
r := gin.Default()
gin.DebugPrintRouteFunc = func(httpMethod, absolutePath, handlerName string, nuHandlers int) {
log.Printf("endpoint %v %v %v %v\n", httpMethod, absolutePath, handlerName, nuHandlers)
}
r.POST("/foo", func(c *gin.Context) {
c.JSON(http.StatusOK, "foo")
})
r.GET("/bar", func(c *gin.Context) {
c.JSON(http.StatusOK, "bar")
})
r.GET("/status", func(c *gin.Context) {
c.JSON(http.StatusOK, "ok")
})
// 监听并在 0.0.0.0:8080 上启动服务
r.Run()
}
控制日志输出颜色
根据检测到的 TTY,控制台的日志输出默认是有颜色的。
禁止日志高亮显示:
示例
func main() {
// 禁止日志的颜色
gin.DisableConsoleColor()
// 用默认中间件创建一个 gin 路由:
// 日志和恢复(无崩溃)中间件
router := gin.Default()
router.GET("/ping", func(c *gin.Context) {
c.String(200, "pong")
})
router.Run(":8080")
}
日志高亮显示:
示例
func main() {
// 强制日志颜色化
gin.ForceConsoleColor()
// 用默认中间件创建一个 gin 路由:
// 日志和恢复(无崩溃)中间件
router := gin.Default()
router.GET("/ping", func(c *gin.Context) {
c.String(200, "pong")
})
router.Run(":8080")
}