Connecting to Apollo (Cloud)
Using the DataStax Java Driver to connect to a DataStax Apollo database is almost identical to using
the driver to connect to any normal Apache Cassandra® database. The only differences are in how the
driver is configured in an application and that you will need to obtain a secure connect bundle.
The following is a Quick Start guide to writing a simple application that can connect to an Apollo database.
Prerequisites
- Download and install Maven.
- Create an Apollo database on GCP or AWS; alternatively, have a team member provide access to their Apollo database (instructions for GCP and AWS) to obtain database connection details.
- Download the secure connect bundle (instructions for GCP and AWS) to obtain connection credentials for your database.
- Ensure you are using Java 8 or higher. The cloud connect api does not support java 6 or 7.
Procedure
- Include the driver artifacts in your - pom.xmlfile according to this pom.xml dependency.
- 
Initialize the DataStax Java Driver. a. Create a ConnectDatabase.javafile in the/src/main/javadirectory for your Java project.$ cd javaProject/src/main/java$ touch ConnectDatabase.javab. Copy the following code for your DataStax Driver into the ConnectDatabase.javafile.
 The following example implements aConnectDatabaseclass to connect to your Apollo database, runs a CQL query, and prints the output to the console.Note: With the Cluster.builder()object, make sure to set the path to the secure connect bundle for your Apollo database (“/path/to/secure-connect-database_name.zip”) in thewithCloudSecureConnectBundle()method as shown in the following example.- 
DataStax Java Driver for Apache Cassandra 3.x import com.datastax.driver.core.Cluster; import com.datastax.driver.core.ResultSet; import com.datastax.driver.core.Row; import com.datastax.driver.core.Session; import java.io.File; public class ConnectDatabase { public static void main(String[] args) { // Create the Cluster object: Cluster cluster = null; try { cluster = Cluster.builder() // make sure you change the path to the secure connect bundle below .withCloudSecureConnectBundle(new File("/path/to/secure-connect-database_name.zip")) .withCredentials("user_name", "password") .build(); Session session = cluster.connect(); // Select the release_version from the system.local table: ResultSet rs = session.execute("select release_version from system.local"); Row row = rs.one(); //Print the results of the CQL query to the console: if (row != null) { System.out.println(row.getString("release_version")); } else { System.out.println("An error occurred."); } } finally { if (cluster != null) cluster.close(); } } }
 c. Save and close the ConnectDatabase.java file. 
- 
Apollo Differences
In most circumstances, the client code for interacting with an Apollo cluster will be the same as interacting with any other Cassandra cluster. The exceptions being:
- An SSL connection will be established automatically. Manual SSL configuration is not necessary. 
- A Cluster’s contact points attribute should not be used. The cloud config contains all of the necessary contact information (i.e. don’t use any of the - addContactPoint()or- addContactPoints()methods on the Builder)
- If a consistency level is not specified for an execution profile or query, then - ConsistencyLevel.LOCAL_QUORUMwill be used as the default.