Need help with diehard?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.

About the developer

sunng87
248 Stars 21 Forks Eclipse Public License 1.0 297 Commits 4 Opened issues

Description

Clojure resilience library for flexible retry, circuit breaker and rate limiter

Services available

!
?

Need anything else?

Contributors list

# 53,749
Clojure
Apache ...
cargo-s...
vala
235 commits
# 391,055
Clojure
Shell
binlog
MySQL
7 commits
# 229,137
Jenkins
jenkins...
Clojure
retry-l...
3 commits
# 126,161
Clojure
retry-l...
circlec...
Clojure...
2 commits
# 76,629
Clojure
Amazon ...
epl
elastic...
2 commits
# 107,890
Clojure
Clojure...
retry-l...
Markdow...
2 commits
# 117,785
Clojure...
Clojure
circlec...
command...
2 commits
# 235,709
Clojure
retry-l...
circlec...
Clojure...
2 commits
# 3,567
Scala
Java
Shell
dropwiz...
2 commits
# 50,217
jvm
Elixir
code-go...
Haxe
1 commit
# 388,410
Clojure
Scala
playfra...
slick
1 commit
# 594,866
Clojure
rate-li...
retry-l...
GraphQL
1 commit
# 723,204
Clojure
rate-li...
retry-l...
1 commit
# 596,516
Clojure
CSS
Firefox
Chrome
1 commit

diehard

Build
Status Clojars license Donate

Clojure library to provide safety guard to your application. Some of the functionality is wrapper over Failsafe.

Note that from 0.7 diehard uses Clojure 1.9 and spec.alpha for configuration validation. Clojure 1.8 users could stick with diehard

0.6.0
.

Usage

A quick example for diehard usage.

Retry block

A retry block will re-execute inner forms when retry criteria matches.

(require '[diehard.core :as dh])
(dh/with-retry {:retry-on TimeoutException
                :max-retries 3}
  (fetch-data-from-the-moon))

Circuit breaker

A circuit breaker will track the execution of inner block and skip execution if the open condition triggered.

(require '[diehard.core :as dh])

(defcircuitbreaker my-cb {:failure-threshold-ratio [8 10] :delay-ms 1000})

(dh/with-circuit-breaker my-cb (fetch-data-from-the-moon))

Rate limiter

A rate limiter protects your code block to run limited times per second. It will block or throw exception depends on your configuration.

(require '[diehard.core :as dh])

(defratelimiter my-rl {:rate 100})

(dh/with-rate-limiter my-rl (send-people-to-the-moon))

Bulkhead

Bulkhead allows you to limit concurrent execution on a code block.

(require '[diehard.core :as dh])

;; at most 10 threads can run the code block concurrently (defbulkhead my-bh {:concurrency 10})

(dh/with-bulkhead my-bh (send-people-to-the-moon))

Timeout

Timeouts allow you to fail an execution with

TimeoutExceededException
if it takes too long to complete
(require '[diehard.core :as dh])

(with-timeout {:timeout-ms 5000} (fly-me-to-the-moon))

Examples

Retry block

(dh/with-retry {:retry-on          Exception
                :max-retries       3
                :on-retry          (fn [val ex] (prn "retrying..."))
                :on-failure        (fn [_ _] (prn "failed..."))
                :on-failed-attempt (fn [_ _] (prn "failed attempt"))
                :on-success        (fn [_] (prn "did it! success!"))}
               (throw (ex-info "not good" {:not "good"})))

output:

"failed attempt"
"retrying..."
"failed attempt"
"retrying..."
"failed attempt"
"retrying..."
"failed attempt"
"failed..."
Execution error (ExceptionInfo) at main.user$eval27430$reify__27441/get (form-init6791465293873302710.clj:7).
not good

Docs

More options can be found in the documentation from cljdoc.

License

Copyright © 2016-2019 Ning Sun

Distributed under the Eclipse Public License either version 1.0 or (at your option) any later version.

Donation

I'm now accepting donation on liberapay, if you find my work helpful and want to keep it going.

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.