virtualenv
主要是为了解决在同一个系统中存在多个项目的情况, 采用虚拟的方式,为每个项目创建各自的环境,使各个项目不会相互干扰
正常情况下,我们 pip 和 python 命令所执行的命令都是在系统环境下执行,修改的也是系统下的 python,导致每次的修改都是全局性的
当一个系统中存在多个项目时,而每个项目的配置需要又不一样,对全局的 python 环境修改又太麻烦
同样适用了虚拟环境,可以大胆的做各种 python 的实验、测试、开发等等,不用担心对系统全局环境的影响
sudo pip install virtualenv
sudo pip install virtualenvwrappe
安装好之后在 /usr/local/bin 下有两者
然后新建一个文件夹用来存放虚拟环境
例如:
cd Desktop
# 新建文件夹 myproject
mkdir myproject
# 进入到文件夹中
cd myproject
命令virtualenv就可以创建一个独立的Python运行环境,我们还加上了参数--no-site-packages,这样,已经安装到系统Python环境中的所有第三方包都不会复制过来,这样,我们就得到了一个不带任何第三方包的“干净”的Python运行环境。
virtualenv 虚拟环境的名称
例如:
virtualenv venv
# 加上--no-site-packages 将不会拷贝系统Python 环境中已经存在的 python 包
virtualenv --no-site-packages venv
这个时候在 venv 下已经创建了一个新的 python 环境
sit-packages 默认安装了 setuptools, pip, wheel
新建的Python环境被放到当前目录下的venv目录。有了venv这个Python环境,可以用source进入该环境:
# 注意需要使用 source 命令进入此 venv 环境,否则所有的 pip或python均是在系统Python环境下执行
source venv/bin/activate
注意到命令提示符变了,有个(venv)前缀,表示当前环境是一个名为venv的Python环境。
下面正常安装各种第三方包,并运行python命令:
现在可以测试安装一个包测试其安装地址
pip install jinja2
# 这个时候可以发下在 venv/lib/python2.7/sit-packages 目录下面发现 jinja 库
在venv环境下,用pip安装的包都被安装到venv这个环境下,系统Python环境不受任何影响。也就是说,venv环境是专门针对myproject这个应用创建的。
退出当前的venv环境,使用deactivate命令:
deactivate
此时就回到了正常的环境,现在pip或python均是在系统Python环境下执行
virtualenv是如何创建“独立”的Python运行环境的呢?原理很简单,就是把系统Python复制一份到virtualenv的环境,用命令source venv/bin/activate进入一个virtualenv环境时,virtualenv会修改相关环境变量,让命令python和pip均指向当前的virtualenv环境。