Redis as a Cache for Your FastAPI App
Introduction
In this tutorial, we’ll learn how to use Redis to add caching to a FastAPI application. By caching API responses in Redis, we can reduce database queries, improve response times, and ensure that frequently requested data is delivered quickly.
We’ll create a simple FastAPI app that fetches weather data from an external API. The app will store the results in Redis, so the next time someone requests the same data, it can be returned from the cache instead of making a new API request. Let’s get started!
Environment Setup
First, install FastAPI, the Upstash Redis client, and an ASGI server:
Database Setup
Create a Redis database using the Upstash Console or Upstash CLI, and export the UPSTASH_REDIS_REST_URL
and UPSTASH_REDIS_REST_TOKEN
to your environment:
We’ll also need to generate a WEATHER_API_KEY
from Weather API Website for free and we will export it.
You can also use python-dotenv
to load environment variables from your .env
file.
Application Setup
In this example, we will build an API that fetches weather data and caches it in Redis.
Create main.py
:
Running the Application
Run the FastAPI app with Uvicorn:
To test the application you can visit http://127.0.0.1:8000/weather/istanbul
in your browser or use curl to get the weather data for Istanbul. The first request will fetch the data from the weather API and cache it, and subsequent requests will return the cached data until the cache expires after 10 minutes.
To monitor your data in Redis, you can use the Upstash Console and check out the Data Browser tab.
Code Breakdown
-
Redis Setup: We use
Redis.from_env()
to initialize the Redis connection using the environment variables. Redis will store the weather data with city names as cache keys. -
Cache Lookup: When a request is made to the
/weather/{city}
endpoint, we check if the weather data is already cached by looking up theweather:{city}
key in Redis. If the data is found in cache, it’s returned immediately. -
Fetching External Data: If the data is not in cache, the app sends a request to the external weather API to fetch the latest data. The response is then cached using
redis.setex()
, which stores the data with a 10-minute expiration. -
Cache Expiration: We use a 10-minute TTL (time-to-live) for the cached weather data to ensure it’s periodically refreshed. After the TTL expires, the next request will fetch fresh data from the external API and store it in cache again.