This is an API that contains the main functions. This will be forked into our main backend project.
- Repository Structure
- Getting Started
- Deployment
- 1. Create
f1-micro
instance - 2. Enable swapfile for
f1-micro
- 3. Install SSL module for our Python 3.7
- 4. Install Python 3.7
- 5. Prepare and test the API
- 5.1 First, we need to clone this repository
- 5.2 Second, Install
default-libmysqlclient-dev
, this is to fix an error when installingmysqlclient
's pip package. - 5.3 Install
pip
packages by running this command inside cloned repository. - 5.4 Install Gunicorn
- 5.5 add allowed host to your external ip in
_main/settings.py
. In this case, I will use my external ip as allowed host - 5.5 Create a firewall rule first
- 5.6 Run the server
- 6. Run the server in the background process
- 7. See if the server successfully listen to port 8000
- 1. Create
Here is the overview of the repository's structure.
.
├── _main
│ ├── __init__.py
│ ├── __pycache__
│ ├── asgi.py
│ ├── settings.py
│ ├── urls.py
│ └── wsgi.py
├── .gitignore
├── LICENSE
├── manage.py
├── README.md
├── requirement.txt
└── <your-apps-directory>
Let's start this learn by creating your virtual environment (venv). Please refer to this link to see how to make it: https://gist.github.com/ryumada/c22133988fd1c22a66e4ed1b23eca233
pip install -r requirement.txt
django-admin startapp app-name
Register the package you want to use and the application you've created on settings.py
inside the _main
directory. Then find the INSTALLED_APPS
variable and insert the package name as the value.
python3 manage.py migrate
python3 manage.py createsuperuser --email admin@example.com --username admin
This is used to follow pep 8 coding standards.
autopep8 --recursive --in-place --aggressive tokens
We are deploying this app into a Google Cloud Engine (GCE). There is some steps need to do for deploying this app into GCE. We use f1-micro
machine type.
The first step is you need to create an f1-micro
instance with 20GB Standard Persistent Storage. You can create it from GCE console.
We need to create swapfile for f1-micro
instance. This is used to make the program not killed by exhausted small ram that f1-micro
have.
We need to ssh into our instance first, then type these scripts into the instance shell.
sudo fallocate -l 2G /swapfile
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile
source: https://redstapler.co/cost-of-hosting-wordpress-website-on-google-cloud/
Our f1-micro instance is used Debian Linux 11. So, these packages will satisfy SSL module error when installing packages using pip
package management.
sudo apt install libssl-dev
sudo apt install libncurses5-dev
sudo apt install libsqlite3-dev
sudo apt install libreadline-dev
sudo apt install libtk8.6
sudo apt install libgdm-dev
sudo apt install libdb4o-cil-dev
sudo apt install libpcap-dev
This is the main step for installing Python 3.7. There is some commands that need to execute:
sudo apt update
sudo apt install build-essential zlib1g-dev libncurses5-dev libgdbm-dev libnss3-dev libssl-dev libsqlite3-dev libreadline-dev libffi-dev wget libbz2-dev
There are two ways to download the package, by using one of these commands:
- using
wget
wget https://www.python.org/ftp/python/3.7.9/Python-3.7.9.tgz
- or using
curl -O
curl -O https://www.python.org/ftp/python/3.7.9/Python-3.7.9.tgz
tar -xf Python-3.7.9.tgz
cd Python-3.7.9
The script will perform a number of checks to make sure all of your dependencies are present in your system.
./configure
If you add the --enable-optimizations
option, this will make the build process slower. Especially we are using f1-micro
that have small resources. In my case, the build process needs to run 416 tests after the build process.
Please use the option if you use more stronger instance. Here is the script example if you use the option:
./configure --enable-optimizations
The build process will take some time to finish. Before you execute this command, you can install htop
first to monitor your CPU usage that used by this process.
sudo apt install htop
You can activate htop
in a separated ssh session terminal.
htop
If you're ready, then you can run the build command in the first ssh terminal.
make
We need to run make
command inside Python-3.7.9
directory. Because we use f1-micro
instance which just have 1 CPU core, we don't need -j
option. The option is used to run the build process using more than 1 CPU core.
Here is the example of the build process command using 4 core CPUs:
make -j 4
Install python binaries by running this command:
sudo make altinstall
if you run sudo make install
, it will replace default python installation in your system.
- If you run
sudo make altinstall
, you will access your installed python binary like this:
python3.7
- But if you run
sudo make install
:
python3
or
python
source: https://linuxize.com/post/how-to-install-python-3-7-on-ubuntu-18-04/
There is some steps need to do:
git clone <link-to-this-git-repository>
5.2 Second, Install default-libmysqlclient-dev
, this is to fix an error when installing mysqlclient
's pip package.
sudo apt install default-libmysqlclient-dev
python3.7 -m pip install -r requirements.txt
python3.7 -m pip install gunicorn
5.5 add allowed host to your external ip in _main/settings.py
. In this case, I will use my external ip as allowed host
ALLOWED_HOST = ["123.456.789.123"]
Before we run the gunicorn to run the server, first we need to create a firewall rule. In this case, I need to create a firewall with port 8000.
please ensure you create your firewall rule for the network used by our
f1-micro
instance.
You can test the api by running this command:
python3.7 manage.py runserver 0.0.0.0:8000
or you can use gunicorn
:
python3.7 -m gunicorn -b 0.0.0.0:8000 _main.wsgi
stop the command and run this to send the process to background:
python3.7 -m gunicorn -b 0.0.0.0:8000 _main.wsgi &
The command above will return pid
number for the process.
You can see the running jobs by running this command:
jobs -l
You can also run this command to see if the server successfully listen to port 8000:
sudo lsof -n -P -i TCP:8000 -s TCP:LISTEN
If there is no lsof
you can install it:
sudo apt install lsof