我目前正在考虑为我的网络项目(主要是 Django)从 pip / virtualenv 切换到pipenv 。他们使用“最小停机时间部署”流程,灵感来自https://kuttler.eu/en/post/django-deployments-without-downtime/中描述的流程
TL;博士
是否有 pipenv 命令从头开始创建新环境(新解释器,无包),然后安装依赖项,然后将其设置为当前目录的默认值?
让我们举一个简单的例子。我在我的 debian 服务器上安装了一个项目,其结构如下:
/srv
└── project
├── .git/
├── etc/
├── sources/
├── venv_20170922/
└── venv -> venv_20170922
目前,当我需要部署它时,我想尽可能地限制网站离线的持续时间。请查看我通常遵循的步骤的简化视图(此处缩进只是为了帮助理解该过程):
cd /srv/project
git pull
virtualenv -p python3 venv_20171015
source venv_20171015/bin/activate
pip install -r sources/requirements.txt
pushd sources
python manage.py migrate
python manage.py collectstatic
popd
deactivate
supervisorctl stop myproject
# Now the website is offline
ln -f -s venv_20171015 venv
supervisorctl start myproject
# Now the website is back online
在这个过程中,网站只需要片刻离线,只有停止、更新符号链接和重新启动所需的时间。主管脚本从基于“venv”路径的环境中运行 gunicorn 进程。
但是如何使用 pipenv 重现类似的行为?据我所知,环境是在第一次pipenv
在项目文件夹中使用命令时动态创建的。在这种情况下,是否有一些命令可以很好地控制这种行为?