引言
最近接到了一个需求:在一台linux机器上让hive用户引用2.7版本的python,但是当前集群中安装的默认python版本为2.6.6,因此会有相关的几个问题:
1、在同一用户下,不同用户在开发时使用不同的python版本,如何来满足不同开发用户的需求。
2、线上已经有一个应用在2.6版本python运行的情况下,该用户采用另一个版本开发但是不会影响生产版本。
3、有效的统一管理用户的python版本并进行灵活的切换。
网上有很多相关的python多版本的管理工具,比如:Anaconda、pyenv。之前已经使用过pyenv进行版本管理,这次发现了一个类似的python管理工具pythonbrew,正好测试一下。
pythonbrew安装
我们本次使用的版本pythonbrew-1.3.6在2015年10月以后就再也没有更新了,不过,该工具的兼容性比较好,依然支持2.x及3.x版本的管理,工具的链接:pythonbrew下载与使用
离线安装
安装部署需要root用户
1、解压:tar -xvf pythonbrew-1.3.6.tar.gz
2、编译:python /root/pythonbrew-1.3.6/setup.py build
3、指定命令安装路径:因为使用root安装以后,默认安装在root用户的根目录中,其他用户没有权限执行该命令,因此安装前需要指定一个安装路径。
export PYTHONBREW_ROOT=/opt/.pythonbrew
4、安装:python /root/pythonbrew-1.3.6/setup.py install
5、安装客户端工具:python /root/pythonbrew-1.3.6/pythonbrew_install.py
检查/opt目录下,即生成.pythonbrew文件夹
环境设置:
安装完毕后,为root用户和hive用户添加环境变量:
1、在root用户和hive用户的.bashrc文件中追加以下环境变量:
export PYTHONBREW_ROOT=/opt/.pythonbrew
[[ -s "/opt/.pythonbrew/etc/bashrc" ]] && source "/opt/.pythonbrew/etc/bashrc"
2、重新使用hive用户登录,即可使用pythonbrew命令。
pythonbrew使用
安装完毕以后,就可以用pythonbrew来管理多个python版本,pythonbrew有自己的一套安装部署python的方式,支持在线安装和离线安装,安装完毕后,会向pythonbrew管理器中注册安装版本,pythonbrew只能管理由自己安装部署的python版本,无法管理现有的或者不通过pythonbrew安装的python版本。
离线安装指定python版本
以安装Python-2.7.15为例,该软件支持的安装方式如下:
其中,支持的直接版本安装(下例的2.7.2)必须在其自动支持列表中,可以根据 pythonbrew list -k命令查看
pythonbrew install 2.7.2
pythonbrew install --verbose 2.7.2
pythonbrew install --test 2.7.2
pythonbrew install --test --force 2.7.2
pythonbrew install --configure="CC=gcc_4.1" 2.7.2
pythonbrew install --no-setuptools 2.7.2
pythonbrew install http://www.python.org/ftp/python/2.7/Python-2.7.2.tgz
pythonbrew install /path/to/Python-2.7.2.tgz
pythonbrew install /path/to/Python-2.7.2
pythonbrew install 2.7.2
本次采用离线下载,软件会将python2.7.15安装在PYTHONBREW_ROOT目录下,并且必须用root用户安装。
1、首先下载好Python-2.7.15.tgz的源码包
2、使用root用户,执行pythonbrew install /root/Python-2.7.15.tgz
安装部署完毕之后,软件会使用curl命令去官网上下载一个ez_setup.py安装包,但是由于行内无法访问外网,该步骤会失败,但是不影响用户使用。
使用指定python版本
1、可以通过pythonbrew list 命令来查看已经安装并且管理的python版本:
[root@scchadpcdev01:/home/hive]#pythonbrew list
# pythonbrew pythons
Python-2.7.15
2、hive用户在全局环境中切换python版本:
通过pythonbrew switch 2.7.15命令,可以在全局环境中切换python版本,切换之后,所有hive的新的连接(session),将会使用2.7.15版本的python,但是旧的连接依然使用原有的python环境。
3、hive用户在当前环境中切换python版本:
可能有这样的场景,我只想在当前的session中开发测试python脚本,使用2.7版本的环境,但是该用户已经在运行的环境还是想用2.6的环境,那么可以使用pythonbrew use 2.7.15,该命令只在当前shell中使用2.7版本的python,不影响其他正在执行的python环境。
4、关闭pythonbrew 修改的环境
如果我想将环境还原为pythonbrew 管理之前的环境,则将使用命令pythonbrew off将pythonbrew 关闭即可,则之前执行的所有命令改变的python环境都会时效并还原。