主要参考资料:How To Serve Flask Applications with Gunicorn and Nginx on Ubuntu 22.04 | DigitalOcean
fava 本质是一个 Flask 应用,所以可以按照 Flask 应用的部署方式来。
#1. 更新系统环境,并安装依赖
sudo apt update
sudo apt install python3-pip python3-dev build-essential libssl-dev libffi-dev python3-setuptools python3-venv
#2. 创建虚拟环境
mkdir ~/fava-site && cd $_
python3 -m venv venv --upgrade-deps
. venv/bin/activate
#3. 安装 Python 依赖
pip install wheel
pip install gunicorn fava
#4. 配置 fava
vim app.py
sudo ufw allow 5000
sudo vim /etc/systemd/system/fava-site.service
sudo systemctl start fava-site
sudo systemctl enable fava-site
sudo systemctl status fava-site
app.py
"""fava wsgi application"""
from __future__ import annotations
from fava.application import app as application
application.config["BEANCOUNT_FILES"] = [
"ABSOLUTE_PATH_TO_BEANCOUNT_FILE",
]
fava-site.service
[Unit]
Description=Gunicorn instance to serve myproject
After=network.target
[Service]
User=user
Group=www-data
WorkingDirectory=/home/user/fava-site
Environment="PATH=/home/user/fava-site/venv/bin"
ExecStart=/home/user/fava-site/venv/bin/gunicorn --workers 3 --bind unix:fava-site.sock -m 007 app
[Install]
WantedBy=multi-user.target
#5. Nginx 配置反向代理
sudo apt update
sudo apt install nginx
sudo ufw app list
sudo ufw allow 'Nginx HTTP'
sudo vim /etc/nginx/sites-available/fava-site
sudo ln -s /etc/nginx/sites-available/fava-site /etc/nginx/sites-enabled
sudo nginx -t # 检查是否运行正常
sudo systemctl restart nginx
sudo ufw delete allow 5000
sudo ufw allow 'Nginx Full'
一个注意事项:
如果 Nginx 无法获取 gunicorn 的 socket 文件,会返回 HTTP 502 网关错误。这通常是因为用户的家目录不允许其他用户访问里面的文件。如果 socket 文件位于家目录,确保家目录的权限号码至少为 755。如果不是,修改方法:
sudo chmod 755 /home/user
fava-site
server {
listen 80;
server_name your_domain www.your_domain;
location / {
include proxy_params;
proxy_pass http://unix:/home/user/fava-site/fava-site.sock;
}
}
#6. 支持 HTTPS
sudo apt install python3-certbot-nginx
sudo certbot --nginx -d your_domain
sudo ufw delete allow 'Nginx HTTP'