“Golang Gin 日志”的版本间差异

本页内容
(创建页面,内容为“开发的应用程序记录日志是一个非常好的习惯,便于我们观察应用程序运行的情况,方便排查分析问题,Gin提供了简单高效的记录日志方法。 == 如何记录日志 == <sample title="" desc=""> func main() { // 禁用控制台颜色,将日志写入文件时不需要控制台颜色。 gin.DisableConsoleColor() // 记录到文件。 f, _ := os.Create("gin.log") gin.DefaultWriter = io.MultiWriter(…”)
 
Neo讨论 | 贡献
无编辑摘要
 
(未显示同一用户的2个中间版本)
第1行: 第1行:
[[分类:Golang Gin Web 框架教程]]
开发的应用程序记录日志是一个非常好的习惯,便于我们观察应用程序运行的情况,方便排查分析问题,Gin提供了简单高效的记录日志方法。
开发的应用程序记录日志是一个非常好的习惯,便于我们观察应用程序运行的情况,方便排查分析问题,Gin提供了简单高效的记录日志方法。


第25行: 第26行:
== 定义路由日志的格式 ==
== 定义路由日志的格式 ==
默认的路由日志格式:
默认的路由日志格式:
<blockquote>
<pre>
[GIN-debug] POST  /foo                      --> main.main.func1 (3 handlers)
[GIN-debug] POST  /foo                      --> main.main.func1 (3 handlers)
[GIN-debug] GET    /bar                      --> main.main.func2 (3 handlers)
[GIN-debug] GET    /bar                      --> main.main.func2 (3 handlers)
[GIN-debug] GET    /status                  --> main.main.func3 (3 handlers)
[GIN-debug] GET    /status                  --> main.main.func3 (3 handlers)
</blockquote>
</pre>
如果你想要以指定的格式(例如 JSON,key values 或其他格式)记录信息,则可以使用 gin.DebugPrintRouteFunc 指定格式。 在下面的示例中,我们使用标准日志包记录所有路由,但你可以使用其他满足你需求的日志工具。
如果你想要以指定的格式(例如 JSON,key values 或其他格式)记录信息,则可以使用 gin.DebugPrintRouteFunc 指定格式。 在下面的示例中,我们使用标准日志包记录所有路由,但你可以使用其他满足你需求的日志工具。
<sample title="" desc="">
<sample title="" desc="">
第62行: 第63行:
}
}


</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:44的最新版本

开发的应用程序记录日志是一个非常好的习惯,便于我们观察应用程序运行的情况,方便排查分析问题,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")
}
此页面最后编辑于2022年9月28日 (星期三) 11:44。