retry alternatives and similar packages
Based on the "Go Tools" category.
Alternatively, view retry alternatives based on common mentions on social networks and blogs.
-
JuiceFS
JuiceFS is a distributed POSIX file system built on top of Redis and S3. -
JSON-to-Go
Translates JSON into a Go type in your browser instantly (original) -
The Go Play Space
Advanced Go Playground frontend written in Go, with syntax highlighting, turtle graphics mode, and more -
Peanut
๐บ Deploy Databases and Services Easily for Development and Testing Pipelines. -
golang-tutorials
Golang Tutorials. Learn Golang from Scratch with simple examples. -
xdg-go
Go implementation of the XDG Base Directory Specification and XDG user directories -
typex
[TOOL, CLI] - Filter and examine Go type structures, interfaces and their transitive dependencies and relationships. Export structural types as TypeScript value object or bare type representations. -
golang-ipc
Golang Inter-process communication library for Window, Mac and Linux. -
gothanks
GoThanks automatically stars Go's official repository and your go.mod github dependencies, providing a simple way to say thanks to the maintainers of the modules you use and the contributors of Go itself. -
Viney's go-cache
A flexible multi-layer Go caching library to deal with in-memory and shared cache by adopting Cache-Aside pattern. -
goroutines
It is an efficient, flexible, and lightweight goroutine pool. It provides an easy way to deal with concurrent tasks with limited resource. -
go-lock
go-lock is a lock library implementing read-write mutex and read-write trylock without starvation -
An exit strategy for go routines.
An exit strategy for go routines -
import "github/shuLhan/share"
A collection of libraries and tools written in Go; including DNS, email, git ini file format, HTTP, memfs (embedding file into Go), paseto, SMTP, TOTP, WebSocket, XMLRPC, and many more. -
go-james
James is your butler and helps you to create, build, debug, test and run your Go projects -
generator-go-lang
A Yeoman generator to get new Go projects started. -
PDF to Image Converter Using Golang
This project will help you to convert PDF file to IMAGE using golang. -
go-sanitize
:bathtub: Golang library of simple to use sanitation functions -
docs
Automatically generate RESTful API documentation for GO projects - aligned with Open API Specification standard -
go-whatsonchain
:link: Unofficial golang implementation for the WhatsOnChain API -
gomodrun
The forgotten go tool that executes and caches binaries included in go.mod files. -
Proofable
General purpose proving framework for certifying digital assets to public blockchains -
channelize
A websocket framework to manage outbound streams. Allowing to have multiple channels per connection that includes public and private channels. -
MessageBus implementation for CQRS projects
CQRS Implementation for Golang language -
go-slices
Helper functions for the manipulation of slices of all types in Go -
modver
Compare two versions of a Go module to check the version-number change required (major, minor, or patchlevel), according to semver rules. -
redispubsub
Redis Streams queue driver for https://godoc.org/gocloud.dev/pubsub package -
num30/go-cache
An in-memory key:value store/cache (similar to Memcached) library that takes advantage of Go Generics
ONLYOFFICE Docs โ document collaboration in your environment
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of retry or a related project?
README
retry
Small, full-featured, 100% test-covered retry package for golang
features
- small (~200 sloc), 100% test-covered codebase
- fully-customizable, you can specify number of retries, sleep (and sleep-jitter) between them and stdlog verbosity
- three ways to retry - single function, chain (one-by-one) and parallel execution
examples
simple
import (
"log"
"github.com/s0rg/retry"
)
try := retry.New()
// single
if err := try.Single("single-func", func() error {
return initSomeResource()
}); err != nil {
log.Fatal("retry:", err)
}
with config
import (
"log"
"time"
"github.com/s0rg/retry"
)
try := retry.New(
retry.Count(5),
retry.Parallelism(2),
retry.Sleep(time.Second*3),
retry.Jitter(time.Second/2),
retry.Verbose(true),
)
var (
dbh *sql.DB
kaf *kafka.Conn
red *redis.Conn
)
steps := []retry.Step{
{"database", func() (err error) {
dbh, err = sql.Open(...)
return
}},
{"kafka", func() (err error) {
kaf, err = kafka.Connect(...)
return
}},
{"redis", func() (err error) {
red, err = redis.Connect(...)
return
}},
}
// parallel execution
if err := try.Parallel(steps...); err != nil {
log.Fatal("retry:", err)
}
// at this point all tree resources will be avialaible
*Note that all licence references and agreements mentioned in the retry README section above
are relevant to that project's source code only.