我正在使用zerolog在我的 Go 應用程序中進行日志記錄,并且我正在嘗試遵循最佳實踐以僅在堆棧頂部出錯。但是,我不確定如何將兩者都寫入我的錯誤日志并將錯誤向上傳遞:func VeryDeepFunction() (int, error) { err := doSomethingThatCouldCauseError() if err != nil { errMsg := fmt.Sprintf("something bad happened: %+v", err) log.Error().Msgf(errMsg) return 0, fmt.Errorf(errMsg) } return 1, nil}這對我來說是多余的——格式化字符串,用 zerolog 歸檔,然后再次包裝錯誤。有沒有更正確的方法來做到這一點?
1 回答

HUWWW
TA貢獻1874條經驗 獲得超12個贊
可以鏈接錯誤
package main
import (
"log"
"github.com/pkg/errors"
)
var someError = errors.New("something is wrong")
func main() {
// processing error on top level
if err := someFunc(); errors.Is(err, someError) {
log.Println(err)
}
}
func someFunc() error {
if err := alwaysError(); err != nil {
return errors.Wrap(err, "someFunc")
}
return nil
}
func alwaysError() error {
return someError
}
輸出將是
2022/09/01 10:00:46 someFunc: something is wrong
有關詳細信息,請參閱錯誤包
- 1 回答
- 0 關注
- 165 瀏覽
添加回答
舉報
0/150
提交
取消