Using the Java Driver to connect to a DataStax Astra 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 Astra database.
Include the driver artifacts in your pom.xml file according to this pom.xml dependency.
Initialize the Java Driver.
a. Create a ConnectDatabase.java file in the /src/main/java directory for your Java project.
$ cd javaProject/src/main/java
$ touch ConnectDatabase.java
b. Copy the following code for your DataStax Driver into the ConnectDatabase.java file.
The following example implements a ConnectDatabase class to connect to your Astra 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 Astra database (“/path/to/secure-connect-database_name.zip”) in the withCloudSecureConnectBundle() method as shown in the following example.
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.
In most circumstances, the client code for interacting with an Astra 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_QUORUM will be used as the default.