登录
首页 >  Golang >  Go问答

在 github actions 和 ubuntu 中运行 go test 时出现太多打开文件错误

来源:stackoverflow

时间:2024-04-08 08:03:35 345浏览 收藏

本篇文章向大家介绍《在 github actions 和 ubuntu 中运行 go test 时出现太多打开文件错误》,主要包括,具有一定的参考价值,需要的朋友可以参考一下。

问题内容

我们构建了一个测试套件,始终可以在本地 ubuntu 机器和 github actions 上的 ubuntu 机器上运行。由于最新添加的单元测试,一个包的单元测试数量大幅增长,并且开始失败,并出现 too much open files 错误消息:

{"Time":"2021-10-22T13:24:15.784106437Z","Action":"output","Package":"github.com/MyCompany/Product/src/interface/service/user","Test":"Test_userService_MethodTest/Case_1","Output":"2021/10/22 13:24:15 too many open files\n"}

出现两个奇怪的事情:在windows上没有这样的问题。如果我注释掉错误中提到的包中的一半单元测试,它也不会发生。

受影响的包中的单元测试数量目前为 245 个,大约在大约 245 个左右时停止工作。


正确答案


在我们的测试设置中,我们通过单独的 viper 实例为每个每次打开一些文件的子测试注入了配置。集中定义一个 viper 实例,然后将配置传递到测试中就可以了。

我认为您需要更改最大文件描述符。之前许多开发虚拟机都出现过同样的问题,需要更改文件描述符最大值,而不是 inotify 设置的任何内容。

注意 ulimit != ulimit -n

➜  cmd git:(wip-poop) ✗ ulimit -a
-t: cpu time (seconds)              unlimited
-f: file size (blocks)              unlimited
-d: data seg size (kbytes)          unlimited
-s: stack size (kbytes)             8192
-c: core file size (blocks)         0
-v: address space (kbytes)          unlimited
-l: locked-in-memory size (kbytes)  unlimited
-u: processes                       1418
-n: file descriptors                4864

今天关于《在 github actions 和 ubuntu 中运行 go test 时出现太多打开文件错误》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

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