50 minutes, Intermediate, Start Building
This sample Python backend provides a REST API service that is used with the Getting Started with Astra UI to show a simple example of how to connect to and query DataStax Astra DBs.
- How to connect to DataStax Astra DB using the secure connect bundle
- How to share a DataStax Driver Session throughout a Python application
- How to expose a basic REST API using the DataStax Driver
This project is built in Python and uses Flask to expose a REST API backend for use with the Getting Started with Astra UI.
This application is the middle man that receives requests from the UI web page and serves data from the underlying DataStax Astra DB.
To build and play with this app, follow the build instructions that are located here: https://github.com/DataStax-Examples/getting-started-with-astra-python
Let's do some initial setup by creating a serverless(!) database.
-
Create a DataStax Astra account if you don't already have one:
-
Define a database name, keyspace name and select a database region, then click create database.
-
Your Astra DB will be ready when the status will change from
Pending
toActive
💥💥💥 -
After your database is provisioned, we need to generate an Application Token for our App. Go to the
Settings
tab in the database home screen. -
Select
Admin User
for the role for this Sample App and then generate the token. Download the CSV so that we can use the credentials we need later. -
After you have your Application Token, head to the database connect screen and select the driver connection that we need. Go ahead and download the
Secure Bundle
for the driver. -
Make note of where to use the
Client Id
andClient Secret
that is part of the Application Token that we generated earlier.
-
Click
Use this template
at the top of the GitHub Repository: -
Enter a repository name and click 'Create repository from template':
Make sure you've completed the prerequisites before starting this step
If you are familiar with Python, then you've likely gotten your hands on Python virtual environments. We'll be leveraging pyenv while setting up this backend, which will serve our Spacecraft frontend that will have you flying through the stars.
If you aren't familiar with Python, hop over to our official documentation for setting that up on your machine, and come back here after you have it installed ( specifically after Step 5 of the Procedure ).
Now that we have that out of the way, we'll use pyenv to install Python 3.6.9
pyenv install 3.6.9
Next create a new virtualenv using that Python version we just installed.
pyenv virtualenv 3.6.9 astra-venv
Almost off to the races, go ahead and activate that virtualenv
pyenv activate astra-venv
Woot, now 3 quick dependencies ( Flask, Flask CORS, and the DataStax Cassandra Driver )
pip install Flask flask-cors cassandra-driver
Last one, clone this repo
git clone https://github.com/DataStax-Examples
/getting-started-with-astra-python.git
If everything above went smoothly, fingers crossed, then we are ready to rock. Go to the directory that you just cloned this repo into
cd getting-started-with-astra-python
Fire up the engines
FLASK_ENV=development FLASK_APP=getting_started_with_astra.py flask run
You should be met with the following output, note that it's running on localhost
and port 5000
* Serving Flask app "getting_started_with_astra.py" (lazy loading)
* Environment: development
* Debug mode: on
* Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
* Restarting with stat
* Debugger is active!
* Debugger PIN: 204-527-831
Once the backend is running, you can start the Getting Started with Astra UI in order to use a web page that leverages this backend.