Golang GC导致的文件描述符不可用

luofanyuguai · · 786 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

现象

1. 压力测试时,使用syscall.Accept得到 bad file descriptor,server直接无法响应。

原因

1. syscall.Accept使用的fd来源是在自己代码初试化的时候通过TCPListener.FIle().Fd()直接拿到,且在自己的代码中通过int 类型保存了这个返回的系统fd,后续直接使用int 类型存储的fd值进行epoll相关操作

2.事实上Golang 的实现实现中TCPListener.FIle() 返回的*os.FIle不是TCPListener原有的*os.File对象,而是dup(拷贝)一份,同时这个dup动作中会使用系统调用对于原来的系统fd也执行一次dup,进而生产一份新的额系统fd

3.TCPListener.FIle().Fd() 这种使用方式,没有保存对于新的*os.File对象的应用,进而在发生GC时,这个*os.File会被清理掉,同时这个对象中的系统fd会被close掉。

解决

当需要使用TCPListener的系统底层提供的文件描述符(fd)时,TCPListener.FIle()得到的*os.File()保证不被GC处理。


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:luofanyuguai

查看原文:Golang GC导致的文件描述符不可用

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

786 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传