Use Astra Database to store a large-scale processed data.
This integration guide explores the combination of AstraDB, a distributed database, with Apache Flink, a powerful stream and batch processing framework. By integrating these technologies, organizations can seamlessly leverage AstraDB's scalability, fault-tolerance, and cloud-native features for efficient data storage and retrieval, while harnessing the capabilities of Apache Flink for both real-time streaming and batch processing of large-scale data.
In this demo, we will be collecting some stock market data from the https://www.alphavantage.co/ API as a batch data and use pyFlink the python package of Flink to collect the data, run some processing on it and store it afterwards into our Astra database. We will explore the RESTApi option of Astra this time in order to accomplish the DB insertion task.
To get started, you need to get the code onto your machine. So Start by cloning this GitHub repository. If you have git installed, you can do this by running the following command in your terminal:
git clone git@github.com:Anant/flink-astra-stock-price.git
This will create a copy of the repository on your local machine. Once you have cloned the repository, navigate into the directory:
cd flink-astra-stock-price
To install the required packages for this plugin, run the following command:
pip install -r requirements.txt
Go to https://www.alphavantage.co/ and click the Get Free API KEY. Once done store that in the my_local_secrets.py file in the field:
api_key=<your-alphavantage-api-key>
In order to run the examples from this repo, you will need to set up a database and create a keyspace. The details of how to do this should be found under the following link https://docs.datastax.com/en/astra-serverless/docs/manage/db/manage-create.html .
Once you've got the database up and running and the keyspace created, make sure you download the bundle as described in the link above and get the keys needed to access your database. Now open the my_local_secrets.py file and make sure you fill in the details
client_id="<your-client_id>"
client_secret="<your-client_secret>"
token="<your-token>"
db_keyspace="<your-keyspace>"
secure_bundle_path="<path-to-bundle>/secure-connect-<YOUR_DB_NAME>.zip"
astra_id="<astra-id>"
astra_region="<astra-region>"
api_key="<your-alphavantage-api-key>"
One important tool we will use here for an interactive coding is jupyter lab, or jupyter notebooks as well.
Jupyter lab in particular has more advanced functionalities than traditional notebooks. So if you don't have jupyter locally feel free to install the labs feature using the following command.
pip install jupterlab
After installing the jupyterlab, go to the terminal, inside your working directory (or the directory you cloned as per the instructions above) and run the following command:
jupyterlab
This should redirect you to the browser automatically, if not you should be able to see the instructions on how to navigate to the jupyter env on the terminal itself.
Now you can start running the steps from the notebook (executing the cells in order), to run the code that populates and extracts data from your AstraDB tables. The description of this can be found in the following link .
Note
For this example the version of python used is: 3.10.11
As for the data, you will find a sample data under the data folder in this repository but feel free to use any dataset with the same schema.
For detailed information and code examples, refer to the following resources:
AstraDB Documentation: https://docs.datastax.com/en/astra/docs/
Apache Flink Documentation: https://flink.apache.org/