Apache Druid: a high performance real-time analytics database.
Go to file
Agustin Gonzalez 8e5048e643
Avoid memory mapping hydrants after they are persisted & after they are merged for native batch ingestion (#11123)
* Avoid mapping hydrants in create segments phase for native ingestion

* Drop queriable indices after a given sink is fully merged

* Do not drop memory mappings for realtime ingestion

* Style fixes

* Renamed to match use case better

* Rollback memoization code and use the real time flag instead

* Null ptr fix in FireHydrant toString plus adjustments to memory pressure tracking calculations

* Style

* Log some count stats

* Make sure sinks size is obtained at the right time

* BatchAppenderator unit test

* Fix comment typos

* Renamed methods to make them more readable

* Move persisted metadata from FireHydrant class to AppenderatorImpl. Removed superfluous differences and fix comment typo. Removed custom comparator

* Missing dependency

* Make persisted hydrant metadata map concurrent and better reflect the fact that keys are Java references. Maintain persisted metadata when dropping/closing segments.

* Replaced concurrent variables with normal ones

* Added   batchMemoryMappedIndex "fallback" flag with default "false". Set this to "true" make code fallback to previous code path.

* Style fix.

* Added note to new setting in doc, using Iterables.size (and removing a dependency), and fixing a typo in a comment.

* Forgot to commit this edited documentation message
2021-05-11 14:34:26 -07:00
.github Add instructions for updating licenses (#10894) 2021-03-03 00:57:09 -08:00
.idea IntelliJ inspection and checkstyle rule for "Collection.EMPTY_* field accesses replaceable with Collections.empty*()" (#9690) 2020-06-18 09:47:07 -07:00
benchmarks Enable rewriting certain inner joins as filters. (#11068) 2021-04-14 10:49:27 -07:00
cloud Fix kinesis ingestion bugs (#10761) 2021-02-05 02:49:58 -08:00
codestyle Add Calcite Avatica protobuf handler (#10543) 2021-03-31 12:46:25 -07:00
core Make sure updating coordinator config is protected against race condition (#11144) 2021-05-10 13:58:08 -07:00
dev chore: fix case of GitHub (#10928) 2021-05-07 01:15:43 -07:00
distribution Consolidate the number of Dockerfiles (#11187) 2021-05-07 10:41:34 -07:00
docs Avoid memory mapping hydrants after they are persisted & after they are merged for native batch ingestion (#11123) 2021-05-11 14:34:26 -07:00
examples First refactor of compaction (#10935) 2021-03-24 11:41:44 -07:00
extendedset Bump dev version to 0.22.0-SNAPSHOT (#10759) 2021-01-15 13:16:23 -08:00
extensions-contrib fix count and average SQL aggregators on constant virtual columns (#11208) 2021-05-10 13:41:48 -07:00
extensions-core Avoid memory mapping hydrants after they are persisted & after they are merged for native batch ingestion (#11123) 2021-05-11 14:34:26 -07:00
helm Add helm chart for Apache Druid (#11163) 2021-04-29 12:38:50 +08:00
hll Bump dev version to 0.22.0-SNAPSHOT (#10759) 2021-01-15 13:16:23 -08:00
hooks Add git pre-commit hook to source control (#9554) 2020-06-05 11:19:42 -10:00
indexing-hadoop Hadoop segment index file rename (#11194) 2021-05-04 20:22:18 -04:00
indexing-service Avoid memory mapping hydrants after they are persisted & after they are merged for native batch ingestion (#11123) 2021-05-11 14:34:26 -07:00
integration-tests Consolidate the number of Dockerfiles (#11187) 2021-05-07 10:41:34 -07:00
licenses Web console: update dev dependencies (#11119) 2021-04-16 20:15:19 -07:00
processing fix count and average SQL aggregators on constant virtual columns (#11208) 2021-05-10 13:41:48 -07:00
publications De-incubation cleanup in code, docs, packaging (#9108) 2020-01-03 12:33:19 -05:00
server Avoid memory mapping hydrants after they are persisted & after they are merged for native batch ingestion (#11123) 2021-05-11 14:34:26 -07:00
services Add feature to automatically remove datasource metadata based on retention period (#11227) 2021-05-11 01:22:33 -07:00
sql fix count and average SQL aggregators on constant virtual columns (#11208) 2021-05-10 13:41:48 -07:00
web-console Handle not having default rules better (#11214) 2021-05-10 15:13:15 -04:00
website Allow user to set group.id for Kafka ingestion task (#11147) 2021-05-09 11:56:19 +08:00
.asf.yaml Add .asf.yaml. (#9083) 2019-12-20 16:45:38 -08:00
.backportrc.json Add 0.18.0 to .backportrc.json to facilitate backport. (#9661) 2020-04-11 13:49:04 -07:00
.codecov.yml Use Codecov (#8388) 2019-08-28 08:49:30 -07:00
.dockerignore Add docker container for druid (#6896) 2019-02-08 12:12:28 +00:00
.gitignore Web console basic end-to-end-test (#9595) 2020-04-09 12:38:09 -07:00
.lgtm.yml Suppress LGTM warnings about stack trace exposure (#9631) 2020-04-09 17:31:03 -07:00
.travis.yml Web console: update dev dependencies (#11119) 2021-04-16 20:15:19 -07:00
CONTRIBUTING.md Fix numbered list formatting in markdown. (#9664) 2020-04-21 20:18:12 -07:00
LABELS Add plain text README.txt, use relative link from README.md to build.md (#7611) 2019-05-09 21:29:26 -07:00
LICENSE support Aliyun OSS service as deep storage (#9898) 2020-07-01 22:20:53 -07:00
NOTICE license.yaml fixes for code introduced related to AWS RDS token based password provider in PR #9518 (#10885) 2021-03-10 12:59:25 -08:00
README.md Update badge for travis in README.md (#10717) 2021-01-07 18:39:58 -08:00
README.template De-incubation cleanup in code, docs, packaging (#9108) 2020-01-03 12:33:19 -05:00
licenses.yaml Upgrade jetty version (#11207) 2021-05-06 18:21:36 +08:00
owasp-dependency-check-suppressions.xml Suppressing false positive CVE-2020-7791 (#11215) 2021-05-06 15:24:12 -07:00
pom.xml Upgrade jetty version (#11207) 2021-05-06 18:21:36 +08:00
setup-hooks.sh Add git pre-commit hook to source control (#9554) 2020-06-05 11:19:42 -10:00
upload.sh Adding licenses and enable apache-rat-plugin. (#6215) 2018-09-18 08:39:26 -07:00

README.md

Slack Build Status Language grade: Java Coverage Status Docker Helm


Website | Documentation | Developer Mailing List | User Mailing List | Slack | Twitter | Download


Apache Druid

Druid is a high performance real-time analytics database. Druid's main value add is to reduce time to insight and action.

Druid is designed for workflows where fast queries and ingest really matter. Druid excels at powering UIs, running operational (ad-hoc) queries, or handling high concurrency. Consider Druid as an open source alternative to data warehouses for a variety of use cases.

Getting started

You can get started with Druid with our local or Docker quickstart.

Druid provides a rich set of APIs (via HTTP and JDBC) for loading, managing, and querying your data. You can also interact with Druid via the built-in console (shown below).

Load data

data loader Kafka

Load streaming and batch data using a point-and-click wizard to guide you through ingestion setup. Monitor one off tasks and ingestion supervisors.

Manage the cluster

management

Manage your cluster with ease. Get a view of your datasources, segments, ingestion tasks, and services from one convenient location. All powered by SQL systems tables, allowing you to see the underlying query for each view.

Issue queries

query view combo

Use the built-in query workbench to prototype DruidSQL and native queries or connect one of the many tools that help you make the most out of Druid.

Documentation

You can find the documentation for the latest Druid release on the project website.

If you would like to contribute documentation, please do so under /docs in this repository and submit a pull request.

Community

Community support is available on the druid-user mailing list, which is hosted at Google Groups.

Development discussions occur on dev@druid.apache.org, which you can subscribe to by emailing dev-subscribe@druid.apache.org.

Chat with Druid committers and users in real-time on the #druid channel in the Apache Slack team. Please use this invitation link to join the ASF Slack, and once joined, go into the #druid channel.

Building from source

Please note that JDK 8 is required to build Druid.

For instructions on building Druid from source, see docs/development/build.md

Contributing

Please follow the community guidelines for contributing.

For instructions on setting up IntelliJ dev/intellij-setup.md

License

Apache License, Version 2.0