AWS is a well-liked cloud supplier that permits the deployment and scaling of enormous purposes. Mastering no less than one cloud platform is a vital ability for software program engineers and knowledge scientists. Operating an software regionally isn’t sufficient to make it usable in manufacturing — it have to be deployed on a server to change into accessible to finish customers.
On this tutorial, we’ll stroll by means of an instance of deploying a FastAPI software. Whereas the instance focuses on core EC2 networking ideas, the rules are broadly relevant to different kinds of purposes as properly.
Please observe that this tutorial doesn’t cowl finest practices for AWS utilization. As an alternative, the aim is to provide readers a hands-on introduction to software deployment utilizing EC2 situations.
# 01. Occasion creation
Navigate to the Ec2 dashboard within the AWS service menu and select to create a brand new occasion. It will open a web page the place we are able to outline occasion parameters.
Choose the corresponding occasion sort. On this tutorial, we’ll launch a quite simple server with minimal technical necessities, so t3.nano ought to be ample for our wants.

For its containers, AWS makes use of SSH authentication. When creating a brand new occasion, it’s essential to create a brand new key pair that may permit us to log in from the native machine utilizing the SSH protocol. Click on on Create new key pair.

Assign a reputation to the brand new key. We won’t dive into the potential choices right here, so we’ll select RSA as the important thing pair sort and .pem because the non-public key file format.

To save lots of time, in our demonstration software we won’t fear about safety. For the community settings, tick all of the checkboxes equivalent to SSH, HTTP, and HTTPS site visitors.

Nice! By clicking Launch occasion, AWS will create a brand new occasion.

After the occasion is created, a .pem file might be downloaded to your native machine. This file comprises the non-public key that permits SSH authentication. As a great apply, retailer this file in a secure location as a result of AWS doesn’t present a solution to get better it whether it is misplaced.
By opening the EC2 dashboard, you’ll discover that the created occasion has an related IP deal with. This IP is proven underneath the label “Public IPv4 deal with”. For instance, within the picture beneath, it’s “16.16.202.153”. As soon as we deploy our software, it is going to be accessible from a browser utilizing this IP deal with.

# 02. SSH connection
AWS affords a number of methods to carry out authentication. In our case, we’ll use the SSH mechanism.
Within the occasion menu, click on Join and choose SSH shopper from the highest bar.

Open the native terminal and, utilizing the screenshot above as reference, copy and execute command #3 (chmod 400 "<key_name>.pem"
) together with the command proven beneath the “Instance” label. Be certain that your present terminal listing matches the placement the place the .pem key was downloaded within the earlier step.
Throughout the SSH connection, the terminal may immediate whether or not to proceed. If it does, sort “sure”.
At this level, we’re efficiently related from the native terminal to the EC2 occasion. Any instructions entered into the terminal will now be executed straight within the EC2 container.
# 03. Atmosphere configuration
After connecting to the occasion from the native terminal, the following step is to replace the bundle supervisor and set up Python together with Nginx.
sudo apt-get replace
sudo apt set up -y python3-pip nginx
To redirect site visitors to our software, we have to create an Nginx configuration file. This file ought to be positioned within the listing /and many others/nginx/sites-enabled/
and may have any customized title. We’ll add the next configuration to it:
server {
pay attention 80;
server_name <Public_IP_Address>;
location / {
proxy_pass http://127.0.0.1:8000;
}
}
Mainly, we’re specifying that any exterior request despatched to the EC2 occasion’s IP deal with on the default port 80 ought to be redirected through a proxy to the appliance working contained in the EC2 container on the deal with http://127.0.0.1:8000
. As a reminder, that is the default HTTP deal with and port assigned by FastAPI.
To use these adjustments, we have to restart Nginx:
sudo service nginx restart
If we now have a FastAPI server that we want to launch, the only means can be to publish it on GitHub after which clone the repository onto the EC2 occasion.
git clone <GitHub_URL> <listing>
cd <listing>
Create and activate a digital setting:
python3 -m venv venv
supply venv/bin/activate
Set up the mandatory Python necessities (assuming that the cloned repository comprises a necessities.txt file):
pip3 set up -r necessities.txt
Run the server:
python3 -m uvicorn <server_filename>:app
Open the browser and enter the IP deal with of the occasion.
Be certain that to make use of the HTTP (not HTTPS) protocol. For instance: <a href="http://16.16.202.153/" rel="noreferrer noopener" goal="_blank">http://16.16.202.153</a>
. The firewall may block your connection, however you need to proceed to open the online web page. Add /docs
after the URL to open Quick API Swagger.
Train
If you want to run a FastAPI instance, you’ll be able to create a easy repository consisting of only a foremost.py file and a necessities.txt.
foremost.py
from fastapi import FastAPI
app = FastAPI()
@app.get("/")
def read_root():
return {"message": "Howdy, World!"}
necessities.txt
fastapi
uvicorn
Importing information
In case you attempt to add a file to a server and obtain a 413 standing with the error message “Error: Request Entity Too Massive”, it’s possible as a result of Nginx has a restrict on the utmost file measurement that may be uploaded. To resolve this subject, go to the Nginx configuration file and specify the utmost allowed file measurement through the use of the client_max_body_size directive (setting it to 0 signifies no limits on enter file sizes):
server {
pay attention 80;
server_name <PUBLIC_IP_ADDRESS>;
location / {
proxy_pass http://127.0.0.1:8000;
client_max_body_size 0;
}
}
After altering the configuration file, don’t forget to restart Nginx.
Conclusion
On this article, we now have discovered tips on how to rapidly create a working EC2 occasion utilizing a FastAPI server for example. Though we didn’t comply with the perfect deployment and safety practices, the principle aim of the article was to supply minimal info for learners to launch their first server on AWS.
The subsequent logical step within the AWS examine roadmap can be creating a number of EC2 situations and connecting them to one another.
All photographs except in any other case famous are by the writer.