Linux——Django 开发环境部署(二)python版本控制器pyenv

时间:2021-07-05 08:37:21

python版本控制器pyenv

之前的 那篇是说明了django环境的site package完全独立出来了,但是使用的python解释器还是系统的,为了继续独立出来,甚至是达到ruby的rvm的*切换解释器版本,那样不更 好,日后线上升级python版本的时候直接再本地切换版本来运行当前代码测试岂不快哉,其实本篇已经不能算django开发环境了,是python开发 环境部署

在上篇的基础上,继续进行解释器的版本管理器的安装,这里我使用的时pyenv,另外一个管理器是pythonbrew,还有一个pythonz,至于为什么选择pyenv,pythonbrew的GitHub主页上给出了解释如下

英文翻译水平太烂,只能搬原文

Deprecated
This project is no longer under active development.
You are encouraged to try out pyenv instead.

为什么选用pyenv

  • Depend on Python itself. pyenv was made from pure shell scripts. There is no bootstrap problem of Python.

  • Need to be loaded into your shell. Instead, pyenv's shim approach works by adding a directory to your $PATH.

  • Manage virtualenv. Of course, you can create virtualenv yourself, or pyenv-virtualenv to automate the process.

这个项目目前已经在慢慢取代了pythonbrew,GitHub主页 https://github.com/yyuu/pyenv

step1:简介

pyenv lets
you easily switch between multiple versions of Python. It's simple,
unobtrusive, and follows the UNIX tradition of single-purpose tools that
do one thing well.
This project was forked from rbenv and ruby-build, and modified for Python.

step2:功能

  • Let you change the global Python version on a per-user basis.

  • Provide support for per-project Python versions.

  • Allow you to override the Python version with an environment variable.

  • Search commands from multiple versions of Python at a time. This may be helpful to test across Python versions with tox.

step3:安装

基于GitHub的安装

This will get you going with the latest version of pyenv and make it easy to fork and contribute any changes back upstream.

1、克隆仓库

$ cd 
$ git clone git://github.com/yyuu/pyenv.git .pyenv

2、指明环境变量

$ echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.bash_profile 
$ echo 'export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.bash_profile

3、开启shims and autocompletion

$ echo 'eval "$(pyenv init -)"' >> ~/.bash_profile

4、重新启动shell让其生效

$ exec $SHELL

5、这时候就可以安装另外版本的python了

#这里会在$PYENV_ROOT/versions下生成一个目录 
$ pyenv install 2.7.6

6、重构shim,利用pyenv安装完新version的py还是利用安装完新site package都需要执行这个操作

$ pyenv rehash

7、升级pyenv

#升级到最新版 $ cd ~/.pyenv $ git pull 
#升级到指定版本 $ cd ~/.pyenv $ git fetch
$ git tag v0.1.0
$ git checkout v0.1.0

8、卸载指定py版本

通用方法
cd ~/.pyenv/versions
pyenv uninstall 暴力做法
rm -rf $pyversion

如果是mac平台

$ brew update 
$ brew install pyenv //安装
$ brew upgrade pyenv //升级 #安装完成之后
$ echo 'eval "$(pyenv init -)"' >> ~/.bash_profile //只需要执行一次即可

step4:使用

官方usage页

$ pyenv commands //列出可以使用的命令 
$ pyenv install 3.4.0
$ pyenv version //查看当前的python version
$ pyenv versions //列出pyenv安装的所有组件,包括site package
$ pyenv which python3.4 //列出给定的python version可执行文件位置
$ pyenv whence 2to3 //列出pyenv安装的python version
$ pyenv install --list //列出所有可以安装的包括python version,pypy等
$ pyenv rehash //Run this command after you install a new version of Python, or install a package that provides binaries.
$ pyenv uninstall //卸载 #下面关于pyenv local和pyenv global是两个重要命令 稍后做出单独使用的解释

step5:整合virtualenv

这个pyenv设计了插件来整合了virtualenv甚至还人性化的推出了virtualenvwrapper

1、安装

$ git clone https://github.com/yyuu/pyenv-virtualenv.git ~/.pyenv/plugins/pyenv-virtualenv 
$ exec "$SHELL" #上面会把最近版本安装到~/.pyenv/plugins/pyenv-virtualenv目录 #mac下的安装
$ brew install pyenv-virtualenv

2、使用

$ pyenv virtualenv 2.7.6 venv-2.7.6 //创建一个使用2.7.6版本的解释器的名称为my-virtual-env-2.7.6虚拟环境,存放在~/.pyenv/versions 
$ pyenv virtualenv 3.4.0 venv-django1.6-3.4.0 //同理创建一个3.4解释器的虚拟环境,就是前面我需要的完全独立的测试环境 #这里有个注意的地方这里的解释器必须是通过pyenv安装的解释器,如果不加参数,如下
$ pyenv virtualenv django1.6 //那么这里会使用系统的python version创建虚拟环境,如果需要加参数,就必须是pyenv安装的版本 #激活虚拟环境,这个虚拟环境必须是pyenv创建存在的
$ pyenv activate venv33 #退出虚拟环境
$ pyenv deactivate
\\当然依旧可以使用deactivate,但是这里不推荐的原因是采用deactivate之后仍旧是需要自己取消pyenv local的设定的,假设之前已经设定
 ,关于pyevn的shell,local、global,会单独写出来说明