After you determine your configuration options, you must set up your virtual machines (VMs) in AWS using a ThoughtSpot Amazon Machine Image (AMI).

Overview of ThoughtSpot setup in AWS

Follow these steps to set up your ThoughtSpot VMs in AWS.

1. Get access to ThoughtSpot’s AMI.
2. Choose a VM instance configuration recommended by ThoughtSpot.
3. Set up your Amazon S3 bucket (optional).
4. Set up your ThoughtSpot cluster in AWS.
5. Configure security groups.
6. Open the required network ports for communication for the nodes in your cluster and end users.
7. Prepare the VMs.

About the ThoughtSpot AMI

An Amazon Machine image (AMI) is a preconfigured template that provides the information required to launch an instance. You must specify an AMI when you launch an instance in AWS.

To make deployment easy, the ThoughtSpot AMI includes a custom ThoughtSpot image, with the following components:

  • A template for the root volume for the instance, such as an operating system, an appliance server, and applications.
  • Launch permissions that control which AWS accounts can use the AMI to launch instances.
  • A block device mapping that specifies the volumes to attach to the instance when it launches.

The ThoughtSpot AMI has specific applications on a CentOS-based image. The AMI includes the EBS volumes necessary to install ThoughtSpot in AWS. When you launch an EC2 instance from this image, it automatically sizes and provisions the EBS volumes. The base AMI includes 200 GB (xvda), 2X400 GB (xvdb), and SSD (gp2). It contains the maximum number of disks to handle a fully loaded VM.

RHEL AMI

This guide explains how to deploy ThoughtSpot on AWS, using ThoughtSpot’s CentOS-based image. You can also deploy ThoughtSpot on AWS using Red Hat Enterprise Linux (RHEL), allowing you to run ThoughtSpot on an RHEL 7.7 or 7.8 image that your organization manages internally. To install ThoughtSpot using RHEL, choose your own RHEL-based image on the AWS console, instead of ThoughtSpot’s image, and refer to the RHEL deployment guide after you launch your virtual machines.

Amazon Linux 2 AMI

This guide explains how to deploy ThoughtSpot on AWS, using ThoughtSpot’s CentOS-based image. You can also deploy ThoughtSpot on AWS using Amazon Linux 2, allowing you to run ThoughtSpot on an Amazon Linux 2 image that your organization manages internally. To install ThoughtSpot using Amazon Linux 2, choose your own Amazon Linux 2-based image on the AWS console, instead of ThoughtSpot’s image, and refer to the Amazon Linux 2 deployment guide after you launch your virtual machines.

Prerequisites

To install and launch ThoughtSpot, you must have the following:

Familiarity with Linux administration, and a general understanding of cloud deployment models.
The necessary AWS Identity and Access Management (IAM) users and roles assigned to you to access and deploy the various AWS resources and services as defined in the Required AWS components section that follows.
Networking information: Download and fill out the ThoughtSpot site survey to have a quick reference point. Ask your network administrator if you need help filling out the site survey.

For more information about IAM, see: What Is IAM? in Amazon’s AWS documentation.

Required AWS components

An AWS Virtual Private Cloud (VPC). An AWS VPC is a virtual network specifically for your AWS account. It exists in all availability zones in your region, but you can specify a local zone for even lower latency. For more details, see VPCs and Subnets in Amazon’s AWS documentation.
A ThoughtSpot AMI. For details, see Choose VM instances.
AWS security groups. For required open ports, see Network ports.
AWS VM instances. For instance type recommendations, see ThoughtSpot AWS instance types.
EBS volumes for data storage.
(Optional) If deploying with S3 persistent storage, you need one S3 bucket for each ThoughtSpot cluster.

Get access to ThoughtSpot AMI

  1. Sign in to your AWS account.
  2. Copy the correct ThoughtSpot public AMI to your AWS region. Refer to the chart below to find the AMI you should use, depending on your release number.

    Release Number AMI Name AMI ID Region
    6.2 thoughtspot-image-20200304-8b8c7b0e56a-prod ami-09079fee8bc0543fc N. California

Choose VM instances

  1. Choose the appropriate EC2 instance type: See ThoughtSpot AWS instance types for help choosing the correct instance type for your cluster.
  2. Networking requirements: 10 GbE network bandwidth is needed between the VMs. Ensure that you have this bandwidth.
  3. Ensure that all your VMs are on the same Amazon Virtual Private Cloud (VPC) and subnetwork. This is necessary because VMs that are part of a cluster need to be accessible by each other. Additional external access may be required to bring data in/out of the VMs to your network. Add all nodes in the same placement group.
  4. Determine the number of EC2 instances you need: Based on the datasets, this number will vary. Refer to ThoughtSpot AWS instance types for recommended nodes for a given data size.

Setting up your Amazon S3 bucket (recommended)

If you are going to deploy your cluster using the S3-storage option, you must set up that bucket before you set up your cluster. Contact ThoughtSpot Support to find out if your specific cluster size can benefit from the S3 storage option.

Follow these steps to set up an S3 bucket in AWS.

  1. On the AWS website, navigate to the S3 service dashboard by clicking Services, then S3.

  2. Make sure the selected region in the top-right corner of the dashboard is the same region in which you plan to set up your cluster.

  3. Click Create bucket.

  4. In the Name and region page, enter a name for your bucket.

  5. Select your region.

  6. Click Next.

  7. On the Properties page, click Next.

  8. On the Configure options page, ensure that Block all public access is selected.

  9. Click Next.

  10. On the Set permissions page, click Create bucket.

Encrypting your data at rest

ThoughtSpot makes use of EBS for the data volumes to store persistent data (in the EBS deployment model) and the boot volume (in the EBS and S3 deployment models). ThoughtSpot recommends that you encrypt your data volumes prior to setting up your ThoughtSpot cluster. If you are using the S3 persistent storage model, you can encrypt the S3 buckets using SSE-S3 or AWS KMS.

For more information on encryption supported with AWS:

Setting up your ThoughtSpot cluster

To set up a ThoughtSpot cluster in AWS, follow these steps:

  1. On the AWS website, navigate to the EC2 service dashboard by clicking Services, then EC2.

  2. Make sure your selected region is correct in the top-right corner of the dashboard. If not, select your region. Let ThoughtSpot support know if you change your region.

  3. Start the process of launching a VM by clicking Launch Instance.

  4. In the My AMIs tab under 1. Choose AMI, search ThoughtSpot to find the ThoughtSpot AMI.

  5. Click Select. Ensure that you select the ThoughtSpot AMI listed above, which you entered earlier in this process.

    Select the ThoughtSpot AMI

  6. On the Choose an Instance Type page, select a ThoughtSpot-supported instance type. (See ThoughtSpot AWS instance types.)

  7. Click Next: Configure Instance Details.

  8. Configure the instances by choosing the number of EC2 instances you need. The instances must be on the same VPC and subnetwork. ThoughtSpot sets up the instances to be in the same ThoughtSpot cluster.

    S3 storage setting: If you are going to use the S3 storage option, ThoughtSpot recommends that you restrict access to a specific S3 bucket. Create a new IAM role that provides read/write access to the specific bucket, and select it. For details on that, click Create new IAM role.

    AWS Systems Manager Agent: If you plan to use the AWS SSM agent as an alternative to SSH, create a new IAM role with an SSM policy to grant AWS SSM permission to perform actions on your instances. Refer to Create an IAM instance profile for Systems Manager.

  9. Click Next: Add Storage. Add the required storage based on your instance type (either EBS volumes or S3), and the amount of data you are deploying. For specific storage requirements, refer to ThoughtSpot AWS instance types.

    Add storage volumes

    1 Click Add new volume.
    2 Specify the type of storage, either EBS or S3.
    3 Specify the size of the volume.
    4 Ensure that you leave Delete on termination unchecked, to prevent potential loss of data if the VM is accidentally terminated.
  10. When you are done modifying the storage size, click Next: Add Tags.

  11. Set a name for tagging your instances. This tag allows you to identify your instance more easily.

Configure security groups

  1. Click Next: Configure Security Group.

  2. Select an existing security group to attach new security groups to so that it meets the security requirements for ThoughtSpot.

    Refer to Network ports.

  3. Click Review and Launch.

  4. After you have reviewed your instance launch details, click Launch.

  5. Choose a key pair. A key pair consists of a public and private key used to encrypt and decrypt login information. If you don’t have a key pair, you must create one. Without a key pair, you cannot SSH into the AWS instance later on.

  6. Click Launch Instances. Wait a few minutes for it to fully start up. After it starts, it appears on the EC2 console.

Prepare the VMs

Before installing a ThoughtSpot cluster, an administrator must prepare the VMs.

Additional resources

As you develop your expertise in AWS VM creation, we recommend the following ThoughtSpot U course:

See other training resources at
ThoughtSpot U