install flask websites into nginx
Project description
footprint 👣
I use this to generate config files for my flask apps. Currently systemd and nginx. It only depends on Flask.
It is intended to be installed into the same virtual environment that the flask app inhabits so it can introspect the app. It has no dependencies other than Flask.
export FLASK_APP=your_package.wsgi
footprint config nginx www.example.com > example.conf
footprint config nginx-install example.conf
# install in ~/.config/systemd/user
export FLASK_APP=your_package.wsgi
footprint config systemd --user > example.service
footprint config systemd-install --user example.service
will install nginx and systemd files that will statically serve you 'static' assets and run the Flask app with gunicorn.
Mostly I've found that confectioning these files by hand are highly error prone. These commands will at least get the absolute pathnames correct :)
footprint will install a Quart (ASGI) service using the --asgi to flag. In this case you need
both the quart and uvicorn-worker packages installed also.
Install with:
python -m pip install flask-nginx
python -m pip install -U git+https://github.com/arabidopsis/footprint.git
# or
# git clone https://github.com/arabidopsis/footprint.git
# cd footprint
# python -m pip install [--editable] .
or add to your pyproject.toml file
footprint = { git = "https://github.com/arabidopsis/footprint.git", branch="main" }
Once installed you can upgrade with:
footprint update
# or
uv pip install -U $(footprint repo)
If footprint finds a pyproject.toml file in the current directory
if will try to load [tool.footprint] values into its global configuration object.
nginx, systemd and all that
Note that these configuration generating functions are not infallible. Please examine the generated configure files carefully! They are mainly useful for getting the directory names correct etc. So if you move your repo then you will have to regenerate and reinstall the files.
- Nginx Docs. Also and Proxy
Test an nginx config with e.g.:
website=~/Sites/websites/ppr
export FLASK_APP=ppr.wsgi
footprint config nginx --app-dir=$website example.org | footprint config nginx-run --app-dir=$website -
This will run nginx at the terminal listening on port 2048 and run the backend website.
To install a website:
footprint config nginx --app-dir=$website example.org -o website.conf
footprint config systemd [--user] --app-dir=$website -o website.service
# nginx requires sudo (default) or su
footprint config nginx-install website.conf
# if you can install into ~/.config/systemd/user
footprint config systemd-install [--user] website.service
You can test this locally by editing /etc/hosts and adding a line:
127.0.0.1 example.org
to the file.
REMEMBER: Unix file permissions mean that you should edit /etc/nginx/nginx.conf
and change user www-data; to user {you}; Or (recursively) change the owner on
all the repo directories to www-data.
If you install as "user" (i.e. footprint config systemd --user ...) then
to ensure that the user systemd starts at boot time use: sudo loginctl enable-linger <user>
See here:
But what’s the real reason for having user services? To answer that, we have to realize when the enabled service starts and stops. If we enable a user service, it starts on user login, and runs as long as there is a session open for that user. Once the last session dies, the service stops.
See digitalocean.com here for a tutorial about serving flask from nginx.
Uninstall with footprint config nginx-uninstall website.conf and footprint config systemd-uninstall [--user] website.service
.flaskenv
If a .flaskenv is found in the repo directory then nginx and systemd will
read paramters from that file. The keywords should be uppercase version of
the known parameters. Unknown parameters will be ignored.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file flask_nginx-0.8.2.tar.gz.
File metadata
- Download URL: flask_nginx-0.8.2.tar.gz
- Upload date:
- Size: 32.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3dd8f25a7314e2a2d3ac7f2f6872622af55175f21331b1dad67333c9fbea6ea0
|
|
| MD5 |
c4b54528dd0746f24ff628e233c68cf0
|
|
| BLAKE2b-256 |
d35ff019f4e3c3e9c2fef42456b213b1e1411f54b3b67e2f9d6d519e70b358e4
|
File details
Details for the file flask_nginx-0.8.2-py3-none-any.whl.
File metadata
- Download URL: flask_nginx-0.8.2-py3-none-any.whl
- Upload date:
- Size: 46.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
418c2009c4fedf6f5a76510d70e57cd54ca3964f4aa4f605f7172a40c56898f1
|
|
| MD5 |
5f499b44f68673d7b5f6032c13efb2bc
|
|
| BLAKE2b-256 |
f77963bdfaa94cfe1030811dbb02e0b582ab06dbaa1874ff97460cfd0f8d4e12
|