A simple blog application implemented in Flask (Python), very much inspired by the Flask tutorial.
Data persistence is managed by PostgreSQL.
./start-dev-db.sh
This will start an instance of the database with settings matching the default values of the app.
It is OK to run this start script also when the database is already running (nothing will happen).
The script expects Docker and docker-compose to be available on your machine.
You can stop the database by running:
./stop-dev-db.sh
Obtain settings such as host/port and credentials needed when configuring the application via the following environment variables:
FLOSKL_POSTGRES_HOST
FLOSKL_POSTGRES_PORT
FLOSKL_POSTGRES_DB
FLOSKL_POSTGRES_USER
FLOSKL_POSTGRES_PASSWORD
Setup Python environment (venv
) and enter the app
directory:
./prep-venv.sh && source .venv/bin/activate
cd app
Initialize database schemas:
flask --app floskl init-db
You only need to run this once unless you want to reset the database by adding the
--reset
option.
Run the app in "dev mode", with Flask's dev-server etc.:
flask --app floskl run
Alternatively, if you want to run in production-mode with the Gunicorn HTTP-server, i.e. without Flask's dev-server:
gunicorn --config gunicorn_config.py
Option 2: run via Visual Studio Code
There are tasks and launcher options prepared, both for initializing the database and for running the application in "development mode", with full support for breakpoints, variable inspections etc (incl. automatic restart when you save you update the code).
The list of launcher options are found in the drop-down select in the "Run and Debug" pane (Ctrl + Shift + D):
- Python: Init database
- Python: Flask
The Python venv
environment is automatically prepared and activated when using these options.
This repo also contains a dev container definition, which is prepared for Python development (and more). By leveraging this feature you don't need a local install of Python and other applicable tools (or the "correct" versions of them).
Read more about the "dev container" concept in the docs and make sure to have the Dev Container extension installed.
Even if you don't use this feature, you can still use the launcher options described above as long as you open the repo root directory in Visual Studio Code.