幾個小時后,我不斷收到錯誤消息,因為我打開的文件太多。我已經編輯過了,ulimit -n但這似乎只會延長錯誤發生和進程崩潰之前的時間。我相信我已經將它縮小到這個功能,我只是不確定我是否正確關閉它。我目前有一個功能go func() { if _, err := io.Copy(rw, stdout); err != nil { if !WritePipeBroken.MatchString(err.Error()) && !ConnectionResetByPeer.MatchString(err.Error()) { rollbar.Error(rollbar.ERR, err) } log.Printf("pipeThruFfmpegToMp3: %v\n", err) if err := ffmpeg.Process.Kill(); err != nil { log.Printf("pipeThruFfmpegToMp3: %v\n", err) } } rw.Flush() wg.Done()}()我相信它正在掛起,所以我應該這樣做go func() { if _, err := io.Copy(rw, stdout); err != nil { if !WritePipeBroken.MatchString(err.Error()) && !ConnectionResetByPeer.MatchString(err.Error()) { rollbar.Error(rollbar.ERR, err) } log.Printf("pipeThruFfmpegToMp3: %v\n", err) if err := ffmpeg.Process.Kill(); err != nil { log.Printf("pipeThruFfmpegToMp3: %v\n", err) } } if ffmpeg.Process != nil { ffmpeg.Process.Kill() } if stdout != nil { stdin.Close() } rw.Flush() wg.Done()}()
1 回答

米脂
TA貢獻1836條經驗 獲得超3個贊
使用defer像谷歌建議的聲明:
func CopyFile(dstName, srcName string) (written int64, err error) {
src, err := os.Open(srcName)
if err != nil {
return
}
defer src.Close()
dst, err := os.Create(dstName)
if err != nil {
return
}
defer dst.Close()
return io.Copy(dst, src)
}
- 1 回答
- 0 關注
- 156 瀏覽
添加回答
舉報
0/150
提交
取消