登录
首页 >  Golang >  Go问答

取消 $GODEBUG 设置的步骤

来源:stackoverflow

时间:2024-03-04 17:39:25 422浏览 收藏

今天golang学习网给大家带来了《取消 $GODEBUG 设置的步骤》,其中涉及到的知识点包括等等,无论你是小白还是老手,都适合看一看哦~有好的建议也欢迎大家在评论留言,若是看完有所收获,也希望大家能多多点赞支持呀!一起加油学习~

问题内容

我一直在使用 dave cheney 的 gcvis 工具来解决内存泄漏问题。一切顺利,问题解决了。

但是,我不知道如何做,但我一生都无法阻止垃圾收集器输出淹没我的日志,从而使开发变得非常困难。

根据runtime-package手册:

将 gctrace 设置为任何 > 0 的值也会导致垃圾收集器 当内存释放回系统时发出摘要。

但是,这没有任何效果。

如何删除输出?

我尝试过以下方法:

导出为空值

$ export godebug=
$ go run main.go

取消设置

$ unset godebug
$ go run main.go

设置为零 (也尝试不带引号,只是为了完成)

$ export godebug="gctrace=0"
$ go run main.go

无论如何,我每次都会得到这个输出(包名称已编辑):

# my-package-0
gc 1 @0.006s 10%: 0.025+3.4+0.11 ms clock, 0.20+1.7/5.9/1.7+0.94 ms cpu, 4->4->3 mb, 5 mb goal, 8 p
gc 2 @0.019s 7%: 0.005+1.0+0.086 ms clock, 0.047+0.67/1.8/2.8+0.69 ms cpu, 5->5->4 mb, 6 mb goal, 8 p
gc 3 @0.030s 6%: 0.006+2.8+0.091 ms clock, 0.053+0.10/4.8/4.2+0.73 ms cpu, 7->8->6 mb, 8 mb goal, 8 p
gc 4 @0.050s 6%: 0.030+4.2+0.096 ms clock, 0.24+1.0/7.3/3.7+0.76 ms cpu, 13->14->8 mb, 14 mb goal, 8 p
# my-package-1
gc 1 @0.007s 5%: 0.010+2.6+0.15 ms clock, 0.086+0.19/3.4/2.6+1.2 ms cpu, 4->4->2 mb, 5 mb goal, 8 p
gc 2 @0.015s 6%: 0.007+2.5+0.11 ms clock, 0.060+0.63/3.4/2.4+0.91 ms cpu, 5->5->4 mb, 6 mb goal, 8 p
gc 3 @0.028s 6%: 0.010+3.0+0.53 ms clock, 0.084+0.23/2.7/2.4+4.2 ms cpu, 8->9->5 mb, 9 mb goal, 8 p
# my-package-3
gc 1 @0.009s 15%: 0.012+4.5+1.7 ms clock, 0.10+0.62/4.5/0.77+13 ms cpu, 4->4->2 mb, 5 mb goal, 8 p
gc 2 @0.030s 9%: 0.006+2.8+0.10 ms clock, 0.050+0.63/3.7/2.9+0.85 ms cpu, 5->5->4 mb, 6 mb goal, 8 p
gc 3 @0.043s 11%: 0.53+3.9+0.084 ms clock, 4.3+7.0/7.8/5.2+0.67 ms cpu, 9->10->7 mb, 10 mb goal, 8 p
gc 4 @0.062s 10%: 0.027+3.6+0.12 ms clock, 0.21+5.2/6.3/5.0+1.0 ms cpu, 12->13->8 mb, 14 mb goal, 8 p
# my-package-4
[...]

根据评论中的要求,以下是 $ go env 的输出:

goarch="amd64"
gobin=""
gocache="/users/dimholt/library/caches/go-build"
goexe=""
goflags=""
gohostarch="amd64"
gohostos="darwin"
goos="darwin"
gopath="/users/dimholt/go"
goproxy=""
gorace=""
goroot="/usr/local/go"
gotmpdir=""
gotooldir="/usr/local/go/pkg/tool/darwin_amd64"
gccgo="gccgo"
cc="clang"
cxx="clang++"
cgo_enabled="1"
gomod=""
cgo_cflags="-g -o2"
cgo_cppflags=""
cgo_cxxflags="-g -o2"
cgo_fflags="-g -o2"
cgo_ldflags="-g -o2"
pkg_config="pkg-config"
gogccflags="-fpic -m64 -pthread -fno-caret-diagnostics -qunused-arguments -fmessage-length=0 -fdebug-prefix-map=/var/folders/fx/p9gpbcnd5_jdgqyp6z1w9tqr0000gn/t/go-build333219542=/tmp/go-build -gno-record-gcc-switches -fno-common"

还有我的 main.go

package main

import (
    "fmt"
    "log"
    "net/http"

    "github.com/redacted/config"
    "github.com/redacted/db"
)

func main() {
    conf := config.GetConfig()

    // Connect database.
    db.Connect()
    defer db.Close()

    // Register all HTTP routes.
    registerRoutes()

    port := fmt.Sprintf(":%v", conf.Port)
    log.Printf("documents: listening on port %v", port[1:])
    log.Fatal(http.ListenAndServe(port, nil))
}

解决方案


如果其他人遇到这个问题,这对我有用。

go clean -cache

到这里,我们也就讲完了《取消 $GODEBUG 设置的步骤》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>