Get in Touch

Course Outline

  • Section 1: Introduction to Big Data and NoSQL
    • Overview of NoSQL
    • The CAP theorem
    • When NoSQL is the right choice
    • Columnar storage
    • The NoSQL ecosystem
  • Section 2: Cassandra Basics
    • Design and architecture
    • Cassandra nodes, clusters, and data centres
    • Keyspaces, tables, rows, and columns
    • Partitioning, replication, and tokens
    • Quorum and consistency levels
    • Labs: Interacting with Cassandra using CQLSH
  • Section 3: Data Modelling – Part 1
    • Introduction to CQL
    • CQL data types
    • Creating keyspaces and tables
    • Choosing columns and data types
    • Selecting primary keys
    • Data layout for rows and columns
    • Time to Live (TTL)
    • Querying with CQL
    • CQL updates
    • Collections (list, map, set)
    • Labs: Various data modelling exercises using CQL; experimenting with queries and supported data types
  • Section 4: Data Modelling – Part 2
    • Creating and using secondary indexes
    • Composite keys (partition keys and clustering keys)
    • Time series data
    • Best practices for time series data
    • Counters
    • Lightweight transactions (LWT)
    • Labs: Creating and using indexes; modelling time series data
  • Section 5: Data Modelling Labs: Group Design Session
    • Multiple use cases from various domains are presented
    • Students work in groups to develop designs and models
    • Discuss various designs and analyse decisions
    • Lab: Implement one of the scenarios
  • Section 6: Cassandra Drivers
    • Introduction to the Java driver
    • CRUD (Create, Read, Update, Delete) operations using the Java client
    • Asynchronous queries
    • Labs: Using the Java API for Cassandra
  • Section 7: Cassandra Internals
    • Understanding Cassandra design under the hood
    • SSTables, memtables, and commit logs
    • Read path and write path
    • Caching
    • Vnodes
  • Section 8: Administration
    • Hardware selection
    • Cassandra distributions
    • Installing Cassandra
    • Running benchmarks
    • Tools for monitoring performance and node activities
      • DataStax OpsCenter
    • Diagnosing Cassandra performance issues
    • Investigating a node crash
    • Understanding data repair, deletion, and replication
    • Other troubleshooting tools and tips
    • Cassandra best practices (compaction, garbage collection)
  • Section 9: Bonus Lab (time permitting)
    • Implement a music service similar to Pandora or Spotify on Cassandra

Requirements

  • Proficient in the Java programming language
  • Comfortable working in a Linux environment (navigating the command line, editing files with vi or nano)

Lab environment:

A fully functional Cassandra environment will be provided for students. Participants will need an SSH client and a web browser to access the cluster.

Zero Install: There is no need to install Cassandra on your machine!

 21 Hours

Number of participants


Price per participant

Testimonials (1)

Provisional Upcoming Courses (Require 5+ participants)

Related Categories