1 回答

TA貢獻1866條經驗 獲得超5個贊
OP 代碼中的問題是 http.Post 調用從不檢測所提供的 io.Reader 的 EOF。
發生這種情況是因為提供的半寫管道永遠不會關閉,因此,半讀管道永遠不會發出常規的 EOF 錯誤。
作為關于關閉半讀管道會產生不規則錯誤的 OP 評論的注釋,必須了解從關閉的管道讀取不是正確的行為。
因此在這種情況下,應注意在復制完內容后立即關閉半寫側。
生成的源代碼應更改為
func ImportAggregate(c echo.Context) error {
oneR, oneW := io.Pipe()
twoR, twoW := io.Pipe()
done := make(chan bool, 2)
go func() {
fmt.Println("Product Starting")
response, err := http.Post("http://localhost:1323/products/import", "application/json", oneR)
if err != nil {
fmt.Println(err)
} else {
fmt.Println(response.Body)
}
done <- true
}()
go func() {
fmt.Println("Import Starting")
response, err := http.Post("http://localhost:1323/discounts/import", "application/json", twoR)
if err != nil {
fmt.Println(err)
} else {
fmt.Println(response.Body)
}
done <- true
}()
mw := io.MultiWriter(oneW, twoW)
io.Copy(mw, c.Request().Body)
oneW.Close()
twoW.Close()
<-done
<-done
return c.String(200, "Imported")
}
OP 問題之外的旁注:
必須圍繞 io.Copy 實施錯誤檢查以檢測傳輸錯誤。
不需要關閉管道的半讀端,http.Post 將在收到 EOF 信號后執行此操作。
必須在復制輸入請求之前聲明并啟動負責使用管道的 goroutine。Pipes 是同步的,代碼會在 io.Copy 等待另一端被消耗的過程中阻塞。
done chan 不需要無緩沖(長度為 2)
一種將錯誤從傳出請求轉發到傳出響應的方法是使用 type 的通道
(chan error)
,循環兩次,并檢查遇到的第一個錯誤。
- 1 回答
- 0 關注
- 92 瀏覽
添加回答
舉報