1

我目前正在考虑为我的网络项目(主要是 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在项目文件夹中使用命令时动态创建的。在这种情况下,是否有一些命令可以很好地控制这种行为?

4

1 回答 1

0

不要在实时服务器上使用 pipenv,而是仅在您的开发机器上使用它并requirements.txt使用以下命令创建一个文件:

$ pipenv lock -r > requirements.txt

在部署期间使用 pip 安装软件包(根本不需要安装或使用 pipenv):

$ pip install -r requirements.txt
于 2018-10-02T18:43:31.877 回答