当前位置:首页 > 文章列表 > Golang > Go问答 > Golang 日志记录器的成本若被舍弃

Golang 日志记录器的成本若被舍弃

来源:stackoverflow 2024-03-03 12:12:25 0浏览 收藏

今天golang学习网给大家带来了《Golang 日志记录器的成本若被舍弃》,其中涉及到的知识点包括等等,无论你是小白还是老手,都适合看一看哦~有好的建议也欢迎大家在评论留言,若是看完有所收获,也希望大家能多多点赞支持呀!一起加油学习~

问题内容

我有一个 http 处理程序,其中有 40 个设置为 os.stdout 的记录器。

它对我来说效果很好,因为我是目前唯一进行测试的人。 但是,到了制作上,恐怕开销太大了。

当前记录器设置为os.stdoutos.stderr。 但是一旦进入生产环境,os.stdout将被设置为ioutil.discard

q1。如果我仍然将记录器设置为丢弃,会影响性能吗?

第二季度。为了获得最佳实践,是否最好从 http 处理程序中完全删除记录器?

---- 更新 ----

package main

import (
    "time"
    "fmt"
    "log"
    "io/ioutil"
    "io"
)

func testprintf(w io.writer, note string, cnt int) {
    l := log.new(w, "", 0)
    t1 := time.now()
    for i:=0; i<cnt; i++ {
        l.printf("%s - %d", "test", i)
    }
    t2 := time.now()
    fmt.printf("%-15s  %-15s, %v\n","printf ", note, t2.sub(t1))
}

func testprintln(w io.writer, note string, cnt int) {
    l := log.new(w, "", 0)
    t1 := time.now()
    for i:=0; i<cnt; i++ {
        l.println("test" + string(i))
    }
    t2 := time.now()
    fmt.printf("%-15s  %-15s, %v\n","println", note, t2.sub(t1))
}

func testdonothing(w io.writer, note string, cnt int) {
    //l := log.new(w, "", 0)
    t1 := time.now()
    for i:=0; i<cnt; i++ {
        _ = "test" + string(i) // evaluated but didn't do any.
    }
    t2 := time.now()
    fmt.printf("%-15s  %-15s, %v\n", "donothing", note, t2.sub(t1))
}

func main() {
    cnt := 10000000 // ten million
    testprintf(ioutil.discard, "discard.attempt.1", cnt)
    testprintln(ioutil.discard, "discard.attempt.1", cnt)
    testdonothing(ioutil.discard, "discard.attempt.1", cnt)
    fmt.println("\n")
    testprintf(ioutil.discard, "discard.attempt.2", cnt)
    testprintln(ioutil.discard, "discard.attempt.2", cnt)
    testdonothing(ioutil.discard, "discard.attempt.2", cnt)
    fmt.println("\n")
    testprintf(ioutil.discard, "discard.attempt.3", cnt)
    testprintln(ioutil.discard, "discard.attempt.3", cnt)
    testdonothing(ioutil.discard, "discard.attempt.3", cnt)
}

--- 结果 ---

Printf           discard.Attempt.1, 2.663697209s
Println          discard.Attempt.1, 2.4289759s
DoNothing        discard.Attempt.1, 190.480694ms

Printf           discard.Attempt.2, 2.493506245s
Println          discard.Attempt.2, 2.426081786s
DoNothing        discard.Attempt.2, 182.899574ms

Printf           discard.Attempt.3, 2.480853275s
Println          discard.Attempt.3, 2.481552836s
DoNothing        discard.Attempt.3, 180.916608ms
  1. 我每个都跑了 1000 万次。
  2. 10m日志到io需要2~3秒。discard比我想象的要快..我想我不必担心速度。
  3. os.stdout,我本来不想使用它; (我最初关心的是使用 ioutil.discard 保留代码与删除代码),但由于 os.stdout 没有缓冲,所以速度很慢。
  4. 顺便说一下,printf() 比我想象的要快得多。与 println() 几乎相同

我不是每天都写 go 代码,所以这个测试可能不准确。如果您在测试中看到误导性信息,请在此处发表评论以供其他人注意。谢谢。


解决方案


基准

虽然我的直觉告诉我,将日志删除到 discard 对代码的影响很小,但我建议设置一个基准来测试记录器的性能影响。

幸运的是,go 通过在单元测试中编写 func benchmarkxxxxx(*testing.b) 函数并运行 go test -bench 使这变得非常容易。更多信息请参见 in the documentation。对于您的基准测试,我建议编写两个测试,一个使用 os.stdout,另一个使用 ioutil.discard - 确保两个测试的输入相同。

来自 ioutil 的相关代码显示“幕后”会发生什么:

// ioutil.go
type devNull int

func (devNull) Write(p []byte) (int, error) {
    return len(p), nil
}

func (devNull) WriteString(s string) (int, error) {
    return len(s), nil
}

记录最佳实践

一种日志记录方法是常见的“基于级别的日志记录”,您可以选择希望记录的消息的严重性(debug/info/warn/error 等),然后选择部署应用程序时要显示的级别(例如debug 及以上版本用于开发,但 warn 及以上版本用于生产)。

正如您所注意到的,go 在标准库中仅提供 printerror 级别语句,因此您将需要 external package 才能从此类内容中受益(这些还可以帮助以更机器可读/搜索友好的 json 格式构建日志也)。戴夫·切尼 (dave cheney) 证明了这一决定背后的理由 in a blog post

在您的情况下,40 条日志语句听起来很多,但这可能取决于有多少是简单的 print 日志;处理程序的大小和复杂性等。print 日志记录作为开发中的临时措施非常有用,如果您没有向客户端显示错误,error 可以帮助在故障期间进行诊断。

以上就是《Golang 日志记录器的成本若被舍弃》的详细内容,更多关于的资料请关注golang学习网公众号!

版本声明
本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
获取嵌套接口中的数值获取嵌套接口中的数值
上一篇
获取嵌套接口中的数值
Goroutines 正在休眠
下一篇
Goroutines 正在休眠
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    514次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    499次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • SEO  AI Mermaid 流程图:自然语言生成,文本驱动可视化创作
    AI Mermaid流程图
    SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
    742次使用
  • 搜获客笔记生成器:小红书医美爆款内容AI创作神器
    搜获客【笔记生成器】
    搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
    757次使用
  • iTerms:一站式法律AI工作台,智能合同审查起草与法律问答专家
    iTerms
    iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
    775次使用
  • TokenPony:AI大模型API聚合平台,一站式接入,高效稳定高性价比
    TokenPony
    TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
    840次使用
  • 迅捷AIPPT:AI智能PPT生成器,高效制作专业演示文稿
    迅捷AIPPT
    迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
    729次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码