Skip to content

Intelligently and flexibly pool among multiple hosts from your Go application

License

Notifications You must be signed in to change notification settings

bitly/go-hostpool

Repository files navigation

go-hostpool

Build Status GoDoc GitHub release

A Go package to intelligently and flexibly pool among multiple hosts from your Go application. Host selection can operate in round robin or epsilon greedy mode, and unresponsive hosts are avoided. Usage example:

hp := hostpool.NewEpsilonGreedy([]string{"a", "b"}, 0, &hostpool.LinearEpsilonValueCalculator{})
hostResponse := hp.Get()
hostname := hostResponse.Host()
err := _ // (make a request with hostname)
hostResponse.Mark(err)

View more detailed documentation on godoc.org

About

Intelligently and flexibly pool among multiple hosts from your Go application

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages