欢迎来到夜的世界

莫听穿林打叶声,何妨吟啸且徐行。竹杖芒鞋轻胜马,谁怕?一蓑烟雨任平生.料峭春风吹酒醒,微冷,山头斜照却相迎。回首向来萧瑟处,归去,也无风雨也无晴。
扩大
缩小

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 

 

posted on 2018-12-30 23:49  二十四桥_明月夜  阅读(863)  评论(0编辑  收藏  举报

导航