python之virtualenv 与 virtualenvwrapper 详解
在使用 Python
开发的过程中,工程一多,难免会碰到不同的工程依赖不同版本的库的问题;
亦或者是在开发过程中不想让物理环境里充斥各种各样的库,引发未来的依赖灾难。
此时,我们需要对于不同的工程使用不同的虚拟环境来保持开发环境以及宿主环境的清洁。
比如 : 需要在Linux服务器上,既可以有Django2.0环境,也能运行Django1.11.11环境,如果用平时的办法,那么在修改Django2.0的时候如果要修改Django1.11.11,那么要退出在进去,很麻烦.
这里,就要隆重介绍 virtualenv
,一个可以帮助我们管理不同 Python
环境的绝好工具。
virtualenv
可以在系统中建立多个不同并且相互不干扰的虚拟环境。
一 . Linux 下安装,配置virtualenv
#指定清华源下载pip的包 pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple virtualenv #升级pip工具 pip3 install --upgrade pip
1.下载virtualenv工具 通过物理环境的pip工具安装 pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple virtualenv 安装完成后你的linux就多了一个virtualenv命令 2.创建目录 mkdir Myproject cd Myproject 3.创建虚拟环境venv1 venv2 virtualenv --no-site-packages --python=python3 venv1 调用虚拟环境的命令 --no-site-packages 这是构建干净,隔离的模块的参数 --python=python3 这个参数是指定虚拟环境以哪一个物理解释器为基础的 最后一个是虚拟环境的名字 会创建这么一个文件夹 4.进入虚拟环境目录,激活虚拟环境 找到你的虚拟环境目录bin地下的activate文件 source myenv/venv1/bin/activate - 激活虚拟环境,原理就是修改了PATH变量,path是有顺序执行的 echo $PATH 检查环境变量 which python3 which pip3 检查虚拟环境是否正常 5.测试安装2个虚拟环境,venv1,venv2,并且运行2个django不同版本的项目 6.退出虚拟换的命令 deactivate 7. virtualenv是如何创建“独立”的Python运行环境的呢?原理很简单,就是把系统Python复制一份到virtualenv的环境,用命令source venv/bin/activate进入一个virtualenv环境时,virtualenv会修改相关环境变量,让命令python和pip均指向当前的virtualenv环境。
二 . 确保开发环境的一致性
1.假设我们在本地开发环境,准备好了项目+依赖包环境 2.现在需要将项目上传至服务器,上线发布 3.那么就要保证服务器的python环境一致性
解决方案: 1.通过命令保证环境的一致性,导出当前python环境的包 pip3 freeze > requirements.txt 这将会创建一个 requirements.txt 文件,其中包含了当前环境中所有包及 各自的版本的简单列表。 可以使用 “pip list”在不产生requirements文件的情况下, 查看已安装包的列表。 2.上传至服务器后,在服务器下创建virtualenv,在venv中导入项目所需的模块依赖 pip3 install -r requirements.txt
三 . 虚拟环境之 virtualenvwrapper
virtualenv
的一个最大的缺点就是:
每次开启虚拟环境之前要去虚拟环境所在目录下的 bin
目录下 source
一下 activate
,这就需要我们记住每个虚拟环境所在的目录。
并且还有可能你忘记了虚拟环境放在哪。。。
- 一种可行的解决方案是,将所有的虚拟环境目录全都集中起来,例如/opt/all_venv/,并且针对不同的目录做不同的事。
- 使用virtualenvwrapper管理你的虚拟环境(virtualenv),其实他就是统一管理虚拟环境的目录,并且省去了source的步骤。
步骤1 : 安装virtualenvwrapper
pip3 install virtualenvwrapper
步骤2 :设置Linux的环境变量,每次启动就加载
把下面两行代码添加到 ~/.bashrc文件中 打开文件 vim ~/.bashrc 写入以下两行代码 export WORKON_HOME=~/Envs #设置virtualenv的统一管理目录 export VIRTUALENVWRAPPER_VIRTUALENV_ARGS='--no-site-packages' #添加virtualenvwrapper的参数,生成干净隔绝的环境 export VIRTUALENVWRAPPER_PYTHON=/opt/python347/bin/python3 #指定python解释器 source /opt/python34/bin/virtualenvwrapper.sh #执行virtualenvwrapper安装脚本 读取文件,使得生效,此时已经可以使用virtalenvwrapper source ~/.bashrc
步骤3 : 基本使用 virtualenvwrapper
创建一个虚拟环境: $ mkvirtualenv my_django115 这会在 ~/Envs 中创建 my_django115 文件夹。 在虚拟环境上工作:激活虚拟环境my_django115 $ workon my_django115 再创建一个新的虚拟环境 $ mkvirtualenv my_django2 virtualenvwrapper 提供环境名字的tab补全功能。 当有很多环境, 并且很难记住它们的名字时,这就显得很有用。 workon还可以任意停止你当前的环境,可以在多个虚拟环境中来回切换 workon django1.15 workon django2.0 也可以手动停止虚拟环境 deactivate 删除虚拟环境,需要先退出虚拟环境 rmvirtualenv my_django115
步骤4 : 常用命令
lsvirtualenv 列举所有的环境。 cdvirtualenv 导航到当前激活的虚拟环境的目录中,比如说这样您就能够浏览它的 site-packages 。 cdsitepackages 和上面的类似,但是是直接进入到 site-packages 目录中。 lssitepackages 显示 site-packages 目录中的内容。 完整官网介绍:https://virtualenvwrapper.readthedocs.io/en/latest/command_ref.html
大白话 :
步骤 : mkvirtualenv 创建一个虚拟环境 workon 进入虚拟环境 : (xuni) [root@localhost ~]# cd 到你所在的虚拟环境中 : (xuni) [root@localhost xuni]# 下载Django pip3 install django(或者django==1.11.11版本) django-admin startproject mysite 创建django项目 ls 查看创建的项目 : bin include lib mysite cd 到你项目所在目录 : manage.py mysite 再次cd 到mysite 目录 : __init__.py settings.py urls.py wsgi.py 修改 settings.py文件 vim settings.py : ALLOW_HOSTS=["*"] 保存退出 :wq! 运行Django python3 manage.py runserver 0.0.0.0:8080