亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

是什么導致 golang 程序處于 100% CPU?

是什么導致 golang 程序處于 100% CPU?

Go
慕標琳琳 2021-12-20 16:42:17
我有一個我編寫的 golang 程序(它是一個 FTP 服務器),它在運行時具有 100% 的 CPU。我在 strace 中看到:futex(0xa83918, FUTEX_WAIT, 0, NULLread(9, "", 4096)                       = 0read(9, "", 4096)                       = 0read(9, "", 4096)                       = 0read(9, "", 4096)                       = 0read(9, "", 4096)                       = 0read(8, "", 4096)                       = 0read(8, "", 4096)                       = 0read(8, "", 4096)                       = 0read(8, "", 4096)                       = 0read(8, "", 4096)                       = 0一遍又一遍。它陷入了一些無限循環。它的主要 for 循環是: for {    tcpConn, err := listener.Accept()    if err != nil {      Server.logger.Print("listening error")      break    }       driver, err := Server.driverFactory.NewDriver()    if err != nil {      Server.logger.Print("Error creating driver, aborting client connection")    } else {      ftpConn := Server.newConn(tcpConn, driver, Server.Auth)      go ftpConn.Serve()    }     }知道是什么導致了無限循環?當程序啟動時,它并不處于這種糟糕的狀態。它以正常的 CPU 使用率正常循環。它需要運行幾個小時才能進入這種不良狀態。
查看完整描述

2 回答

?
守著星空守著你

TA貢獻1799條經驗 獲得超8個贊

原來這根本不是 TCP 相關的。由于“\n”輸入問題,這是代碼中的一個while循環,永遠不會結束。即我有:


for {

  if something {

    break;

  }

}

它從未破裂。


查看完整回答
反對 回復 2021-12-20
?
慕桂英3389331

TA貢獻2036條經驗 獲得超8個贊

當您嘗試在錯誤時創建新驅動程序時,也許嘗試關閉 tcpConn。此外,嘗試檢查 Server.newConn(tcpConn, driver, Server.Auth) 在連接完成時是否實際關閉了連接。


查看完整回答
反對 回復 2021-12-20
  • 2 回答
  • 0 關注
  • 220 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號