lun先生

导航

< 2025年1月 >
29 30 31 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31 1
2 3 4 5 6 7 8

统计

virtualenv环境变量的配置

virtualenv环境变量的配置

下载virtualenv源码包

pip3 install virtualenv
或者
这里要说明一下,在使用下面的方式之前,要先给pip3的工具升级一下
pip3 install --upgrade pip
然后在使用连接的方式(如下)
pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple virtualenv
​

安装成功

常用命令

1.安装virtualenv
pip3 install virtualenv 
2.创建目录
mkdir Myproject
cd Myproject
3.创建独立运行环境-命名
virtualenv --no-site-packages --python=python3  venv#得到独立第三方包的环境,并且指定解释器是python3
4.进入虚拟环境
source venv/bin/activate#此时进入虚拟环境(venv)Myproject
5.安装第三方包
(venv)Myproject: pip3 install django==1.9.8
#此时pip的包都会安装到venv环境下,venv是针对Myproject创建的
6.退出venv环境
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

记住,要在物理环境下安装virtualenvwrapper
pip3 install virtualenvwrapper

步骤2:设置Linux的环境变量,每次启动就加载virtualenvwrapper

把下面两行代码添加到 ~/.bashrc文件中
打开文件
vim ~/.bashrc
写入以下两行代码
export WORKON_HOME=~/Envs   #设置virtualenv的统一管理目录
export VIRTUALENVWRAPPER_VIRTUALENV_ARGS='--no-site-packages'   #添加virtualenvwrapper的参数,生成干净隔绝的环境
export VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3     #指定python解释器
source /usr/bin/virtualenvwrapper.sh #执行virtualenvwrapper安装脚本
############以上是配置内容#########################

# 最后执行下面的命令
读取文件,使得生效,此时已经可以使用virtalenvwrapper
source ~/.bashrc

注意: 如果将代码放到~/.bashrc文件中执行 source ~/.bashrc报错

virtualenvwrapper.sh: There was a problem running the initialization hooks.

If Python could not import the module virtualenvwrapper.hook_loader,
check that virtualenvwrapper has been installed for
VIRTUALENVWRAPPER_PYTHON= and that PATH is
set properly.

内容:

1838/5000 
文件"/usr/lib/python3.6/site-packages/stevedore/_cache.py",第28行,在

进口importlib。元数据作为importlib_metadata

ModuleNotFoundError:没有名为'importlib.metadata'的模块

下载个importlib_metadata就解决了

 

if [ -f /usr/local/bin/virtualenvwrapper.sh ]; then
    export WORKON_HOME=$HOME/.virtualenvs
    export VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3
    source /usr/local/bin/virtualenvwrapper.sh
fi
# 将这段代码写入到.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

步骤四:常用其他命令

lsvirtualenv
列举所有的环境。
cdvirtualenv
导航到当前激活的虚拟环境的目录中,比如说这样您就能够浏览它的 site-packages 。
cdsitepackages
和上面的类似,但是是直接进入到 site-packages 目录中。
lssitepackages
显示 site-packages 目录中的内容。完整官网介绍:https://virtualenvwrapper.readthedocs.io/en/latest/command_ref.html

posted on   lun先生  阅读(1264)  评论(0编辑  收藏  举报

点击右上角即可分享
微信分享提示