取消 $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删除
相关阅读
更多>
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习