分享
golang程序问题处理经验
凯文不上班 · · 1154 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
1.在做内存问题相关的 profiling 时:
若 gc 相关函数占用异常,可重点排查对象数量
解决速度问题(CPU占用)时,关注对象数量( --inuse/alloc_objects )指标
解决内存占用问题时,关注分配空间( --inuse/alloc_space )指标
inuse 代表当前时刻的内存情况,alloc 代表从从程序启动到当前时刻累计的内存情况,一般情况下看 inuse 指标更重要一些,但某些时候两张图对比着看也能有些意外发现。
2.在日常 golang 编码时:
参数类型要检查,尤其是 sql 参数要检查(低级错误)
传递struct尽量使用指针,减少复制和内存占用消耗(尤其对于赋值给interface,会分配到堆上,额外增加gc消耗)
尽量不使用循环引用,除非逻辑真的需要
能在初始化中做的事就不要放到每次调用的时候做
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信1154 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
1.在做内存问题相关的 profiling 时:
若 gc 相关函数占用异常,可重点排查对象数量
解决速度问题(CPU占用)时,关注对象数量( --inuse/alloc_objects )指标
解决内存占用问题时,关注分配空间( --inuse/alloc_space )指标
inuse 代表当前时刻的内存情况,alloc 代表从从程序启动到当前时刻累计的内存情况,一般情况下看 inuse 指标更重要一些,但某些时候两张图对比着看也能有些意外发现。
2.在日常 golang 编码时:
参数类型要检查,尤其是 sql 参数要检查(低级错误)
传递struct尽量使用指针,减少复制和内存占用消耗(尤其对于赋值给interface,会分配到堆上,额外增加gc消耗)
尽量不使用循环引用,除非逻辑真的需要
能在初始化中做的事就不要放到每次调用的时候做