1. Create an API using python
For python, there are many options available to create APIs, such as Flask, Falcon, Starlette, FastAPI etc.
We will be using FastApi in this article for three reasons:
- We can create an API end-point with minimal code
- It is incredibly fast and its speed is on par with NodeJS and Go
- It automatically creates both OpenAPI (Swagger) and ReDoc documentation
We here will serve our FastAPI server with Uvicorn.
Uvicorn is the ASGI server that allows for asynchronous processes compared to the more traditional WSGI servers. This will speed up the application and brings us closer to production-performance.
Before we start creating our first Python API, make sure that Python and pip are already installed on our development system.
First, we need to install both FastAPI and Uvicorn and to install both, execute below commands in the terminal
pip install fastapi pip install uvicorn
Now, create a file structure as shown below
data:image/s3,"s3://crabby-images/34c24/34c24034bd072b1ec22b95a49a8640b75a3d6643" alt=""
data:image/s3,"s3://crabby-images/dcb1f/dcb1fdd4c9e3dc8d3b400c27b508c3a55653dd6b" alt=""
Now in the terminal window, write below command
uvicorn main:app --reload
data:image/s3,"s3://crabby-images/e4db7/e4db7aad81233c4258f6f7ba6a2b973b942f52f9" alt=""
It will start our Fast API at the port 8000 by default.
After starting our FastAPI server, we can go to http://127.0.0.1:8000/docs to see the documentation of our server automatically generated. We can even press “try it” to see if the server works as intended.
data:image/s3,"s3://crabby-images/3608b/3608ba4cf5af14a54e7975bebe12e379f35482ae" alt=""
http://127.0.0.1:8000/redoc
data:image/s3,"s3://crabby-images/f8155/f815576ed2b2f63f285effd58d630c0a74bf5210" alt=""
data:image/s3,"s3://crabby-images/4f7ac/4f7ac266e9560930a5195f46f1ef18a12ca08e3f" alt=""
2. Deploy API using Docker
Now that we have an API to deploy we might want to containerize the application using Docker. Docker containerizes our app and all its dependencies to ensure it works seamlessly in any environment. This makes it easier to deploy your application across environments without much additional integration steps.
Start by making sure that we have Docker installed. Also specify a requirements.txt file for the application as shown below.
data:image/s3,"s3://crabby-images/f4138/f41387e3fe734cc82d805c05acaf669924dd8fbc" alt=""
Next is creating the Dockerfile, which is needed to run a containerized version of our API. Fortunately, the developers of FastAPI have created python images that allow for proper environments to run FastAPI.
Here is what a Dockerfile will look like
data:image/s3,"s3://crabby-images/d8f1f/d8f1f7213103fc436f89b1f7b76b41fb0f7d86b8" alt=""
docker build -t myimage ./ docker run -d --name mycontainer -p 80:80 myimageHere, the first command will create an image of our FastAPI, this will build and run the image that we have specified in the Dockerfile.The second command will use the image which we have just created and will create a container of it.Our API is now ready and can be accessed from http://127.0.0.1/docs .
3. Conclusion
In this comprehensive guide, we have gone through step by step creating an API and containerizing the application. We can now choose to host it locally or deploy the Docker via cloud solutions such as AWS or Azure.
We have tried to make this article as simple as possible, hence we have only included subjects that we thought are important. Some more advanced topics have been excluded such as:
- Securing the API
- Routing and POST, PUT endpoints
- Configuring the Gunicorn/uvicorn server
- How to compose a Docker file in detail
- Creating separate Dockerfiles for different stages
- Using Kubeflow with Kubernetes to simplify production