StudentShare
Contact Us
Sign In / Sign Up for FREE
Search
Go to advanced search...
Free

Cassandra Database - Case Study Example

Cite this document
Summary
The paper "Cassandra Database" discusses the database's data storage, query format, and query processing. The database automatically divides the data across nodes found in the cluster of databases. After Facebook decided to open source the code, Cassandra became an incubator for Apache…
Download full paper File format: .doc, available for editing
GRAB THE BEST PAPER98.7% of users find it useful
Cassandra Database
Read Text Preview

Extract of sample "Cassandra Database"

Cassandra Database al Affiliation) Cassandra database is an open source system designed to store and manages large quantities of data across the entire commodity servers. The database serves as a real-time data store for applications that are online and read intensive database for Business Intelligence systems. The database was originally developed for Facebook and designed to accommodate peer-to-peer symmetric nodes. The database automatically divides the data across nodes found in cluster of database. After Facebook decided to open source the code, Cassandra later became an incubator for Apache. As of this writing, the paper will discuss the general information about Cassandra database. Consequently, the paper will further discuss the database based on its data storage, query format, and its query processing General Information about Cassandra Database Definition Cassandra Database is a wide spread open source NoSQL database. The database is best used to manage large quantity of data across many centers of data and cloud. Cassandra database is characterized as a continuous availability, operational simplicity, and linear scalability across various servers without a single failure. Additionally, the database has a powerful data model mandated to offer a maximum flexibility and a rapid response period. Based on its operation, Cassandra database has an outstanding plan and architecture, meaning that all the nodes are similar. Increasingly, the database offers automatic distribution of data across the nodes participating in a database cluster. Importance The database saves the administrators and developers the coding process in distrusting the data across the cluster since the data are partitioned in a transparent manner across the nodes. Consequently, the database provides a customized replication that stores redundant data across nodes participating the Cassandra ring. Meaning, assuming a node goes down, single, or multiple copies of the data will still be available on other cluster’s machines. Replication undergoes configuration to operate across zones of a single data center, multiple data centers, and many cloud zones. The database can be used in supplying linear scalability, meaning that a capacity can added easily through the addition of new nodes. For instance, two nodes can accommodate 100000 operations in a second, four nodes can accommodate 200000 operations in a second, and eight nodes can handle 400000 operations in a second. Latest Version The latest version of the database is Cassandra 2.1. The new version has new features such as user-defined types, collection indexes, and improved metrics through metrics-core library. The new version has performance improvements based on the improved row cache, faster reads and writes, reduced heap, and new counters implementation. Additionally, the repair and compaction improvement include incremental node repair, and post-compaction read performance. Other notable changes on the database include unique table IDs, Bundled JNA, Improved logging, and new configurations. Cassandra Query Language Increasingly, the primary and default interface of the database is Cassandra Query Language. Using CQL is same as using SQL. The two programming language share a similar abstract idea of tables constructed of rows. Compared to SQL, Cassandra do not support sub queries or joins rather than batch analysis via Hive. Conversely, the database focusses on denormalization through Cassandra Query Language features such as clustering and collection specified at schema. Cassandra Query Language is the preferred way of interacting with the database. Features of the Database system Data Storage Storage Engine Cassandra database uses data storage similar to Log Structured Merge Tree. The database different to conventional relational database, it writes then reads it later. Normally, in systems that are largely distributed, they produce stalls during reading performance and other issues. To avoid this read before write scenario, the engine groups, updates and inserts to be carried, and consequently writes the updates sections of rows in append mode. The database rewrite or reread the existing data, and do not overwrite rows found in place. Separate table directories Cassandra database offers a fine-grained control of disk’s table storage, writing tables on the disk with help of separate directories for every table. From the directory of installation, the data file are then stored with the help of the directories and the file naming technique on tarball installations as shown below /data/data/ks1/cf1-5be396077b811e3a3ab9dc4b9ac088d/ks1-cf1-hc-1-Data.db For installations that are packaged, the data files are kept and stored in similar format by in a default technique of /var/lib/Cassandra/data. Cassandra database develops a subdirectory for every table, which allows one to symlink tables to a given data volume or physical drive. This offers a capability to shift active table to a media that is faster like SSD. Compaction write path Cassandra database processes data are various phases on the path, beginning with immediate compaction logging write and ending: The database intervals include logging data, writing data, flushing data, storing data, and compaction. When writing occurs, the database stores the written in memtable. In addition, it appends write to the disk’s commit log offering a configurable durability. The write are then received by commit log made to the node of the database. The memtable will then store the writes until a limit is reached and then flushed. When the content of a memtable exceed the configurable threshold, the data is then placed in queue for flushing. The queue length can be configured by altering the memtable_flush_queue_size found in Cassandra.yaml. If the flushed data exceeds the size of queue, the database then blocks the writes until succession of the next flush occurs. Flushing of data involves sorting the memtable by token and then writes the data on the disk sequentially. To store the data on disk, the data found in commit log undergoes purging after the corresponding data found in the memtable is taken to SSTable. As shown in the figure below. The SSTable and Memtable are then maintained on each table. The SSTable are not mutable. Later, the division is stored across the various SSTable file. For every SSTable, the database creates partition index structure, partition summary, and Bloom filter. From the diagram below, in the memtable, the data are organized and store in sorted order. For effectiveness and efficiency, Cassandra does not repeat column names in memory. For instance, the following writes will be arranged as Write (k1, c1:v1) Write (K2, c1:v1 C2:v2) Write (k1, c1:v4 c3:v3 c2:v2) The Cassandra database then stores the data after the writes are received k1 c1:v4 c2:v2 c3:v3 k2 c1:v1 c2:v2 In the disk’s commit log, Cassandra then stores the store after the writes are already received k1, c1:v1 k2, c1:v1 C2:v2 k1, c1:v4 c3:v3 c2:v2 In the disk’s SSTable, Cassandra then stores the data after the memtable is flushed k1 c1:v4 c2:v2 c3:v3 k2 c1:v1 c2:v2 Query format The data model of Cassandra is a divided row store having tunable consistency. The rows are organized in form of tables. The first feature of the tables’ primary key is a partition key, within the partition; the rows are grouped by remaining columns of keys. Other columns of the table are indexed separately from the partition key. Tables can be altered, dropped, and created at runtime without blocking the queries and updates. A compound primary key entails a partition key. The partition key determines the kind of node that will store the data. These keys include single or multiple additional columns that finds out the per-partition clustering. The database utilized the first column slot in the primary key definition as a partition key. For instance in a music playlist table, the music id is termed as partition key. The remaining columns are the clustering columns. The partition data are clustered by the clustering column. Conventionally, when the partition key’s rows are stored based on clustering columns format, retrieving the row will become inefficient. For instance, since the name in the playlist table is termed as the partition key, every song in the playlist will be clustered based on clustering column format. Deleting, inserting, and updating the operations on rows share a similar partition key for tables are carried out atomically and in isolation. One is able to query one sequential data set on a disk to find the songs for a given playlist. In Cassandra database, one can find collections that contain a given value. For instance, supposing one wants to find songs tagged in a given color, the venue map and tags set need to be indexed. Querying for values found in the venue map and tags set is as shown below CREATE INDEX ON playlists (tags); CREATE INDEX mymapvalues ON playlists (venue); Specifying an index name like mapindex is optional. To filter the kind of data in the collection, when the tags set is selected, the set of tags will be returned; SELECT album, tags FROM playlists; Internally, the query do not change the mapping of row and column from the mapping of Thrift API. Thrift and CQL uses a similar storage engine. It supports similar query-driven, principles of denormalized data modeling as shift. The existing application does not need to undergo upgrade to CQL. The abstraction layer of CQL makes the query easier for new applications. Query Processing Using Cassandra Query Language, one can easily query legacy table. The legacy table managed in Cassandra Query Language entails an implicit directive of WITH COMPACT STORAGE. When using the Cassandra Query Language without column names defined for the data within the partition, the database generates the first column and first value for the data. With the help of RENAME clause, one can change the name of default column to a meaningful id as ALTER TABLE users RENAME userid to user_id; The query support the dynamic table developed in CLI, Thrift API, and earlier versions of CQL. For instance, the dynamic table is queried as Cassandra Query Language offers an API to Cassandra simpler than Thrift for newer application. The query adds the abstraction layer hiding the implementation details of the structure and offers native syntaxes for collections and other conventional encodings. Accessing Query Conventional ways of accessing CQL include starting the cqlsh. Cqlsh is the python based command line client found in Cassandra node command line. Then use the DataStax DevCenter, which acts as graphical user interface. To develop an application, one can use python, java, or other open source drivers. Finally, use set cql version for the programmatic access. Updating and creating a keyspace Creating a keyspace defines the replication of data on nodes. Normally, a cluster has a single key space for every application. Replication process is controlled on keyspace to keyspace basis, therefore data with different replication needs resides in various keyspaces. The keyspaces are not developed to be used as crucial map layer within the model. The keyspaces are developed to control the replication of data for a collection of tables. When a key space is created, a strategy class will be classified to replicate the keyspaces. A SimpleStrategy class is used in evaluating the Cassandra. Using the NetworkTopologyStrategy for purposes of evaluation, a single node cluster will specify the center name of the default data, this is made possible by using the nodetool status command. Replication Factor To increase the replication factor leads to an increase in the total number of copies for the data stored in Cassandra cluster. It is good to increase the system’s replication factor if one uses the security features since when one used the default and the node, they will not log into the cluster since the system_auth did not replicate. The procedure for this includes updating the cluster’s keyspace and change the options of replication strategy using the ALTER KEYSPACE system_auth WITH REPLICATION = {class : NetworkTopologyStrategy, dc1 : 3, dc2 : 2}; then on the affected node, run the command of nodetool repair. Then one has to wait until the repair is completed on the node, then shift to the next. Then creating a table with single primary key, one has to use the PRIMARY KEY, then key name, enclosed in the parenthesis. Read More
Cite this document
  • APA
  • MLA
  • CHICAGO
(“Cassandra Database Research Paper Example | Topics and Well Written Essays - 2000 words - 1”, n.d.)
Cassandra Database Research Paper Example | Topics and Well Written Essays - 2000 words - 1. Retrieved from https://studentshare.org/information-technology/1659568-cassandra-database
(Cassandra Database Research Paper Example | Topics and Well Written Essays - 2000 Words - 1)
Cassandra Database Research Paper Example | Topics and Well Written Essays - 2000 Words - 1. https://studentshare.org/information-technology/1659568-cassandra-database.
“Cassandra Database Research Paper Example | Topics and Well Written Essays - 2000 Words - 1”, n.d. https://studentshare.org/information-technology/1659568-cassandra-database.
  • Cited: 0 times

CHECK THESE SAMPLES OF Cassandra Database

What Is a Computer Software

One has to understand first the meaning of the term "computer software".... It is clear that computers have two different elements in their operation - the machines and the language for the operation of the machines.... The operations of the two are different and the same machine can be operated in more than one language, or used for a number of different purposes....
6 Pages (1500 words) Essay

Information Retrieval through Multi-Agent System

It is “the analysis step in the Knowledge Discovery and Databases process” (Nodine, Ngu, cassandra and Bohrer, 2003).... This paper ''Information Retrieval through Multi-Agent System'' tells that Problem-solving solutions like Multi-Agent System (MAS) capitalizes on its multiple intelligent agents to receive precepts from the environment, process the information, and produce the desired result for the environment....
6 Pages (1500 words) Research Paper

Data Management in Cloud Environments

However, the most vital component which forms the basis of such operations but is often overlooked is the database management system in the cloud environment.... RDBMS or traditional database management system which was designed in the earlier times possessed different hardware, processing, and storage requirements in comparison to the requirements for DBMS in the present scenario....
10 Pages (2500 words) Research Paper

Data Structures and Algorithm Applications in Social Media

In social media, the information is stored in a large database; hence, computations that result in the searching of different information need to be performed at a very fast rate.... This essay "Data Structures and Algorithm Applications in Social Media" discusses how the choice of data structures and algorithms affect social media....
7 Pages (1750 words) Essay

Using Social Media To Help With The Job Hunt

The primary objective of this review was to investigate how social media has influenced job search.... This analysis was carried out through using secondary data, print books on job hunting, job adverts on company websites and articles from the Seneca databases.... hellip; According to recent reports, it is believed that several companies do a background check of the new staff they would like to higher....
6 Pages (1500 words) Literature review

Edible Arrangements

Customs and Border Protection E-Recordation Tool is one tool that facilitates the businesses with a platform for recording their copyright and trademark in an online database (Mitchell 22).... This work called "Edible Arrangements" describes the vast and highly competitive franchising industry of Edible Arrangements International....
6 Pages (1500 words) Essay

Harnessing Information Management, Data, and Infrastructure in Walmart

The paper "Harnessing Information Management, Data, and Infrastructure in Walmart" concerns the impact of enterprise architecture on information management in Wal-Mart, the impact of IT structure on the effectiveness of information management, data storage space methods of Wal-Mart's database....
5 Pages (1250 words) Case Study

Personality Disorder According DSM-IV Cluster

… The paper "Mental Health: cassandra's Behaviour" is a good example of n assignment on nursing.... nbsp;cassandra's behaviour can be diagnosed borderline personality disorder as thus According to the American Psychiatric Association (APA) Dictionary of Psychology, the DSM-IV, borderline personality disorder.... The paper "Mental Health: cassandra's Behaviour" is a good example of n assignment on nursing.... Answer 1 Personality Disorder According to DSM-IV cluster cassandra's behaviour can be diagnosed borderline personality disorder as thus According to the American Psychiatric Association (APA) Dictionary of Psychology, the DSM-IV, borderline personality disorder, which falls under Axis II, Cluster II, is characterized by A long-standing pattern of instability in mood, interpersonal relationships, and self-image that is severe enough to cause extreme distress or interfere with social and occupational functioning....
7 Pages (1750 words) Assignment
sponsored ads
We use cookies to create the best experience for you. Keep on browsing if you are OK with that, or find out how to manage cookies.
Contact Us