Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/apache/carbondata
High performance data store solution
https://github.com/apache/carbondata
apache big-data carbondata data-format hadoop java scala spark
Last synced: 3 days ago
JSON representation
High performance data store solution
- Host: GitHub
- URL: https://github.com/apache/carbondata
- Owner: apache
- License: apache-2.0
- Created: 2016-06-28T07:00:06.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-12-23T21:15:46.000Z (about 1 month ago)
- Last Synced: 2025-01-14T19:24:24.868Z (10 days ago)
- Topics: apache, big-data, carbondata, data-format, hadoop, java, scala, spark
- Language: Scala
- Homepage: carbondata.apache.org
- Size: 82.6 MB
- Stars: 1,434
- Watchers: 124
- Forks: 703
- Open Issues: 140
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Support: docs/supported-data-types-in-carbondata.md
Awesome Lists containing this project
README
Apache CarbonData is an indexed columnar data store solution for fast analytics on big data platform, e.g. Apache Hadoop, Apache Spark, etc.
You can find the latest CarbonData document and learn more at:
[https://carbondata.apache.org](https://carbondata.apache.org/)[CarbonData cwiki](https://cwiki.apache.org/confluence/display/CARBONDATA/)
## Status
Spark2.4:
[![Coverage Status](https://coveralls.io/repos/github/apache/carbondata/badge.svg?branch=master)](https://coveralls.io/github/apache/carbondata?branch=master)
## Features
CarbonData file format is a columnar store in HDFS, it has many features that a modern columnar format has, such as splittable, compression schema, complex data type etc, and CarbonData has following unique features:
* Stores data along with index: it can significantly accelerate query performance and reduces the I/O scans and CPU resources, where there are filters in the query. CarbonData index consists of multiple level of indices, a processing framework can leverage this index to reduce the task it needs to schedule and process, and it can also do skip scan in more finer grain unit (called blocklet) in task side scanning instead of scanning the whole file.
* Operable encoded data: through supporting efficient compression and global encoding schemes, can query on compressed/encoded data, the data can be converted just before returning the results to the users, which is "late materialized".
* Supports for various use cases with one single Data format : like interactive OLAP-style query, Sequential Access (big scan), Random Access (narrow scan).## Building CarbonData
CarbonData is built using Apache Maven, to [build CarbonData](https://github.com/apache/carbondata/blob/master/build)## Online Documentation
* [What is CarbonData](https://github.com/apache/carbondata/blob/master/docs/introduction.md)
* [Quick Start](https://github.com/apache/carbondata/blob/master/docs/quick-start-guide.md)
* [Use Cases](https://github.com/apache/carbondata/blob/master/docs/usecases.md)
* [Language Reference](https://github.com/apache/carbondata/blob/master/docs/language-manual.md)
* [CarbonData Data Definition Language](https://github.com/apache/carbondata/blob/master/docs/ddl-of-carbondata.md)
* [CarbonData Data Manipulation Language](https://github.com/apache/carbondata/blob/master/docs/dml-of-carbondata.md)
* [CarbonData Streaming Ingestion](https://github.com/apache/carbondata/blob/master/docs/streaming-guide.md)
* [Configuring CarbonData](https://github.com/apache/carbondata/blob/master/docs/configuration-parameters.md)
* [Index Developer Guide](https://github.com/apache/carbondata/blob/master/docs/index-developer-guide.md)
* [Data Types](https://github.com/apache/carbondata/blob/master/docs/supported-data-types-in-carbondata.md)
* [CarbonData Index Management](https://github.com/apache/carbondata/blob/master/docs/index/index-management.md)
* [CarbonData BloomFilter Index](https://github.com/apache/carbondata/blob/master/docs/index/bloomfilter-index-guide.md)
* [CarbonData Lucene Index](https://github.com/apache/carbondata/blob/master/docs/index/lucene-index-guide.md)
* [CarbonData MV](https://github.com/apache/carbondata/blob/master/docs/mv-guide.md)
* [Carbondata Secondary Index](https://github.com/apache/carbondata/blob/master/docs/index/secondary-index-guide.md)
* [Heterogeneous format segments in carbondata](https://github.com/apache/carbondata/blob/master/docs/addsegment-guide.md)
* [SDK Guide](https://github.com/apache/carbondata/blob/master/docs/sdk-guide.md)
* [C++ SDK Guide](https://github.com/apache/carbondata/blob/master/docs/csdk-guide.md)
* [Performance Tuning](https://github.com/apache/carbondata/blob/master/docs/performance-tuning.md)
* [S3 Storage](https://github.com/apache/carbondata/blob/master/docs/s3-guide.md)
* [Distributed Index Server](https://github.com/apache/carbondata/blob/master/docs/index-server.md)
* [CDC and SCD](https://github.com/apache/carbondata/blob/master/docs/scd-and-cdc-guide.md)
* [Carbon as Spark's Datasource](https://github.com/apache/carbondata/blob/master/docs/carbon-as-spark-datasource-guide.md)
* [FAQs](https://github.com/apache/carbondata/blob/master/docs/faq.md)## Experimental Features
Some features are marked as experimental because the syntax/implementation might change in the future.
1. Hybrid format table using Add Segment.
2. Accelerating performance using MV on parquet/orc.
3. Merge API for Spark DataFrame.
4. Hive write for non-transactional table.
5. Secondary Index as a Coarse Grain Index in query processing.## Integration
* [Hive](https://github.com/apache/carbondata/blob/master/docs/hive-guide.md)
* [Presto](https://github.com/apache/carbondata/blob/master/docs/prestodb-guide.md)
* [Alluxio](https://github.com/apache/carbondata/blob/master/docs/alluxio-guide.md)
* [Flink](https://github.com/apache/carbondata/blob/master/docs/flink-integration-guide.md)## Other Technical Material
* [Apache CarbonData meetup material](https://cwiki.apache.org/confluence/pages/viewpage.action?pageId=66850609)
* [Use Case Articles](https://cwiki.apache.org/confluence/display/CARBONDATA/CarbonData+Articles)## Fork and Contribute
This is an active open source project for everyone, and we are always open to people who want to use this system or contribute to it.
This guide document introduces [how to contribute to CarbonData](https://github.com/apache/carbondata/blob/master/docs/how-to-contribute-to-apache-carbondata.md).## Contact us
To get involved in CarbonData:* First join by emailing to [[email protected]](mailto:[email protected]), then you can discuss issues by emailing to [[email protected]](mailto:[email protected]).
You can also directly visit [[email protected]](https://lists.apache.org/[email protected]).
Or you can visit [Apache CarbonData Dev Mailing List archive](https://lists.apache.org/[email protected]).
* Report issues on [github issues](https://github.com/apache/carbondata/issues).* You can also slack to get in touch with the community. After we invite you, you can use this [Slack Link](https://carbondataworkspace.slack.com/) to sign in to CarbonData.
## About
Apache CarbonData is an open source project of The Apache Software Foundation (ASF).