ScyllaDB University LIVE, FREE Virtual Training Event | March 21
Register for Free
ScyllaDB Documentation Logo Documentation
  • Server
  • Cloud
  • Tools
    • ScyllaDB Manager
    • ScyllaDB Monitoring Stack
    • ScyllaDB Operator
  • Drivers
    • CQL Drivers
    • DynamoDB Drivers
  • Resources
    • ScyllaDB University
    • Community Forum
    • Tutorials
Download
ScyllaDB Docs ScyllaDB Enterprise Getting Started Install ScyllaDB Enterprise Launch ScyllaDB on AWS

Caution

You're viewing documentation for a previous version. Switch to the latest stable version.

Launch ScyllaDB on AWS¶

This article will guide you through self-managed ScyllaDB Enterprise deployment on AWS. For a fully-managed deployment of ScyllaDB as-a-service, see ScyllaDB Cloud documentation.

Launching Instances from ScyllaDB AMI¶

  1. Choose your region, and click the Node link to open the EC2 instance creation wizard.

    The following table shows the latest patch release. See AWS Images for earlier releases.

    2024.2.11¶

    Region

    x86 AMI ID

    Launch x86

    ARM AMI ID

    Launch ARM

    Asia Pacific (Hyderabad)

    ami-09a2e0a230cdf8867

    Node / Cluster

    ami-094257f56bc5a1735

    Node / Cluster

    Africa (Cape Town)

    ami-0e2d1fb483efb1211

    Node / Cluster

    ami-09d597c0976174468

    Node / Cluster

    Asia Pacific (Mumbai)

    ami-0f5d3531f5f1d5401

    Node / Cluster

    ami-0aa851d6951631d9e

    Node / Cluster

    Europe (Stockholm)

    ami-040270bfaa2ddb1a6

    Node / Cluster

    ami-0026f967d14eb9955

    Node / Cluster

    Europe (Paris)

    ami-0f1b801fb78b02c32

    Node / Cluster

    ami-01ac6336f74521500

    Node / Cluster

    Europe (Milan)

    ami-0774d6fa78ffc7473

    Node / Cluster

    ami-0015be124515486f0

    Node / Cluster

    Europe (London)

    ami-00541e5c90cd77e36

    Node / Cluster

    ami-014cb349327ae1e94

    Node / Cluster

    Europe (Ireland)

    ami-099f196fca6d4f2ea

    Node / Cluster

    ami-003d540db518dbe1d

    Node / Cluster

    Asia Pacific (Osaka)

    ami-08bd441afd16a70e4

    Node / Cluster

    ami-0f69c8f9a5ea3421f

    Node / Cluster

    Asia Pacific (Seoul)

    ami-0a452b65bef326baa

    Node / Cluster

    ami-050c1dc75c1cbae0a

    Node / Cluster

    Middle East (Bahrain)

    ami-088d55b8dc5b97f14

    Node / Cluster

    ami-0c4991c87b8464b96

    Node / Cluster

    Asia Pacific (Tokyo)

    ami-0399c9cbea19dc72f

    Node / Cluster

    ami-0161021a495a0baaf

    Node / Cluster

    Israel (Tel Aviv)

    ami-0638626a02f06c610

    Node / Cluster

    ami-0da2cd4902f16d0fc

    Node / Cluster

    Canada (Central)

    ami-03173fde45c63ffa0

    Node / Cluster

    ami-09df1d1326ac8eef2

    Node / Cluster

    South America (Sao Paulo)

    ami-01db9d1e150c9e415

    Node / Cluster

    ami-07c6fdad861d258d9

    Node / Cluster

    Asia Pacific (Hong Kong)

    ami-0b4d7bef19f88a7b2

    Node / Cluster

    ami-0c1d7815c7fc0c324

    Node / Cluster

    Asia Pacific (Singapore)

    ami-0653d180cb6470cf8

    Node / Cluster

    ami-042e45a0b64358bd5

    Node / Cluster

    Asia Pacific (Sydney)

    ami-052c000bfaf8bd871

    Node / Cluster

    ami-0585f6c9c381966a0

    Node / Cluster

    Europe (Frankfurt)

    ami-085c0670aa6e506c3

    Node / Cluster

    ami-0c8ab958d004c0ed9

    Node / Cluster

    Asia Pacific (Jakarta)

    ami-03242f636d74b8b55

    Node / Cluster

    ami-0b7053c5bee6cf634

    Node / Cluster

    US East (N. Virginia)

    ami-06d3f70054194b951

    Node / Cluster

    ami-0ffc95542106e3611

    Node / Cluster

    US East (Ohio)

    ami-0b44a6d919b59b8b2

    Node / Cluster

    ami-07e83835ba39ce159

    Node / Cluster

    US West (N. California)

    ami-0189e19b79c855c43

    Node / Cluster

    ami-092e3576bdb55a4ea

    Node / Cluster

    US West (Oregon)

    ami-03e44e5d7b59e5bcc

    Node / Cluster

    ami-0b4126ad2807abb4e

    Node / Cluster

  2. Choose the instance type. See Cloud Instance Recommendations for AWS for the list of recommended instances.

    Other instance types will work, but with lesser performance. If you choose an instance type other than the recommended ones, make sure to run the scylla_setup script.

  3. Configure your instance details.

    • Number of instances – If you are launching more than one instance, make sure to correctly set the IP of the first instance with the seeds parameter - either in the User Data (see below) or after launch.

    • Network – Configure the network settings.

      • Select your VPC.

      • Configure the security group. Ensure that all ScyllaDB ports are open.

    • Advanced Details> User Data – Here, you can add ScyllaDB configuration options in the JSON format. See scylla.yaml for information about supported options.

      The following example shows a configuration using the most popular options.

      • cluster_name - The name of the cluster.

      • seed_provider - The IP of the first node. New nodes will use the IP of this seed node to connect to the cluster and learn the cluster topology and state. See ScyllaDB Seed Nodes.

      • post_configuration_script - A base64 encoded bash script that will be executed after the configuration is completed.

      • start_scylla_on_first_boot - Starts ScyllaDB once the configuration is completed.

      Example:

      {
           "scylla_yaml": {
               "cluster_name": "test-cluster",
               "seed_provider": [{"class_name": "org.apache.cassandra.locator.SimpleSeedProvider",
                                  "parameters": [{"seeds": "10.0.219.209"}]}],
           },
           "post_configuration_script": "#! /bin/bash\nyum install cloud-init-cfn",
           "start_scylla_on_first_boot": true
      }
      

      For full documentation of ScyllaDB AMI user data, see the ScyllaDB Image documentation.

  4. Add storage.

    • ScyllaDB AMI requires XFS to work. You must attach at least one drive for ScyllaDB to use as XFS for the data directory. When attaching more than one drive, the AMI setup will install RAID0 on all of them.

    • The ScyllaDB AMI requires at least two instance store volumes. The ScyllaDB data directory will be formatted with XFS when the instance first boots. ScyllaDB will fail to start if only one volume is configured.

  5. Tag your instance

  6. Configure Security Group. Make sure all ScyllaDB ports are open.

  7. Click Launch Cluster. You now have a running ScyllaDB cluster on EC2.

  8. Connect to the servers using the username scyllaadm.

    ssh -i your-key-pair.pem scyllaadm@ec2-public-ip
    

    The default file paths:

    • The scylla.yaml file: /etc/scylla/scylla.yaml

    • Data: /var/lib/scylla/

    To check that the ScyllaDB server is running, run:

    nodetool status
    

Next Steps¶

  • Configure ScyllaDB

  • Manage your clusters with ScyllaDB Manager

  • Monitor your cluster and data with ScyllaDB Monitoring

  • Get familiar with ScyllaDB’s command line reference guide.

  • Learn about ScyllaDB at ScyllaDB University

Was this page helpful?

PREVIOUS
ScyllaDB Developer Mode
NEXT
Launch ScyllaDB on GCP
  • Create an issue

On this page

  • Launch ScyllaDB on AWS
    • Launching Instances from ScyllaDB AMI
    • Next Steps
ScyllaDB Enterprise
  • 2024.2
    • 2024.2
    • 2024.1
    • 2023.1
    • 2022.2
  • Getting Started
    • Install ScyllaDB Enterprise
      • ScyllaDB Web Installer for Linux
      • Install ScyllaDB Without root Privileges
      • Air-gapped Server Installation
      • ScyllaDB Housekeeping and how to disable it
      • ScyllaDB Developer Mode
      • Launch ScyllaDB on AWS
      • Launch ScyllaDB on GCP
      • Launch ScyllaDB on Azure
    • Configure ScyllaDB
    • ScyllaDB Configuration Reference
    • ScyllaDB Requirements
      • System Requirements
      • OS Support by Linux Distributions and Version
      • Cloud Instance Recommendations
      • ScyllaDB in a Shared Environment
    • Migrate to ScyllaDB
      • Migration Process from Cassandra to Scylla
      • Scylla and Apache Cassandra Compatibility
      • Migration Tools Overview
    • Integration Solutions
      • Integrate Scylla with Spark
      • Integrate Scylla with KairosDB
      • Integrate ScyllaDB with Presto
      • Integrate Scylla with Elasticsearch
      • Integrate Scylla with Kubernetes
      • Integrate Scylla with the JanusGraph Graph Data System
      • Integrate Scylla with DataDog
      • Integrate Scylla with Kafka
      • Integrate Scylla with IOTA Chronicle
      • Integrate Scylla with Spring
      • Shard-Aware Kafka Connector for Scylla
      • Install Scylla with Ansible
      • Integrate Scylla with Databricks
      • Integrate Scylla with Jaeger Server
      • Integrate Scylla with MindsDB
    • Tutorials
  • ScyllaDB for Administrators
    • Administration Guide
    • Procedures
      • Cluster Management
      • Backup & Restore
      • Change Configuration
      • Maintenance
      • Best Practices
      • Benchmarking Scylla
      • Migrate from Cassandra to Scylla
      • Disable Housekeeping
    • Security
      • ScyllaDB Security Checklist
      • Enable Authentication
      • Enable and Disable Authentication Without Downtime
      • Creating a Custom Superuser
      • Generate a cqlshrc File
      • Reset Authenticator Password
      • Enable Authorization
      • Grant Authorization CQL Reference
      • Certificate-based Authentication
      • Role Based Access Control (RBAC)
      • ScyllaDB Auditing Guide
      • Encryption: Data in Transit Client to Node
      • Encryption: Data in Transit Node to Node
      • Generating a self-signed Certificate Chain Using openssl
      • Encryption at Rest
      • LDAP Authentication
      • LDAP Authorization (Role Management)
    • Admin Tools
      • Nodetool Reference
      • CQLSh
      • Admin REST API
      • Tracing
      • Scylla SStable
      • Scylla Types
      • SSTableLoader
      • cassandra-stress
      • SSTabledump
      • SSTableMetadata
      • Scylla Logs
      • Seastar Perftune
      • Virtual Tables
      • Reading mutation fragments
      • Maintenance socket
      • Maintenance mode
    • ScyllaDB Monitoring Stack
    • ScyllaDB Operator
    • ScyllaDB Manager
    • Upgrade Procedures
      • ScyllaDB Versioning
      • ScyllaDB Enterprise
      • ScyllaDB Open Source to ScyllaDB Enterprise
      • ScyllaDB Image
    • System Configuration
      • System Configuration Guide
      • scylla.yaml
      • ScyllaDB Snitches
    • Benchmarking ScyllaDB
    • ScyllaDB Diagnostic Tools
  • ScyllaDB for Developers
    • Develop with ScyllaDB
    • Tutorials and Example Projects
    • Learn to Use ScyllaDB
    • ScyllaDB Alternator
    • ScyllaDB Features
      • Lightweight Transactions
      • Global Secondary Indexes
      • Local Secondary Indexes
      • Materialized Views
      • Counters
      • Change Data Capture
      • Workload Attributes
      • Workload Prioritization
    • ScyllaDB Drivers
      • Scylla CQL Drivers
      • Scylla DynamoDB Drivers
  • CQL Reference
    • CQLSh: the CQL shell
    • Appendices
    • Compaction
    • Consistency Levels
    • Consistency Level Calculator
    • Data Definition
    • Data Manipulation
      • SELECT
      • INSERT
      • UPDATE
      • DELETE
      • BATCH
    • Data Types
    • Definitions
    • Global Secondary Indexes
    • Expiring Data with Time to Live (TTL)
    • Functions
    • Wasm support for user-defined functions
    • JSON Support
    • Materialized Views
    • Non-Reserved CQL Keywords
    • Reserved CQL Keywords
    • DESCRIBE SCHEMA
    • Service Levels
    • ScyllaDB CQL Extensions
  • ScyllaDB Architecture
    • Data Distribution with Tablets
    • ScyllaDB Ring Architecture
    • ScyllaDB Fault Tolerance
    • Consistency Level Console Demo
    • ScyllaDB Anti-Entropy
      • Scylla Hinted Handoff
      • Scylla Read Repair
      • Scylla Repair
    • SSTable
      • ScyllaDB SSTable - 2.x
      • ScyllaDB SSTable - 3.x
    • Compaction Strategies
    • Raft Consensus Algorithm in ScyllaDB
  • Troubleshooting ScyllaDB
    • Errors and Support
      • Report a Scylla problem
      • Error Messages
      • Change Log Level
    • ScyllaDB Startup
      • Ownership Problems
      • Scylla will not Start
      • Scylla Python Script broken
    • Upgrade
      • Inaccessible configuration files after ScyllaDB upgrade
    • Cluster and Node
      • Handling Node Failures
      • Failure to Add, Remove, or Replace a Node
      • Failed Decommission Problem
      • Cluster Timeouts
      • Node Joined With No Data
      • SocketTimeoutException
      • NullPointerException
      • Failed Schema Sync
    • Data Modeling
      • Scylla Large Partitions Table
      • Scylla Large Rows and Cells Table
      • Large Partitions Hunting
      • Failure to Update the Schema
    • Data Storage and SSTables
      • Space Utilization Increasing
      • Disk Space is not Reclaimed
      • SSTable Corruption Problem
      • Pointless Compactions
      • Limiting Compaction
    • CQL
      • Time Range Query Fails
      • COPY FROM Fails
      • CQL Connection Table
    • ScyllaDB Monitor and Manager
      • Manager and Monitoring integration
      • Manager lists healthy nodes as down
  • Knowledge Base
    • Upgrading from experimental CDC
    • Compaction
    • Consistency in ScyllaDB
    • Counting all rows in a table is slow
    • CQL Query Does Not Display Entire Result Set
    • When CQLSh query returns partial results with followed by “More”
    • Run Scylla and supporting services as a custom user:group
    • Customizing CPUSET
    • Decoding Stack Traces
    • Snapshots and Disk Utilization
    • DPDK mode
    • Debug your database with Flame Graphs
    • Efficient Tombstone Garbage Collection in ICS
    • How to Change gc_grace_seconds for a Table
    • Gossip in Scylla
    • Increase Permission Cache to Avoid Non-paged Queries
    • How does Scylla LWT Differ from Apache Cassandra ?
    • Map CPUs to Scylla Shards
    • Scylla Memory Usage
    • NTP Configuration for Scylla
    • Updating the Mode in perftune.yaml After a ScyllaDB Upgrade
    • POSIX networking for Scylla
    • Scylla consistency quiz for administrators
    • Recreate RAID devices
    • How to Safely Increase the Replication Factor
    • Scylla and Spark integration
    • Increase Scylla resource limits over systemd
    • Scylla Seed Nodes
    • How to Set up a Swap Space
    • Scylla Snapshots
    • Scylla payload sent duplicated static columns
    • Stopping a local repair
    • System Limits
    • How to flush old tombstones from a table
    • Time to Live (TTL) and Compaction
    • Scylla Nodes are Unresponsive
    • Update a Primary Key
    • Using the perf utility with Scylla
    • Configure Scylla Networking with Multiple NIC/IP Combinations
  • Reference
    • AWS Images
    • Azure Images
    • GCP Images
    • Configuration Parameters
    • Glossary
    • Limits
    • ScyllaDB Enterprise vs. Open Source Matrix
    • API Reference (BETA)
    • Metrics (BETA)
  • ScyllaDB University
  • ScyllaDB FAQ
  • Contribute to ScyllaDB
  • Alternator: DynamoDB API in Scylla
    • Getting Started With ScyllaDB Alternator
    • ScyllaDB Alternator for DynamoDB users
    • Alternator-specific APIs
Docs Tutorials University Contact Us About Us
© 2025, ScyllaDB. All rights reserved. | Terms of Service | Privacy Policy | ScyllaDB, and ScyllaDB Cloud, are registered trademarks of ScyllaDB, Inc.
Last updated on 20 Jun 2025.
Powered by Sphinx 7.4.7 & ScyllaDB Theme 1.8.6