• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

golang(go语言)调试和查看gc信息,以及gc信息解析

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

这里记录一下调试golang gc的方法
启用gc打印:

# GODEBUG=gctrace=1 go run ./main.go

程序启动后gc将打印如下信息:

gc 65 @16.996s 0%: 0+1.0+0 ms clock, 0+0/1.0/2.0+0 ms cpu, 10->10->4 MB, 11 MB goal, 4 P
gc 66 @100.235s 0%: 0+1.0+0 ms clock, 0+1.0/1.0/2.0+0 ms cpu, 9->9->3 MB, 10 MB goal, 4 P
GC forced
gc 35 @127.931s 0%: 0+1.9+0 ms clock, 0+0/1.9/4.9+0 ms cpu, 8->8->3 MB, 9 MB goal, 4 P
scvg0: inuse: 6, idle: 12, sys: 18, released: 0, consumed: 18 (MB)
scvg0: inuse: 6, idle: 9, sys: 15, released: 0, consumed: 15 (MB)
GC forced
gc 67 @220.264s 0%: 0+0.98+0 ms clock, 0+0/0.98/2.9+0 ms cpu, 5->5->3 MB, 7 MB goal, 4 P

gc打印信息的含义依次如下:

  1. gc 65 @16.996s:第65次执行,进程已经启动16.996秒
  2. 0%:本次执行gc占用的进程cpu时间的百分比
  3. 0+1.0+0 ms clock:本次gc的耗时。依次是STW清扫的时间, 并发标记和扫描的时间,STW标记的时间。(STW即stop-the-world,STW时间内进程完全被挂起)
  4. 0+0/1.0/2.0+0 ms cpu:本次gc占用cpu时间
  5. 10->10->4 MB:堆的大小,gc后堆的大小,存活堆的大小
  6. 11 MB goal:整体堆的大小
  7. 4 P:CPU核数
  8. GC forced:由runtime.GC()强制执行
  9. 系统内存回收信息
	scvg0: inuse: 6, idle: 12, sys: 18, released: 0, consumed: 18 (MB)
 - inuse:使用多少M内存
 - idle:剩下要清除的内存
 - sys:系统映射的内存
 - released:释放的系统内存
 - consumed:申请的系统内存

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
go语言strconv.ParseInt的实现分析发布时间:2022-07-10
下一篇:
gomoddownload下载失败发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap