Go to file
Jake Luciani 2d29ebd415 prepare 1.2.19 release 2014-09-12 12:45:52 -04:00
bin remove shuffle bat again 2014-08-04 12:12:43 -05:00
conf Enable keepalive for native protocol 2014-06-12 09:29:05 -05:00
debian prepare 1.2.19 release 2014-09-12 12:45:52 -04:00
doc Add UNLOGGED, COUNTER options to BATCH docs 2014-03-19 11:37:09 -05:00
examples update pig example scripts 2013-11-20 10:19:17 -06:00
interface comment CqlRow for #6807 2014-03-19 12:10:52 -05:00
lib match internal only filename to internal directory version 2013-10-18 10:08:25 -05:00
pylib Use 'text' formatter for 'ascii' values 2014-06-20 14:01:00 +11:00
src Don't index tombstones. 2014-09-08 12:01:37 -07:00
test Track expired tombstones 2014-08-27 12:55:17 +02:00
tools stress: add username/password authentication support 2013-10-12 23:49:47 +07:00
.gitignore add logs/ and data/ to .gitignore 2014-06-09 21:14:58 -04:00
.rat-excludes Update versions and licenses for 1.2.14 release 2014-01-31 10:45:03 +01:00
CHANGES.txt Don't index tombstones. 2014-09-08 12:01:37 -07:00
LICENSE.txt merge with 0.6 branch (post-850) 2010-03-26 16:31:52 +00:00
NEWS.txt Remove shuffle/taketoken 2014-08-01 13:56:09 -05:00
NOTICE.txt Update copyright date in NOTICE file 2014-03-17 11:03:32 +01:00
README.txt Update CQL example in readme file 2012-11-12 08:25:27 +01:00
build.properties.default merge from 0.8 2011-08-06 02:14:31 +00:00
build.xml prepare 1.2.19 release 2014-09-12 12:45:52 -04:00

README.txt


Cassandra is a highly scalable, eventually consistent, distributed, structured 
key-value store. 


Project description
-------------------

Cassandra brings together the distributed systems technologies from Dynamo 
and the data model from Google's BigTable. Like Dynamo, Cassandra is 
eventually consistent. Like BigTable, Cassandra provides a ColumnFamily-based
data model richer than typical key/value systems.

For more information see http://cassandra.apache.org/

Requirements
------------
  * Java >= 1.6 (OpenJDK and Sun have been tested)

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.

  * tar -zxvf apache-cassandra-$VERSION.tar.gz
  * cd apache-cassandra-$VERSION
  * sudo mkdir -p /var/log/cassandra
  * sudo chown -R `whoami` /var/log/cassandra
  * sudo mkdir -p /var/lib/cassandra
  * sudo chown -R `whoami` /var/lib/cassandra

Note: The sample configuration files in conf/ determine the file-system 
locations Cassandra uses for logging and data storage. You are free to
change these to suit your own environment and adjust the path names
used here accordingly.

Now that we're ready, let's start it up!

  * bin/cassandra -f

Unix: Running the startup script with the -f argument will cause
Cassandra to remain in the foreground and log to standard out.

Windows: bin\cassandra.bat runs in the foreground by default.  To
install Cassandra as a Windows service, download Procrun from
http://commons.apache.org/daemon/procrun.html, set the PRUNSRV
environment variable to the full path of prunsrv (e.g.,
C:\procrun\prunsrv.exe), and run "bin\cassandra.bat install".
Similarly, "uninstall" will remove the service.

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 2.2.0 | Cassandra 1.2.0 | CQL spec 3.0.0 | Thrift protocol 19.35.0]
  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 SCHEMA 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://github.com/apache/cassandra/blob/trunk/doc/cql3/CQL.textile.  A
reasonable way to think of it is as, "SQL minus joins and subqueries."

Wondering where to go from here? 

  * Getting started: http://wiki.apache.org/cassandra/GettingStarted
  * Join us in #cassandra on irc.freenode.net and ask questions
  * Subscribe to the Users mailing list by sending a mail to
    user-subscribe@cassandra.apache.org
  * Planet Cassandra aggregates Cassandra articles and news:
    http://planetcassandra.org/