Go 语言实现的一个简单的重试方法

栏目: Go · 发布时间: 6年前

内容简介:简单的东西就不废话了,直接上代码。接收三个参数:最多重试

代码

简单的东西就不废话了,直接上代码。

func Retry(attempts int, sleep time.Duration, fn func() error) error {
	if err := fn(); err != nil {
		if s, ok := err.(stop); ok {
			return s.error
		}

		if attempts--; attempts > 0 {
			logger.Warnf("retry func error: %s. attemps #%d after %s.", err.Error(), attempts, sleep)
			time.Sleep(sleep)
			return Retry(attempts, 2*sleep, fn)
		}
		return err
	}
	return nil
}

type stop struct {
	error
}

func NoRetryError(err error) stop {
	return stop{err}
}

接收三个参数:

func() error

重试的逻辑

最多重试 attempts 次,如果调用 fn 返回错误,等待 sleep 的时间,而下次错误重试就需要等待两倍的时间了。还有一点是错误的类型,常规错误会重试,而 stop 类型的错误会中断重试,这也提供了一种中断机制。

示例

cnt := 0
err := fmt.Errorf("test error every time")
a := func() error {
	if cnt == 0 {
		cnt++
		return err
	} else {
		cnt++
		return nil
	}
}
errFn := util.Retry(3, 1*time.Millisecond, a)

本文涉及的代码可以从 这里 下载。

更多阅读: Simple Golang Retry Function


以上所述就是小编给大家介绍的《Go 语言实现的一个简单的重试方法》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数据结构与算法分析(C++版)(第3版)

数据结构与算法分析(C++版)(第3版)

Clifford A. Shaffer / 张铭、刘晓丹、等译 / 电子工业出版社 / 2013 / 59.00元

本书采用当前流行的面向对象的C++程序设计语言来描述数据结构和算法, 因为C++语言是程序员最广泛使用的语言。因此, 程序员可以把本书中的许多算法直接应用于将来的实际项目中。尽管数据结构和算法在设计本质上还是很底层的东西, 并不像大型软件工程项目开发那样, 对面向对象方法具有直接的依赖性, 因此有人会认为并不需要采用高层次的面向对象技术来描述底层算法。 但是采用C++语言能更好地体现抽象数据类型的......一起来看看 《数据结构与算法分析(C++版)(第3版)》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

URL 编码/解码
URL 编码/解码

URL 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换