Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gocrane/crane
Crane is a FinOps Platform for Cloud Resource Analytics and Economics in Kubernetes clusters. The goal is not only to help users to manage cloud cost easier but also ensure the quality of applications.
https://github.com/gocrane/crane
analytics autoscaling cloud-computing cloud-native cncf cost-control cost-estimation cost-optimization finops kubernetes monitoring prediction time-series
Last synced: 6 days ago
JSON representation
Crane is a FinOps Platform for Cloud Resource Analytics and Economics in Kubernetes clusters. The goal is not only to help users to manage cloud cost easier but also ensure the quality of applications.
- Host: GitHub
- URL: https://github.com/gocrane/crane
- Owner: gocrane
- License: apache-2.0
- Created: 2021-11-18T03:36:30.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-12-20T01:55:09.000Z (about 1 month ago)
- Last Synced: 2025-01-07T20:06:16.016Z (13 days ago)
- Topics: analytics, autoscaling, cloud-computing, cloud-native, cncf, cost-control, cost-estimation, cost-optimization, finops, kubernetes, monitoring, prediction, time-series
- Language: Go
- Homepage: https://gocrane.io
- Size: 66.3 MB
- Stars: 1,907
- Watchers: 41
- Forks: 387
- Open Issues: 127
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Roadmap: docs/roadmaps/roadmap-2022.md
Awesome Lists containing this project
- awesome-ops - gocrane/crane - 2.0|1866|2021-11-18|2024-08-21 | Crane 是一个基于 FinOps 的云资源分析与成本优化平台。它的愿景是在保证客户应用运行质量的前提下实现极致的降本。 | (K8S-Tools)
README
# Crane: Cloud Resource Analytics and Economics
[![Go Report Card](https://goreportcard.com/badge/github.com/gocrane/crane)](https://goreportcard.com/report/github.com/gocrane/crane)
[![GoDoc](https://godoc.org/github.com/gocrane/crane?status.svg)](https://godoc.org/github.com/gocrane/crane)
[![License](https://img.shields.io/github/license/gocrane/crane)](https://www.apache.org/licenses/LICENSE-2.0.html)
![GoVersion](https://img.shields.io/github/go-mod/go-version/gocrane/crane)---
## What is Crane
> English | [中文](README_zh.md)
Crane is a FinOps Platform for Cloud Resource Analytics and Economics in Kubernetes clusters. The goal is not only help user to manage cloud cost easier but also ensure the quality of applications.
Crane is a [FinOps Certified Solution](https://www.finops.org/certifications/finops-certified-solution/) project of the [FinOps Foundation](https://www.finops.org/).
**How to start a Cost-Saving journey on Crane?**
1. **Understanding**: Cost insight for cloud assets and kubernetes resources(Deployments, StatefulSets).
2. **Analytics**: Periodically analytics the states in cluster and provide optimization recommendations.
3. **Optimization**: Rich set of functionalities to operate and reduce your cost.https://user-images.githubusercontent.com/35299017/186680122-d7756b47-06be-44cb-8553-1957eaa3ed45.mp4
**Live Demo** for Crane Dashboard: http://dashboard.gocrane.io/
## Main Features
**Cost Visualization and Optimization Evaluation**
- Provides a collection of exporters which collect cloud resource pricing and billing data and ship to your monitoring system like Prometheus.
- Multi-dimensional cost insight, optimization evaluates are supported. Support Multi-cloud Pricing through `Cloud Provider`。**Recommendation Framework**
Provide a pluggable framework for analytics and give recommendation for cloud resources, support out-of-box recommenders: Workload Resources/Replicas, Idle Resources. [learn more](https://gocrane.io/docs/tutorials/recommendation/).
**Prediction-driven Horizontal Autoscaling**
EffectiveHorizontalPodAutoscaler supports prediction-driven autoscaling. With this capability, user can forecast the incoming peak flow and scale up their application ahead, also user can know when the peak flow will end and scale down their application gracefully. [learn more](https://gocrane.io/docs/tutorials/using-effective-hpa-to-scaling-with-effectiveness/).
**Load-Aware Scheduling**
Provide a simple but efficient scheduler that schedule pods based on actual node utilization data,and filters out those nodes with high load to balance the cluster. [learn more](https://gocrane.io/docs/tutorials/scheduling-pods-based-on-actual-node-load/).
**Colocation with Enhanced QOS**
QOS-related capabilities ensure the running stability of Pods on Kubernetes. It has the ability of interference detection and active avoidance under the condition of multi-dimensional metrics, and supports reasonable operation and custom metrics access; it has the ability to oversell elastic resources enhanced by the prediction algorithm, reuse and limit the idle resources in the cluster; it has the enhanced bypass cpuset Management capabilities, improve resource utilization efficiency while binding cores. [learn more](docs/tutorials/using-qos-ensurance.md).
## Architecture
The overall architecture of Crane is shown as below:
**Craned**
Craned is the core component which manage the lifecycle of CRDs and APIs. It's deployed by a `Deployment` which consists of two container:
- Craned: Operators for management CRDs, WebApi for Dashboard, Predictors that provide query TimeSeries API.
- Dashboard: Web component that built from TDesign's Starter, provide an easy-to-use UI for crane users.**Fadvisor**
Fadvisor provides a collection of exporters which collect cloud resource pricing and billing data and ship to your monitoring system like Prometheus. Fadvisor support Multi-Cloud Pricing API by `Cloud Provider`.
**Metric Adapter**
Metric Adapter implements a `Custom Metric Apiserver`. Metric Adapter consume Crane CRDs and provide HPA Metrics by `Custom/External Metric API`.
**Crane Agent**
Crane Agent is a `DaemonSet` that runs in each node.
## Getting Started
- [Introduction](https://gocrane.io/docs/getting-started/introduction/)
- [Quick Start](https://gocrane.io/docs/getting-started/installation/quick-start/)
- [Tutorials](https://gocrane.io/docs/tutorials/)## Documentation
Full documentation is available on the [Crane website](https://gocrane.io).
## Community
- Slack(English): [https://gocrane.slack.com](https://join.slack.com/t/gocrane/shared_invite/zt-1rirt4xgk-N1ckyMW4acbPLWA8AemhxA)
- Wechat Group (Chinese):
Add it and Reply "Crane",Robot will add you in Wechat group.- Bi-weekly Community Call(APAC, Chinese)
- [Meeting Link](https://meeting.tencent.com/dm/ri7x8wCCEUut)
- [Meeting Notes](https://doc.weixin.qq.com/doc/w3_AHMAlwa_AFU7PT58rVhTFKXV0maR6?scode=AJEAIQdfAAo0gvbrCIAHMAlwa_AFU)
- [Video Records](https://www.wolai.com/33xC4HB1JXCCH1x8umfioS)## RoadMap
Please see [this document](./docs/roadmaps/roadmap-2022.md) to learn more.
## Contributing
Contributors are welcomed to join Crane project. Please check [CONTRIBUTING](./CONTRIBUTING.md) about how to contribute to this project.
For how to start develop for Crane, you can check [developer's documentation](./docs/developer-guide.md).
## Code of Conduct
Crane adopts [CNCF Code of Conduct](https://github.com/cncf/foundation/blob/master/code-of-conduct.md).