Skip to content

Latest commit

 

History

History
48 lines (32 loc) · 2.7 KB

README.md

File metadata and controls

48 lines (32 loc) · 2.7 KB

Python Fast API Boilerplate code

Requirements

  • python 3.9 or above

How to run locally

  1. Create a venv inside the project python3 -m venv venv/
  2. Source the venv activation script source venv/bin/activate
  3. Install all python dependencies pip install -r requirements.txt
  4. Run the app using uvicorn python3 -m uvicorn src.main:app --host 127.0.0.1 --port 8000
  5. In the browser go to 127.0.0.1:8000/docs to view the Swagger docs

How to run via Docker

Using docker-compose

This is the recommended method as the container, network and volume configurations are provided once. And the application can be started and stopped by just single commands.

  1. Perform docker-compose up. Wait for the application to startup. You can check the logs to verify this.
  2. Go to 127.0.0.1:8000/docs to view the Swagger docs.
  3. If you make any changes to the code, you need to perform docker-compose down and then docker-compose up --build to build the docker image with new changes and to up the application.
  4. If the containerized application is not required anymore do docker-compose down to bring down the container.

Note: docker-compose down will not delete the volume that was attached to the mysqldb container. This is not a bug, but a well thought feature. By not deleting the volume, the volume will be reused when the application is started again. And you won't lose any data stored in the database. If you want to delete the volume, you can do it by running docker volume rm <volume_name>


Not using docker-compose

The docker image, network, volume and containers have to created manually by separate commands in this method.

  1. docker pull mysql:latest
  2. docker network create --driver bridge app-network
  3. docker volume create db-data
  4. docker run -dit --name mysqldb --network app-network --volume db-data:/var/lib/mysql --publish 3306:3306 --restart always --platform linux/x86_64 --env MYSQL_DATABASE=dev --env MYSQL_USER=admin --env MYSQL_ROOT_PASSWORD=<provide-root-password-here> --env MYSQL_PASSWORD=<provide-password-here> mysql:latest
  5. docker build -t=pythonwebbase .
  6. docker run -dit --name app --network app-network --publish 8000:8000 --env MYSQL_DATABASE=dev --env MYSQL_USER=admin --env MYSQL_PASSWORD=<provider-password-here> pythonwebbase:latest
  7. Now go to 127.0.0.1:8000/docs to view the Swagger docs.

To stop the containarized application

  1. Perform docker stop app && docker rm app to stop and destroy the app container. Similarly, for the mysqldb container, do docker stop mysqldb && docker rm mysqldb.
  2. To remove the network docker network rm app-network.
  3. Finally remove the created volume by doing docker volume rm db_data.