網站首頁 編程語言 正文
場景
服務依賴第三方服務或者其他服務,但有時第三方服務偶發性出現問題并且會快速的恢復,而我們的系統可能因為這些偶發性出現問題。
所以無法保證以來服務的可靠性,但是我們可以通過其他的方式來保證我們的服務是穩定的,可靠的。
重試機制可以協助我們構建健壯的服務。比如調用第三方服務或執行某操作時,出現執行失敗,我們可以讓其再重試幾次再拋出錯誤。
設計原理
重試機制:某方法或者函數執行失敗了重新執行,嘗試重新執行后,嘗試幾次失敗后結束。期間成功一次則表示成功。
- 重試次數
- 需要被重新執行方法
func add() (string, error) { var i = 1 var j = 2 result := i + j return strconv.Itoa(result), nil } func RetryFunc(count int, cback func() (string, error)) { for i := 0; i < count; i++ { result, err := cback() if err == nil { return result } } } // 應用 package main func main(){ Retry(3, add) }
重試函數接收2個參數,一個是重試次數,一個是需要重新執行的函數。但函數都是固定的。可以進一步優化。
type Effector func(context.Context) (string, error) func Retry(count int ,delay time.Duration, effector){ return func(ctx. context.Context)(string, error){ for r:=0; ;r++{ response, err := effector() if err == nil || r>= count { return response, err } fmt.Printf("Function call failed, retrying in %v", delay) select { case <- time.After(delay) case <- ctx.Done(): return "", ctx.Err() } } } }
增加延時參數 delay 控制重試延時 ,使用匿名函數定義一個函數接收器,返回值為匿名函數的。所以重試函數接受三個參數:一個效應器,一個整數,描述函數重試傳遞的效應器的次數以及重試之間的延遲。
函數接收器的參數是 context ,context 主要用來在 goroutine 之間傳遞上下文信息。這里使用context主要是用于超時取消,然后快速返回。 context
包主要提供了兩種方式創建context
:
context.Background
?是上下文的默認值,所有其他的上下文都應該從它衍生(Derived)出來。
context.TODO
?應該只在不確定應該使用哪種上下文時使用;
原文鏈接:https://juejin.cn/post/7133982021562744840
相關推薦
- 2022-05-07 Python列表的淺拷貝與深拷貝_python
- 2022-07-09 Python二分查找+字符串模板+textwrap模塊,_python
- 2022-06-17 詳解在Flutter中如何使用dio_Android
- 2023-07-16 uniapp 調用拍照組件
- 2022-10-01 Python利用Bokeh進行數據可視化的教程分享_python
- 2022-04-16 C語言實現順序循環隊列實例_C 語言
- 2022-04-01 SQL?Server?事務,異常和游標詳解_MsSql
- 2022-11-21 詳解Go語言中的內存對齊_Golang
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支