About Cassandra for DSEDocumentation for developers and administrators on configuring, and using the features and capabilities of Apache Cassandra provided with DataStax Enterprise (DSE).
What's newAn overview of new features in Cassandra.
CQLCassandra Query Language (CQL) is the default and primary interface into the Cassandra DBMS.
Understanding the architectureImportant topics for understanding Cassandra.
Architecture in briefEssential information for understanding and using Cassandra.
Internode communications (gossip)Cassandra uses a protocol called gossip to discover location and state information about the other nodes participating in a Cassandra cluster.
Data distribution and replicationHow data is distributed and factors influencing replication.
PartitionersA partitioner determines how data is distributed across the nodes in the cluster (including replicas).
SnitchesA snitch determines which datacenters and racks nodes belong to.
Client requestsClient read or write requests can be sent to any node in the cluster because all nodes in Cassandra are peers.
Planning a deploymentVital information about successfully deploying a Cassandra cluster.
InstallingVarious installation methods.
Installing on RHEL-based systemsInstall using Yum repositories on RHEL, CentOS, and Oracle Linux.
Installing on Debian-based systemsInstall using APT repositories on Debian and Ubuntu.
Installing from the binary tarballInstall on all Linux-based platforms using a binary tarball.
Installing prior releasesSteps for installing the same version as other nodes in your cluster.
Installing Python 2.7 on older RHEL-based package installationsSteps for installing Python 2.7 on older distributions such as CentOS 6.5.
Uninstalling CassandraSteps for uninstalling Cassandra by install type.
Installing on cloud providersInstallation methods for the supported cloud providers.
Installing Oracle JDKInstructions for various platforms.
Recommended production settings for LinuxRecommendations for Linux production environments.
Initializing a clusterTopics for deploying a cluster.
Initializing a multiple node cluster (single datacenter)A deployment scenario for a Cassandra cluster with a single datacenter.
Initializing a multiple node cluster (multiple datacenters)A deployment scenario for a Cassandra cluster with multiple datacenters.
SecurityTopics for securing Cassandra.
Securing CassandraCassandra provides various security features to the open source community.
SSL encryptionTopics for using SSL in Cassandra.
Internal authenticationTopics for internal authentication.
Internal authorizationTopics about internal authorization.
Configuring firewall port accessWhich ports to open when nodes are protected by a firewall.
Enabling JMX authenticationThe default settings for Cassandra make JMX accessible only from localhost. To enable remote JMX connections, change the LOCAL_JMX setting in cassandra-env.sh.
Database internalsTopics about the Cassandra database.
Storage engineA description about Cassandra's storage structure and engine.
Separate table directoriesCassandra provides fine-grained control of table storage on disk.
Cassandra storage basicsUnderstanding how Casssandra stores data.
The write path of an updateA brief description of the write path of an update.
About deletesHow Cassandra deletes data and why deleted data can reappear.
About hinted handoff writesHow hinted handoff works and how it optimizes the cluster.
ReadsHow reads work and factors affecting them.
About transactions and concurrency controlA brief description about transactions and concurrency control.
Data consistencyTopics about how up-to-date and synchronized a row of data is on all replicas.
ConfigurationConfiguration topics.
cassandra.yaml configuration fileThe cassandra.yaml file is the main configuration file for Cassandra.
Configuring gossip settingsUsing the cassandra.yaml file to configure gossip.
Configuring the heap dump directoryAnalyzing the heap dump file can help troubleshoot memory problems.
Configuring the buffered read sizeConfiguring the buffered read size can reduce problems with wasted disk I/) and unnecessary garbage collection.
Configuring virtual nodesTopics about configuring virtual nodes.
Using multiple network interfacesSteps for configuring Cassandra for multiple network interfaces or when using different regions in cloud implementations.
Configuring loggingAbout Cassandra logging functionality using Simple Logging Facade for Java (SLF4J) with a logback backend.
Commit log archive configurationCassandra provides commit log archiving and point-in-time recovery.
Generating tokensIf not using virtual nodes (vnodes), you must calculate tokens for your cluster.
Hadoop supportCassandra support for integrating Hadoop with Cassandra.
OperationsOperation topics.
Tuning Bloom filtersCassandra uses Bloom filters to determine whether an SSTable has data for a particular row.
Data cachingData caching topics.
Configuring memtable throughputConfiguring memtable throughput to improve write performance.
Configuring compactionSteps for configuring compaction. The compaction process merges keys, combines columns, evicts tombstones, consolidates SSTables, and creates a new index in the merged SSTable.
CompressionCompression maximizes the storage capacity of Cassandra nodes by reducing the volume of data on disk and disk I/O, particularly for read-dominated workloads.
Tuning Java resourcesTuning the Java Virtual Machine (JVM) can improve performance or reduce high memory consumption.
Purging gossip state on a nodeCorrecting a problem in the gossip state.
Repairing nodesNode repair topics.
Adding or removing nodes, datacenters, or clustersTopics for adding or removing nodes, datacenters, or clusters.
Backing up and restoring dataCassandra backs up data by taking a snapshot of all on-disk data files (SSTable files) stored in the data directory.
About snapshotsA brief description of how Cassandra backs up data.
Taking a snapshotSteps for taking a global snapshot or per node.
Deleting snapshot filesSteps to delete snapshot files.
Enabling incremental backupsSteps to enable incremental backups. When incremental backups are enabled, Cassandra hard-links each memtable flushed to a SSTable to a backups directory under the keyspace data directory.
Restoring from a snapshotMethods for restoring from a snapshot.
Restoring a snapshot into a new clusterSteps for restoring a snapshot by recovering the cluster into another newly created cluster.
Recovering using JBODRecovering from a single disk failure in a disk array using JBOD.
Cassandra toolsTopics for Cassandra tools.
About the nodetool utilityA command line interface for managing a cluster.
The cassandra utilityCassandra start-up parameters can be run from the command line (in Tarball installations) or specified in the cassandra-env.sh file (Package or Tarball installations).
The cassandra-stress toolA Java-based stress testing utility for basic benchmarking and load testing a Cassandra cluster.
SSTable utilitiesTools for using, upgrading, and changing Cassandra SSTables.
ReferencesReference topics.
Starting and stopping CassandraTopics for starting and stopping Cassandra.
Install locationsInstall location topics.
Cassandra include fileSet environment variables (cassandra.in.sh).
Cassandra-CLI utility (deprecated) Deprecated configuration attributes. Will be removed in Cassandra 3.0.
Moving data to/from other databasesSolutions for migrating from other databases.
Release notesHow to find the Apache Cassandra release notes.