Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/taoensso/tufte
Simple performance monitoring library for Clojure/Script
https://github.com/taoensso/tufte
benchmarking clojure clojurescript epl performance-monitoring profiling taoensso
Last synced: about 2 months ago
JSON representation
Simple performance monitoring library for Clojure/Script
- Host: GitHub
- URL: https://github.com/taoensso/tufte
- Owner: taoensso
- License: epl-1.0
- Created: 2016-07-07T04:50:01.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-04-11T13:28:30.000Z (9 months ago)
- Last Synced: 2024-05-01T21:41:21.153Z (9 months ago)
- Topics: benchmarking, clojure, clojurescript, epl, performance-monitoring, profiling, taoensso
- Language: Clojure
- Homepage: https://www.taoensso.com/tufte
- Size: 683 KB
- Stars: 529
- Watchers: 13
- Forks: 22
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: FUNDING.yml
- License: LICENSE.txt
Awesome Lists containing this project
- stars - taoensso/tufte - Simple performance monitoring library for Clojure/Script \[*Eclipse Public License 1.0*\] (⭐️543) (Clojure)
- stars - taoensso/tufte - Simple performance monitoring library for Clojure/Script \[*Eclipse Public License 1.0*\] (⭐️541) (Clojure)
README
[**Documentation**](#documentation) | [Latest releases](#latest-releases) | [Get support][GitHub issues]# Tufte
### Simple performance monitoring for Clojure/Script applications
**Tufte** allows you to **easily monitor the ongoing performance** of your Clojure and ClojureScript applications in production and other environments.
It provides **sensible application-level metrics**, and gives them to you as **Clojure data** that can be easily analyzed programatically.
> [Carte Figurative](https://en.wikipedia.org/wiki/Charles_Joseph_Minard#The_map_of_Napoleon's_Russian_campaign), one of [Edward Tufte](https://en.wikipedia.org/wiki/Edward_Tufte)'s favourite data visualizations.
## Latest release/s
- `2023-09-27` `2.6.3`: [changes](../../releases/tag/v2.6.3)
[![Main tests][Main tests SVG]][Main tests URL]
[![Graal tests][Graal tests SVG]][Graal tests URL]See [here][GitHub releases] for earlier releases.
## Why Tufte?
- Small, **fast**, cross-platform Clojure/Script codebase
- Sensible **application-level metrics** without the obscure JVM-level noise
- **Metrics as Clojure maps**: easily aggregate, **analyse**, log, serialize to db, etc.
- **Tiny**, flexible API: [`p`](https://taoensso.github.io/tufte/taoensso.tufte.html#var-p), [`profiled`](https://taoensso.github.io/tufte/taoensso.tufte.html#var-profiled), [`profile`](https://taoensso.github.io/tufte/taoensso.tufte.html#var-profile)
- Great **compile-time elision** and **runtime filtering** support
- Arbitrary Clojure/Script **form-level** profiling
- Full support for **thread-local** and **multi-threaded** profiling## 10-second example
```clojure
(require '[taoensso.tufte :as tufte :refer [defnp p profiled profile]]);; Request to send `profile` stats to `println`:
(tufte/add-basic-println-handler! {});;; Define a couple dummy fns to simulate doing some expensive work
(defn get-x [] (Thread/sleep 500) "x val")
(defn get-y [] (Thread/sleep (rand-int 1000)) "y val");; Let's check how these fns perform:
(profile ; Profile any `p` forms called during body execution
{} ; Profiling options; we'll use the defaults for now
(dotimes [_ 5]
(p :get-x (get-x))
(p :get-y (get-y))));; The following will be printed to *out*:
;;
;; pId nCalls Min 50% ≤ 90% ≤ 95% ≤ 99% ≤ Max Mean MAD Clock Total
;; :get-x 5 501ms 503ms 505ms 505ms 505ms 505ms 503ms ±0% 2.52s 53%
;; :get-y 5 78ms 396ms 815ms 815ms 815ms 815ms 452ms ±48% 2.25s 47%
;;
;; Accounted 4.78s 100%
;; Clock 4.78s 100%
```## Documentation
- [Full documentation][GitHub wiki] (**getting started** and more)
- Auto-generated API reference: [Codox][Codox docs], [clj-doc][clj-doc docs]## Funding
You can [help support][sponsor] continued work on this project, thank you!! 🙏
## License
Copyright © 2016-2023 [Peter Taoussanis][].
Licensed under [EPL 1.0](LICENSE.txt) (same as Clojure).[GitHub releases]: ../../releases
[GitHub issues]: ../../issues
[GitHub wiki]: ../../wiki[Peter Taoussanis]: https://www.taoensso.com
[sponsor]: https://www.taoensso.com/sponsor[Codox docs]: https://taoensso.github.io/tufte/
[clj-doc docs]: https://cljdoc.org/d/com.taoensso/tufte/[Clojars SVG]: https://img.shields.io/clojars/v/com.taoensso/tufte.svg
[Clojars URL]: https://clojars.org/com.taoensso/tufte[Main tests SVG]: https://github.com/taoensso/tufte/actions/workflows/main-tests.yml/badge.svg
[Main tests URL]: https://github.com/taoensso/tufte/actions/workflows/main-tests.yml
[Graal tests SVG]: https://github.com/taoensso/tufte/actions/workflows/graal-tests.yml/badge.svg
[Graal tests URL]: https://github.com/taoensso/tufte/actions/workflows/graal-tests.yml