关于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文件才行,先别急,打开这个文件看看,里面有安装步骤,我们照着操作把环境设置好。
创建目录用来存放虚拟环境
#mkdir $HOME/.virtualenvs
在~/.bashrc中添加行: export WORKON_HOME=$HOME/.virtualenvs
在~/.bashrc中添加行:#source /usr/bin/virtualenvwrapper.sh
运行: #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文件,该文件可以发布给开发者或者终端用户来运行。
——游响云停