AWS ElastiCache with Redis Part – 2 (Flask application)
Introduction
- In our previous part, we have covered the basics of caching and ElastiCache. link- https://statusneo.com/aws-elasticache-with-redis-part-1/
- In this part, we will cover how to implement Redis in our Flask App.
- Just for convenience, we will host the Redis server on our local system, so that it can become on how to use Redis.
- For using ElastiCache we can simply log in to AWS ElastiCache and host a Redis server there.
Redis installation
- we can download Redis for here- https://redis.io/downloadhttps://redis.io/download
- Then we can open Redis in any editor say visual studio, it will look something like this-
data:image/s3,"s3://crabby-images/87b23/87b23cc6e63286030cc01fddf60f41d330efa22d" alt=""
- Now we will go to the src folder and run ./redis-server it will start the Redis server locally.
data:image/s3,"s3://crabby-images/8a6b1/8a6b172c6def9668ccedf1cea95847289573177e" alt=""
Implementing Caching on Flask Application
- Let’s create a small flask application, that hits an opensource API that fetches the covid data.
- The structure of our application looks like this-
data:image/s3,"s3://crabby-images/c7a5d/c7a5de46304a361c6ed55566c6d52f1bb9509e33" alt=""
- Let’s see the time taken by the API to fetch the data without caching.
data:image/s3,"s3://crabby-images/50b82/50b822abfab7242992e91082ed75edca2357742e" alt=""
- we can see that it’s around 845ms.
- Let’s now try to implement caching in it using the Redis server and flask caching.
- we will create a config file in our project source directory having the Redis database configuration.
data:image/s3,"s3://crabby-images/d7276/d72761482de28be16ee870fafdd1dfb92f7d300c" alt=""
- Now in our main file, we are going to add this configuration to our app and app caching to our API’s.
data:image/s3,"s3://crabby-images/c58a8/c58a892f4138ab3717d599843973a5c83d2cd8aa" alt=""
- timeout is in seconds that means how much time the data will be retained in our cache.
- Let us know try to hit the API with the latest changes.
data:image/s3,"s3://crabby-images/01ee6/01ee6d4786d25873e73b95f0a537230dd1e772d5" alt=""
- Now you can see that after the data has been cached after the first hit, it is taking only 10ms that is almost 83% less then its original time.
- This is how cache is implemented in flask application using Redis database.
References-
Still Curious? Visit my website to know more!
For more interesting Blogs Visit- Utkarsh Shukla Author
0 Comments
Add Comment
You must be logged in to post a comment.