Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/trickstercache/trickster
Open Source HTTP Reverse Proxy Cache and Time Series Dashboard Accelerator
https://github.com/trickstercache/trickster
accelerator caching clickhouse dashboards golang http-proxy influxdb performance prometheus reverse-proxy tsdb
Last synced: 3 months ago
JSON representation
Open Source HTTP Reverse Proxy Cache and Time Series Dashboard Accelerator
- Host: GitHub
- URL: https://github.com/trickstercache/trickster
- Owner: trickstercache
- License: apache-2.0
- Created: 2018-03-29T20:31:44.000Z (almost 7 years ago)
- Default Branch: main
- Last Pushed: 2024-04-09T23:02:20.000Z (10 months ago)
- Last Synced: 2024-04-18T03:00:07.600Z (9 months ago)
- Topics: accelerator, caching, clickhouse, dashboards, golang, http-proxy, influxdb, performance, prometheus, reverse-proxy, tsdb
- Language: Go
- Homepage: https://trickstercache.org
- Size: 29 MB
- Stars: 1,954
- Watchers: 43
- Forks: 177
- Open Issues: 53
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.MD
- Support: docs/supported-origin-types.md
- Governance: GOVERNANCE.md
- Roadmap: docs/roadmap.md
Awesome Lists containing this project
- awesome-go - Trickster - HTTP reverse proxy cache and time series accelerator. (Server Applications / HTTP Clients)
- awesome-ops - trickstercache/trickster - 2.0|1986|2018-03-29|2024-08-17 | HTTP 反向代理/缓存,用于时间序列数据库的仪表板查询加速器 | (时序数据库)
- awesome-repositories - trickstercache/trickster - Open Source HTTP Reverse Proxy Cache and Time Series Dashboard Accelerator (Go)
- awesome-clickhouse - trickstercache/trickster - Trickster is an open-source HTTP reverse proxy cache that enhances the performance of web applications and time series databases. (Integrations / Data Transfer and Synchronization)
- awesome-list - trickster
- awesome-go-extra - trickster - 03-29T20:31:44Z|2022-08-23T19:28:37Z| (Server Applications / HTTP Clients)
- awesome-cloud-native - Trickster - Open Source HTTP Reverse Proxy Cache and Time Series Dashboard Accelerator. (Observability)
README
# [![Follow on Twitter](https://img.shields.io/twitter/follow/trickstercache.svg?style=social&logo=twitter)](https://twitter.com/trickstercache)
[![License](https://img.shields.io/github/license/trickstercache/trickster)](/LICENSE)
[![Coverage Status](https://coveralls.io/repos/github/trickstercache/trickster/badge.svg)](https://coveralls.io/github/trickstercache/trickster)
[![build Status](https://github.com/trickstercache/trickster/workflows/build/badge.svg)](https://github.com/trickstercache/trickster/actions)
[![Go Report Card](https://goreportcard.com/badge/github.com/trickstercache/trickster)](https://goreportcard.com/report/github.com/trickstercache/trickster)
[![CII Best Practices](https://bestpractices.coreinfrastructure.org/projects/2518/badge)](https://bestpractices.coreinfrastructure.org/en/projects/2518)
[![GoDoc](https://godoc.org/github.com/trickstercache/trickster?status.svg)](https://godoc.org/github.com/trickstercache/trickster)
[![Docker Pulls](https://img.shields.io/docker/pulls/tricksterio/trickster.svg?maxAge=86400)](https://hub.docker.com/r/tricksterio/trickster)Trickster is an HTTP reverse proxy/cache for http applications and a dashboard query accelerator for time series databases.
Learn more below, and check out our [roadmap](./docs/roadmap.md) to find out what else is in the works.
Trickster is hosted by the [Cloud Native Computing Foundation](https://cncf.io) (CNCF) as a sandbox level project. If you are a company that wants to help shape the evolution of technologies that are container-packaged, dynamically-scheduled and microservices-oriented, consider joining the CNCF.
Note: Trickster v1.1 is the production release, sourced from the [v1.1.x](https://github.com/trickstercache/trickster/tree/v1.1.x) branch. The `main` branch sources Trickster 2.0, which is currently in beta.
## HTTP Reverse Proxy Cache
Trickster is a fully-featured HTTP Reverse Proxy Cache for HTTP applications like static file servers and web API's.
### Proxy Feature Highlights
* A unique and powerful [Application Load Balancer](./docs/alb.md) for Time Series and generic HTTP endpoints
* [Supports TLS](./docs/tls.md) and HTTP/2 for frontend termination and backend origination
* Offers several options for a [caching layer](./docs/caches.md), including in-memory, filesystem, Redis and bbolt
* [Highly customizable](./docs/configuring.md), using simple yaml configuration settings, [down to the HTTP Path](./docs/paths.md)
* Built-in Prometheus [metrics](./docs/metrics.md) and customizable [Health Check](./docs/health.md) Endpoints for end-to-end monitoring
* [Negative Caching](./docs/negative-caching.md) to prevent domino effect outages
* High-performance [Collapsed Forwarding](./docs/collapsed-forwarding.md)
* Best-in-class [Byte Range Request caching and acceleration](./docs/range_request.md).
* [Distributed Tracing](./docs/tracing.md) via OpenTelemetry, supporting Jaeger and Zipkin
* Rules engine for custom request routing and rewriting## Time Series Database Accelerator
Trickster dramatically improves dashboard chart rendering times for end users by eliminating redundant computations on the TSDBs it fronts. In short, Trickster makes read-heavy Dashboard/TSDB environments, as well as those with highly-cardinalized datasets, significantly more performant and scalable.
### Compatibility
Trickster works with virtually any Dashboard application that makes queries to any of these TSDB's:
Prometheus
ClickHouse
InfluxDB
Circonus IRONdb
See the [Supported TSDB Providers](./docs/supported-origin-types.md) document for full details
### How Trickster Accelerates Time Series
#### 1. Time Series Delta Proxy Cache
Most dashboards request from a time series database the entire time range of data they wish to present, every time a user's dashboard loads, as well as on every auto-refresh. Trickster's Delta Proxy inspects the time range of a client query to determine what data points are already cached, and requests from the tsdb only the data points still needed to service the client request. This results in dramatically faster chart load times for everyone, since the tsdb is queried only for tiny incremental changes on each dashboard load, rather than several hundred data points of duplicative data.
#### 2. Step Boundary Normalization
When Trickster requests data from a tsdb, it adjusts the clients's requested time range slightly to ensure that all data points returned are aligned to normalized step boundaries. For example, if the step is 300s, all data points will fall on the clock 0's and 5's. This ensures that the data is highly cacheable, is conveyed visually to users in a more familiar way, and that all dashboard users see identical data on their screens.
#### 3. Fast Forward
Trickster's Fast Forward feature ensures that even with step boundary normalization, real-time graphs still always show the most recent data, regardless of how far away the next step boundary is. For example, if your chart step is 300s, and the time is currently 1:21p, you would normally be waiting another four minutes for a new data point at 1:25p. Trickster will break the step interval for the most recent data point and always include it in the response to clients requesting real-time data.
## Trying Out Trickster
Check out our end-to-end [Docker Compose demo composition](./examples/docker-compose) for a zero-configuration running environment.
## Installing
### Docker
Docker images are available on Docker Hub:
$ docker run --name trickster -d -v /path/to/trickster.yaml:/etc/trickster/trickster.yaml -p 0.0.0.0:8480:8480 trickstercache/trickster
See the 'deploy' Directory for more information about using or creating Trickster docker images.
### Kubernetes
See the 'deploy' Directory for Kube and deployment files and examples.
### Helm
Trickster Helm Charts are located at for installation, and maintained at . We welcome chart contributions.
### Building from source
To build Trickster from the source code yourself you need to have a working
Go environment with [version 1.19 or greater installed](http://golang.org/doc/install).You can directly use the `go` tool to download and install the `trickster`
binary into your `GOPATH`:```bash
$ go get github.com/trickstercache/trickster/cmd/trickster
# this starts a prometheus accelerator proxy for the provided endpoint
$ trickster -origin-url http://prometheus.example.com:9090 -provider prometheus
```You can also clone the repository yourself and build using `make`:
```bash
$ mkdir -p $GOPATH/src/github.com/trickstercache
$ cd $GOPATH/src/github.com/trickstercache
$ git clone https://github.com/trickstercache/trickster.git
$ cd trickster
$ make build
$ ./bin/trickster -origin-url http://prometheus.example.com:9090 -provider prometheus
```The Makefile provides several targets, including:
* *build*: build the `trickster` binary
* *docker*: build a docker container for the current `HEAD`
* *clean*: delete previously-built binaries and object files
* *test*: runs unit tests
* *bench*: runs benchmark tests
* *rpm*: builds a Trickster RPM## More information
* Refer to the [docs](./docs/) directory for additional info.
## Contributing
Refer to [CONTRIBUTING.md](CONTRIBUTING.md)
© 2021 The Linux Foundation. All rights reserved. The Linux Foundation has registered trademarks and uses trademarks. For a list of trademarks of The Linux Foundation, please see our [Trademark Usage](https://www.linuxfoundation.org/trademark-usage) page.