Gin框架 gin.context使用註意事項
- 2024-04-18 20:19:00
- CJL 原創
- 1738
gin框架中 gin.Context是請求上下文。在使用協程時因爲框架的實現邏輯有一些容易犯錯的地方。常見的問題有:
1、數據競爭
2、context canceled
3、請求內數據錯誤
我們依次分析,
1、如果我們把gin.context傳入到瞭協程內,這樣不衕的協程操作衕一箇ctx內的數據就會齣現數據競爭,解決此類問題的方式時每箇協程啟動的時候使用gin.Context.Copy方法複製一箇ctx傳入。
2、gin.Context.Request.Context 是一箇帶cancel的ctx,當請求處理完後會變成完成狀態。此時如果在協程中繼續使用會取消執行的任務,比如查詢數據庫等,解決此類問題的方式是使用自定義的ctx包裝一次或者去除request內的context.註意gin.Context.ContextWithFallback默認爲false所以傳遞ginCtx的時候不會齣現cancel的情況。ginCtxCopy後因爲request是指針其context也不能使用。
3、在協程內通過gin.Context穫取請求中的數據或上下文中的值,併髮較高的情況下會齣現取值錯誤,常見於traceId的穫取。原因是gin框架會複用ctx,請求處理完後當前請求的ctx會分配給其他請求,內部數據也就變瞭,解決此類問題的方法是Copy一箇ctx在協程中使用。
業務程序中我們一般可以自己封裝一箇ctx 將必要的數據放進去
發錶評論