Overview and Workflow of the Project
The Serverless Movies API is a capstone project that showcases a serverless architecture to provide movie information through various API endpoints. Using cloud-based resources like a NoSQL database, cloud storage, and serverless functions, this project delivers movie data, including details, cover images, and AI-generated summaries.
This API includes the following serverless functions:
- GetMovies: Fetches a list of all movies, including their details and cover image URLs.
- GetMoviesByYear: Retrieves a list of movies based on a specified release year.
- GetMovieSummary: Provides an AI-generated summary for a specific movie.
-
Set up your SDK: Use the SDK of your cloud provider (e.g., AWS SDK, Azure SDK, Google Cloud SDK) to configure your infrastructure.
-
NoSQL Database: Create a NoSQL database (e.g., Cosmos DB on Azure, DynamoDB on AWS, or Firestore on Google Cloud).
-
Cloud Storage: Set up cloud storage (e.g., Azure Blob Storage, Amazon S3, or Google Cloud Storage) for storing movie cover images.
-
Serverless Functions: Configure serverless functions for each endpoint:
- GetMovies
- GetMoviesByYear
- GetMovieSummary (For AI summaries)
Note: Check for additional setup steps based on your cloud provider, such as configuring permissions, setting up API Gateway, or obtaining necessary keys.
- Movie Data: Gather or create a dataset of movies with relevant information, such as title, release year, genre, etc.
- Cover Images: Upload movie cover images to your cloud storage. Ensure each movie has a unique URL for its cover image.
Each serverless function is created to handle a specific request for movie information:
-
GetMovies
- Description: Retrieves a JSON list of all movies stored in the NoSQL database.
- Response: Includes details such as title, genre, release year, and a cover image URL for each movie.
-
GetMoviesByYear
- Description: Fetches a list of movies released in a specified year.
- Parameters:
year
(query parameter): Specifies the release year of the movies.
- Response: Returns a JSON list of movies that match the specified year.
-
GetMovieSummary
- Description: Returns an AI-generated summary for a specified movie.
- Parameters:
title
(query parameter): Specifies the title of the movie for which the summary is requested.
- Response: A summary generated using AI for the requested movie title.
-
Clone the Repository:
git clone https://github.com/your-username/serverless-movies-api.git cd serverless-movies-api
-
Install SDK dependencies based on the cloud provider.
-
Deploy Cloud Resources: Use your SDK or cloud console to deploy the NoSQL database, storage, and serverless functions.
Once deployed, the API provides the following endpoints:
- GetMovies: GET /movies
- GetMoviesByYear: GET /movies?year={year}
- GetMovieSummary: GET /movie-summary?title={title}
Replace {year} and {title} with the specific year or title for your query.
------------------------------------------------------------------------------------------------------------------------------
Python: Make sure you have Python 3.8 or 3.9 installed.
python -m venv ./<your-venv>
Local Development: Set up your Python environment locally, installing necessary packages (azure-functions, azure-cosmos, azure-storage-blob).
Azure Functions Core Tools: For local function development.
npm install -g azure-functions-core-tools@3 --unsafe-perm true
Note: Before creating any resource in Azure, always create the resource group for the project. It helps in organizing all the resources required for the project.
az login
You can do it through Azure CLI or Azure portal.
az group create --name <ResourceGroupName> --location <Location>
In your Serverless Movies API project, the storage account (specifically, Blob Storage within it) is used to store movie cover images. These image URLs are then saved in your Cosmos DB and referenced in the API responses, allowing clients to access and display the cover images.
- Search for Storage Accounts in Azure portal: In the search bar at the top, type "Storage Accounts" and select it.
- Click 'Create': Select "Create" to start setting up a new storage account.
- Choose Subscription and Resource Group: Select the current subscription and the above created resource group.
- Provide a Storage Account Name: This must be unique across Azure and use only lowercase letters and numbers.
- Choose Region: Select the region closest to your users for optimized latency.
- Select Performance and Redundancy: Choose the performance tier (Standard or Premium) and redundancy option.
- Review and Create: Click "Review + Create" to verify settings, then "Create" to deploy the storage account.
Note - Choose the same location for Storage account, CosmosDB account and Functions app.
Azure Function App: Create an Azure Function App in the Azure Portal (or using Azure CLI) to host your serverless functions.
- Search for Function App from Azure portal: Type "Function App" in the search bar and select it.
- Click 'Create': Start the process of creating a new Function App.
- Select Subscription and Resource Group: Choose the above created resource group.
- Enter Function App Name: Provide a globally unique name for the Function App.
- Choose Runtime Stack: Select the runtime stack (e.g., Python, Node.js) and the version.
- Select Region: Choose a region where the Function App will be hosted.
- Choose Hosting Plan: Under "Hosting Plan," select "Consumption (Serverless)" for pay-per-execution billing.
- Configure Storage: Select the above created storage account where all the images of the movie coverpages is stored.
- Review and Create: Review the settings, then click "Create" to deploy the Function App. This setup allows your function to scale automatically and minimizes costs, as you’re only billed for the actual execution time.
While creating function-app, select Consumption plan for this project. In the storage section, select the storage account you created earlier. It is recommended to create all the resources in the same region to avoid some trouble later. In Monitoring sections, enable Application Insights, select yes.
- Search for Cosmos DB in Azure portal: In the search bar, type "Azure Cosmos DB" and select it.
- Click 'Create': Start creating a new Cosmos DB account.
- Choose API: Select Azure Cosmos DB for NoSQL for this project.
- Enter Resource Group: Choose the above created resource group.
- Enter Account Name: Provide a unique name for the Cosmos DB account.
- Select Region: Choose the same region for the database as chosen for functions-app and storage-account.
- Configure Capacity Mode: Choose "Provisioned throughput" based on your needs.
- Review and Create: Review your settings and click "Create" to deploy the Cosmos DB account.
After the account is created, you can add databases and containers to store your data. Cosmos DB is used in this project for efficient storage and retrieval of movie data for the Movies API.
Note: Store your Cosmos DB connection string and Blob Storage connection string in environment variables for secure access.
While displaying the serverless function output , we have to include the coverpage URLs of the movies. We have to store the images in blob storage in storage account to get the URL for CosmosDB.
Upload it from local directory to Container on Storage Account.
Implement API calls to the OMDB API to fetch movie details. Store the relevant data in your Azure Cosmos DB.
After uploading the images on blob, you can access the URLs. You can manually add data to cosmosdb or add via code and deploy the data on CosmosDB. I used code for deployment. You can access my code uploaded in the repository.
- Set Up Local Development Environment
mkdir MoviesApi
cd MoviesApi
func init --python
-
Ensure, you have already installed required libraries. Else, you can install the Azure SDKs for Function app Cosmos DB and Blob Storage with the below command.
pip install azure-functions azure-cosmos azure-storage-blob
-
Create Individual Functions: For each API endpoint, create an HTTP-triggered function
func new
Choose the HTTP trigger template and name your functions:
- GetMovies
- GetMoviesByYear
- GetMovieSummary
After running the command 'func new', select the HTTP Trigger, then enter the name of the Function
Once, you do the above for all the functions, it means you have created HTTP Trigger for the function.
An HTTP trigger in Azure Functions is a type of trigger that allows your serverless function to be invoked via an HTTP request. When you set up an HTTP-triggered function, it becomes accessible through an endpoint URL, allowing you to interact with it directly over the web using standard HTTP methods like GET, POST, PUT, and DELETE. This makes it ideal for building RESTful APIs or webhooks.
Now, implement the function logic for each function. The function_app.py is included in the repository. After appending the function logic to the file. Run the below command to test the function locally.
func start
The below image shows that once, you access your functions at http://localhost:7071/api/ to confirm they’re correctly recognized as HTTP triggers locally. The terminal keeps track of the log.
After testing locally, you can now deploy it on the Azure functions-app service with the below command
The below images confirms that the functions are deployed on Azure
To access your functions via Azure, you have to access your function which will be added at the end. Since, we have set the AuthLevel to Function.
Therefore, this completes the API logic for each function in your Serverless Movies API
I faced some issues, and the below solutions worked for me.