在开发Python应用程序的时候,如果我们要同时开发多个应用程序,那这些应用程序都会共用一个Python,就是安装在系统的Python 3。如果应用A需要jinja 2.7,而应用B需要jinja 2.6怎么办?
这种情况下,每个应用可能需要各自拥有一套“独立”的Python运行环境。
venv模块是Python3.3之后标准库自带的虚拟环境创建和管理工具,在一定程度上能够替代virtualenv。但venv是Python3.3才有的,Python2.X不能使用,而virtualenv同时支持Python2.X和Python3.X
Python3.3以上
python -m venv myvenv
激活环境
Posix标准平台下:
$ source <myvenv>/bin/activate
Windows cmd :
C:> <myvenv>/Scripts/activate.bat
Windows PowerShell:
PS C:> <myvenv>/Scripts/Activate.ps1
Python 2.X及其他版本
在Python 2.X版本中,virtualenv就是用来为一个应用创建一套“隔离”的Python运行环境。
首先,我们用pip安装virtualenv:
$ pip3 install virtualenv
我们要开发一个新的项目,需要一套独立的Python运行环境,可以这么做:
第一步,创建目录:
mkdir myproject
cd myproject/
第二步,创建一个独立的Python运行环境,命名为venv:
virtualenv --no-site-packages venv
这里会默认使用当前python的环境,如果想指定目标python版本环境,可以使用
virtualenv -p /usr/bin/python3.6 --no-site-packages venv
这样就会使用python3.6的环境到虚拟环境中。
命令virtualenv就可以创建一个独立的Python运行环境,我们还加上了参数–no-site-packages,这样已经安装到系统Python环境中的所有第三方包都不会复制过来,我们就得到了一个不带任何第三方包的“干净”的Python运行环境。
新建的Python环境被放到当前目录下的venv目录。有了venv这个Python环境,可以用source进入该环境:
source venv/bin/activate
(venv)XXXXXX$
注意到命令提示符变了,有个(venv)前缀,表示当前环境是一个名为venv的Python环境。
下面正常安装各种第三方包,并运行python命令:
(venv)XXXXXX$ pip install jinja2
(venv)XXXXXX$ python myapp.py
在venv环境下,用pip安装的包都被安装到venv这个环境下,系统Python环境不受任何影响。也就是说,venv环境是专门针对myproject这个应用创建的。
如果我们需要启动py文件,需要讲项目文件夹复制到虚拟环境中venv文件夹下。
退出当前的venv环境,使用deactivate命令:
(venv)XXXXXX$ deactivate
此时就回到了正常的环境,现在pip或python均是在系统Python环境下执行。完全可以针对每个应用创建独立的Python运行环境,这样就可以对每个应用的Python环境进行隔离。
virtualenv是如何创建“独立”的Python运行环境的呢?原理很简单,就是把系统Python复制一份到virtualenv的环境,用命令source venv/bin/activate进入一个virtualenv环境时,virtualenv会修改相关环境变量,让命令python和pip均指向当前的virtualenv环境。