关于virtualenv


从字面上可以理解到,virtualenv旨在搭建一个虚拟python环境,根据Python Package Index上的描述,virtualenv是一个工具,可以创建独立的Python环境,一个专属于项目的python环境。用virtualenv 来保持一个干净的环境非常有用。

virtualenv解决的基本问题是消除了包冲突问题。经常会有这样的情况,某个工具需要一个包版本,而另一个工具却需要另一个不同的包版本。这会导致因为一些人无意地修改全局site-packages目录,以此希望通过升级包来运行一个不同的工具,从而一个web应用被破坏。

通常的解决办法是:一个开发者不具有对一个全局sit-packages目录的写权限,并且可以使用virtualenv来保持一个独立的、与系统Python相分离的virtualenv。virtualenv是一个消除之前诸多问题的解决方案,因为它允许创建新的发送箱,新的发送箱可以彻底与全局sit-packages目录相隔离。

virtualenv具有以下特点:

1. 能够在没有权限的情况下安装新套件
2. 不同应用可以使用不同的套件版本
3. 套件升级不影响其他应用


安装virtualenv


virtualenv是一个Python包,可以直接使用easy_install或者pip安装:

#easy_install virtualenv


创建独立的Python环境


1. 单一版本的Python使用virtualenv


当主机上只安装有一个版本的Python时,可以直接使用virtualenv来创建虚拟环境:virtualenv [虚拟环境目录]

#virtualenv pythonenv

默认情况下,虚拟环境会依赖系统环境中的site packages,就是说系统中已经安装好的第三方package也会安装在虚拟环境中,如果不想依赖这些package,那么可以加上参数 --no-site-packages建立虚拟环境:

#virtualenv --no-site-packages [虚拟环境目录]


启动虚拟环境:

#cd pythonenv

#source ./bin/activate

注意此时命令行会多出一个pythonenv,pythonenv为虚拟环境名称,接下来所有模块都只会安装到该目录中去。


退出虚拟环境:

#deactivate


2. 多个版本创建virtualenv


当主机上安装有不同版本的Python,如Python 2.6、Python 2.7或者Python 3.x,它们会共享相同的bin主目录。

最新版的virtualenv已经支持--python选项,该选项可以直接指定虚拟环境运行的Python环境。如:

#virtualenv --python=/usr/local/python2.7/bin/python2.7 py27ENV

查看:

#ls py27ENV

bin/    lib/

可以看出virtualenv创建了一个相对的bin目录和lib目录,bin目录中是Python解释器,lib目录是它自己的本地site-packages目录。


3. 在虚拟环境安装Python套件


pip 用来解决项目依赖问题。将项目所有依赖的第三方库写在一个requirements.txt 中用pip 批量安装。一般和virtualenv 配合使用,将所有包安装在virtualenv 的环境中。

如果没有启动虚拟环境,而且没有使用虚拟环境下的pip的绝对路径,系统也安装了pip工具,那么套件将被安装在系统环境中,为了避免发生此事,可以在~/.bashrc文件中加上:

export PIP_REQUIRE_VIRTUALENV=true

或者让在执行pip的时候让系统自动开启虚拟环境:

export PIP_RESPECT_VIRTUALENV=true


4. Virtualenvwrapper


Virtaulenvwrapper是virtualenv的扩展包,用于更方便管理虚拟环境,它可以做:
1. 将所有虚拟环境整合在一个目录下
2. 管理(新增,删除,复制)虚拟环境
3. 切换虚拟环境

#easy_install virtualenvwrapper  

此时还不能使用virtualenvwrapper,默认virtualenvwrapper安装在/usr/local/bin下面,实际上你需要运行virtualenvwrapper.sh文件才行,先别急,打开这个文件看看,里面有安装步骤,我们照着操作把环境设置好。

  1. 创建目录用来存放虚拟环境

    #mkdir $HOME/.virtualenvs
  2. 在~/.bashrc中添加行: export WORKON_HOME=$HOME/.virtualenvs

  3. 在~/.bashrc中添加行:#source /usr/bin/virtualenvwrapper.sh

  4. 运行: #source ~/.bashrc

此时virtualenvwrapper就可以使用了。

列出虚拟环境列表

#workon

也可以使用

#lsvirtualenv

新建虚拟环境

#mkvirtualenv [虚拟环境名称]       #可使用--python选项指定Python版本

启动/切换虚拟环境

#workon [虚拟环境名称]

删除虚拟环境

#rm virtualenv [虚拟环境名称]

离开虚拟环境

#deactivate


创建自定义的自启动虚拟环境


通过virtualenv默认只能创建一个“干净”的Python环境,其中只有Python及其标准库。而为了在生成基本的Python环境之后,还能够自动安装所需要的包,比如开发库等,就需要通过调virtualenv.create_bootstrap_script(extra_text),来创建一个启动脚本,类似于virtualenv,但具有额外的特征可以扩展选项parsing、adjust_options、以及使用after_install钩子。

virtualenv.create_bootstrap_script支持在生成的定制化脚本的末尾添加一段自己的代码,而且支持在默认的环境创建完成之后调用自定义的 after_install 方法。

示例:使用virtualenv来创建一个新的虚拟环境并且使用liten包。

创建启动脚本:

import virtualenv,textwrap

output = virtualenv.create_bootstrap_script(textwrap.dedent("""

import os, subprocess

def after_install(options, home_dir):

     etc = join(home_dir, 'etc')

     if not os.path.exists(etc):

           os.makedirs(etc)

     subprocess.call([join(home_dir, 'bin', 'easy_install'),

              'liten'])

"""))

f = open('liten-bootstrap.py', 'w').write(output)

注解:以上代码告诉after_install函数在当前称为liten-bootstrap.py的工作目录下写入一个新文件,然后加入一个自定义的liten模块的easy_install。代码创建bootstrap.py文件,通过执行这个脚本,会生成一个liten-bootstrap.py文件,该文件可以发布给开发者或者终端用户来运行。                                                                                                                                                        

                                                                                                                                                       ——游响云停