虚拟环境之virtualenv与virtualenvwrapper
一.前言
在使用python开发的过程中,工程一多,难免会碰到不同的工程依赖不同版本的库的问题;亦或者是在开发过程中不想让物理环境里充斥各种各样的库,引发未来的依赖灾难。此时,我们需要对于不同的工程使用不同的虚拟环境来保持开发环境以及宿主环境的清洁。这里,就要隆重介绍virtualenv,一个可以帮助我们管理不同Python环境的绝好的工具。virtualenv可以在系统中建立多个不同并且相互不干扰的虚拟环境。
二.Linux下安装,配置virtualenv
1.下载virtualenv工具
通过物理环境的pip工具安装
# 指定清华源下载pip的包 pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple virtualenv、 # 升级pip工具 pip3 install --upgrade pip
安装完成之后你的Linux就多了一个virtualenv命令
2.创建目录
mkdir Myproject
cd Myproject
3.创建虚拟环境-命名(venv venv1)
virtualenv --no-site-packages --python=python3 venv # 得到独立第三方包的环境,并且指定解释器的python3
调用虚拟环境的命令
--no-site-packages 这是构建干净,隔离的模块的参数 --python=python3 这个参数是指定虚拟环境以哪一个物理解释器为基础的 最后一个是虚拟环境的名字,会创建这么一个文件夹
4.进入虚拟环境目录,激活虚拟环境
找到你的虚拟环境目录bin地下的activate文件 source myenv/venv/bin/activate # 此时进入虚拟环境 #激活虚拟环境,原理就是修改了PATH变量,path是有顺序执行的 echo $PATH 检查环境变量 which python3 which pip3 检查虚拟环境是否正常
5.安装第三方包
(venv)Myproject: pip3 install django==1.9.8 # 此时pip的包都会安装到venv环境下,venv是针对Myproject创建的 # 测试安装两个环境。venv,venv1,并且运行两个不同版本的django项目
6.退出venv环境
deactivate命令
三.确保开发环境的一致性
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
注意!!!:注意这里path的配置,需要将物理解释器的python,放在path最前面
echo $PATH 这里保持配置和我一样,将python3放在最前面 [root@localhost ~]# echo $PATH /opt/python36/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/root/bin
2.设置Linux的环境变量,每次启动就加载virtualenvwrapper
# 把下面两行代码添加到 ~/.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安装脚本 source ~/.bashrc # 读取文件,使得生效,此时已经可以使用virtalenvwrapper
3.如果没有生效的话,重新登陆会话,使得配置生效
logout
ssh ......
4.基本使用virtualenvwrapper
创建一个虚拟环境:
# mkvirtualenv 虚拟环境名 #自动下载虚拟环境,且激活虚拟环境 mkvirtualenv my_django 这会在 ~/Envs 中创建 my_django文件夹。
# workon 虚拟环境名 #激活虚拟环境 在虚拟环境上工作:激活虚拟环境my_django workon my_django 再创建一个新的虚拟环境 mkvirtualenv my_django1 virtualenvwrapper 提供环境名字的tab补全功能。 当有很多环境, 并且很难记住它们的名字时,这就显得很有用。 workon还可以任意停止你当前的环境,可以在多个虚拟环境中来回切换 workon django1.15 workon django2.0
# deactivate 退出虚拟环境 也可以手动停止虚拟环境 deactivate
# rmvirtualenv 删除虚拟环境 删除虚拟环境,需要先退出虚拟环境 rmvirtualenv my_django
5.常用其他命令
lsvirtualenv # 列举所有的环境。 cdvirtualenv # 导航到当前激活的虚拟环境的目录中,比如说这样您就能够浏览它的 site-packages 。 cdsitepackages # 和上面的类似,但是是直接进入到 site-packages 目录中。 lssitepackages # 显示 site-packages 目录中的内容。 完整官网介绍:https://virtualenvwrapper.readthedocs.io/en/latest/command_ref.html