Apache Cassandra® https://cassandra.apache.org/
Find a file
Sam Tunnicliffe 5c07c122be Ninja: increase heap size in LocalRangesAllSettledBench
Follow up to 4454ab8699 (CASSANDRA-21144)
2026-03-19 10:27:57 +00:00
.build Merge branch 'cassandra-5.0' into trunk 2026-03-16 22:06:27 +01:00
.circleci Migrate sstableloader code to its own tools directory and artifact 2025-05-18 12:35:52 -05:00
.github Add a github action that runs .build/docker/check-code.sh 2025-10-13 12:34:51 +02:00
.idea/codeStyles Add configuration for sorted imports in source files 2025-12-30 22:34:12 +01:00
.jenkins Merge branch 'cassandra-5.0' into trunk 2026-03-16 22:06:27 +01:00
bin Merge branch 'cassandra-4.0' into cassandra-4.1 2026-03-17 23:06:38 +01:00
ci
conf Merge branch 'cassandra-5.0' into trunk 2026-03-17 23:09:49 +01:00
debian ninja-fix add offlineclustermetadatadump tool to bin directory in deb/rpm packages 2026-03-16 08:52:12 +01:00
doc Merge branch 'cassandra-5.0' into trunk 2026-03-17 23:09:49 +01:00
examples Support custom StartupCheck implementations via SPI 2026-02-02 10:12:37 +11:00
ide Move the code style configuration from the .idea/codeStyles to the ide/idea folder 2026-02-15 17:47:54 +01:00
lib Accord: PreLoadContext must properly and consistently support ranges 2025-04-17 11:59:50 -07:00
modules Fix flakey test org.apache.cassandra.utils.SimpleBitSetSerializersTest#any 2026-01-07 16:00:10 -08:00
pylib Merge branch 'cassandra-5.0' into trunk 2026-03-17 23:09:49 +01:00
redhat ninja-fix add offlineclustermetadatadump tool to bin directory in deb/rpm packages 2026-03-16 08:52:12 +01:00
src Merge branch 'cassandra-5.0' into trunk 2026-03-17 15:35:08 -05:00
test Ninja: increase heap size in LocalRangesAllSettledBench 2026-03-19 10:27:57 +00:00
tools Add tool to offline dump cluster metadata and the log 2026-03-13 15:21:19 +01:00
.asf.yaml enrich .asf.yaml 2024-08-23 10:48:15 +02:00
.git-blame-ignore-revs ninja: add a commit with the import order to ignore revs 2025-12-30 22:39:50 +01:00
.gitignore Move the code style configuration from the .idea/codeStyles to the ide/idea folder 2026-02-15 17:47:54 +01:00
.gitmodules Split AsyncChain and AsyncResult; normalise AsyncResult with C* Future 2025-09-18 12:31:13 +01:00
.snyk Merge branch 'cassandra-5.0' into trunk 2026-02-17 11:46:44 +11:00
build-shaded-dtest-jar.sh
build.properties.default Merge branch 'cassandra-5.0' into trunk 2024-09-16 15:53:25 -04:00
build.xml Merge branch 'cassandra-5.0' into trunk 2026-03-13 15:08:19 +00:00
CASSANDRA-14092.txt
CHANGES.txt Merge branch 'cassandra-5.0' into trunk 2026-03-17 23:09:49 +01:00
CONTRIBUTING.md Improving CONTRIBUTING.md for new contributors 2025-09-01 23:54:00 +08:00
LICENSE.txt
NEWS.txt Add JDK21 support 2026-02-02 12:39:05 -05:00
NOTICE.txt
README.asc Merge branch 'cassandra-5.0' into trunk 2026-01-20 15:30:22 +01:00
relocate-dependencies.pom Update maven-shade-plugin to version 3.6.1 2026-02-25 09:13:04 +01:00
TESTING.md

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

image:https://img.shields.io/badge/License-Apache%202.0-blue.svg[License, link=https://github.com/apache/cassandra/blob/trunk/LICENSE.txt]
image:https://ci-cassandra.apache.org/job/Cassandra-trunk/badge/icon[Build Status, link=https://ci-cassandra.apache.org/job/Cassandra-trunk/]      
image:https://img.shields.io/badge/Official-Downloads-brightgreen[Official Downloads, link=https://cassandra.apache.org/$$_$$/download.html]
image:https://img.shields.io/docker/pulls/$$_$$/cassandra[Docker Pulls, link=https://hub.docker.com/r/$$_$$/cassandra]      
image:https://img.shields.io/badge/Slack-4A154B?style=flat&logo=slack&logoColor=white[Slack, link=https://infra.apache.org/slack.html]
image:https://img.shields.io/badge/Bluesky-0285FF?logo=bluesky&logoColor=fff&color=0285FF[Bluesky, link=https://bsky.app/profile/cassandra.apache.org]
image:https://img.shields.io/badge/-LinkedIn-blue?style=flat-square&logo=Linkedin&logoColor=white&link=https://www.linkedin.com/company/apache-cassandra/[LinkedIn, link=https://www.linkedin.com/company/apache-cassandra/]
image:https://img.shields.io/badge/YouTube-FF0000?style=flat&logo=youtube&logoColor=white[Youtube, link=https://www.youtube.com/c/PlanetCassandra]


Apache Cassandra
-----------------

Apache Cassandra is a highly-scalable partitioned row store. Rows are organized into tables with a required primary key.

https://cwiki.apache.org/confluence/display/CASSANDRA2/Partitioners[Partitioning] means that Cassandra can distribute your data across multiple machines in an application-transparent matter. Cassandra will automatically repartition as machines are added and removed from the cluster.

https://cwiki.apache.org/confluence/display/CASSANDRA2/DataModel[Row store] means that like relational databases, Cassandra organizes data by rows and columns. The Cassandra Query Language (CQL) is a close relative of SQL.

For more information, see https://cassandra.apache.org/[the Apache Cassandra web site].

Issues should be reported on https://issues.apache.org/jira/projects/CASSANDRA/issues/[The Cassandra Jira].

Requirements
------------
- Java: see supported versions in build.xml (search for property "java.supported").
- Python: for `cqlsh`, see `bin/cqlsh` (search for function "is_supported_version").


Getting started
---------------

This short guide will walk you through getting a basic one node cluster up
and running, and demonstrate some simple reads and writes. For a more-complete guide, please see the Apache Cassandra website's https://cassandra.apache.org/doc/trunk/cassandra/getting-started/index.html[Getting Started Guide].

First, we'll unpack our archive:

  $ tar -zxvf apache-cassandra-$VERSION.tar.gz
  $ cd apache-cassandra-$VERSION

After that we start the server. Running the startup script with the -f argument will cause
Cassandra to remain in the foreground and log to standard out; it can be stopped with ctrl-C.

  $ bin/cassandra -f

Now let's try to read and write some data using the Cassandra Query Language:

  $ bin/cqlsh

The command line client is interactive so if everything worked you should
be sitting in front of a prompt:

----
Connected to Test Cluster at localhost:9160.
[cqlsh 6.3.0 | Cassandra 5.0-SNAPSHOT | CQL spec 3.4.8 | Native protocol v5]
Use HELP for help.
cqlsh>
----

As the banner says, you can use 'help;' or '?' to see what CQL has to
offer, and 'quit;' or 'exit;' when you've had enough fun. But lets try
something slightly more interesting:

----
cqlsh> CREATE KEYSPACE schema1
       WITH replication = { 'class' : 'SimpleStrategy', 'replication_factor' : 1 };
cqlsh> USE schema1;
cqlsh:Schema1> CREATE TABLE users (
                 user_id varchar PRIMARY KEY,
                 first varchar,
                 last varchar,
                 age int
               );
cqlsh:Schema1> INSERT INTO users (user_id, first, last, age)
               VALUES ('jsmith', 'John', 'Smith', 42);
cqlsh:Schema1> SELECT * FROM users;
 user_id | age | first | last
---------+-----+-------+-------
  jsmith |  42 |  john | smith
cqlsh:Schema1>
----

If your session looks similar to what's above, congrats, your single node
cluster is operational!

For more on what commands are supported by CQL, see
https://cassandra.apache.org/doc/trunk/cassandra/developing/cql/index.html[the CQL reference]. A
reasonable way to think of it is as, "SQL minus joins and subqueries, plus collections."

Wondering where to go from here?

  * Join us in #cassandra on the https://s.apache.org/slack-invite[ASF Slack] and ask questions.
  * Subscribe to the Users mailing list by sending a mail to
    user-subscribe@cassandra.apache.org.
  * Subscribe to the Developer mailing list by sending a mail to
    dev-subscribe@cassandra.apache.org.
  * Visit the https://cassandra.apache.org/community/[community section] of the Cassandra website for more information on getting involved.
  * Visit the https://cassandra.apache.org/doc/latest/development/index.html[development section] of the Cassandra website for more information on how to contribute.