短的问题
安装pip、virtualenv和分发的正确方法是什么?
背景
在我对SO问题4314376的回答中,我建议使用ez_setup,这样你就可以像下面这样安装pip和virtualenv:
curl -O http://peak.telecommunity.com/dist/ez_setup.py
sudo python ez_setup.py
sudo easy_install pip
sudo pip install virtualenv
我最初从Jesse Noller的博客文章中提取了这些说明所以你想在Mac上使用Python ?我喜欢保持一个干净的全局site-packages目录的想法,所以我在那里安装的其他包只有virtualenvwrapper和distribute。(因为这个Python公共服务公告,我最近把分发添加到我的工具箱中。为了安装这两个包,我使用了:
sudo pip install virtualenvwrapper
curl -O http://python-distribute.org/distribute_setup.py
sudo python distribute_setup.py
不再有setuptools和easy_install
为了真正遵循Python公共服务声明,在新的Python安装上,我将执行以下操作:
curl -O http://python-distribute.org/distribute_setup.py
sudo python distribute_setup.py
sudo easy_install pip
sudo pip install virtualenv
sudo pip install virtualenvwrapper
字形的责备
在我对SO问题4314376的回答的评论中,SO用户Glyph表示:
不。永远不要使用sudo python setup.py安装任何东西。编写~/.pydistutils.cfg文件,将pip安装放在~/目录下。本地的或者其他的。特别是名为ez_setup.py的文件往往会占用setuptools和easy_install等新版本的东西,这可能会破坏操作系统上的其他东西。
回到那个简短的问题
所以,Glyph的回答让我想到了我最初的问题:
安装pip、virtualenv和分发的正确方法是什么?
我在安装升级的SSL模块时遇到了各种问题(见下文),甚至是在virtualenv中,在旧的操作系统提供的Python版本上安装,所以我现在使用pyenv。
pyenv使得安装新的Python版本非常容易,并支持virtualenv。入门比其他答案中列出的virtualenv食谱容易得多:
在Mac上,输入brew install pyenv,在Linux上,使用pyenv installer
这为你提供了内置的virtualenv支持以及Python版本切换(如果需要)
适用于python2或python3,可以同时安装多个版本
这可以很好地将“新Python”版本和virtualenv与系统Python隔离开来。因为你可以很容易地使用最新的Python(2.7.9之后),SSL模块已经升级了,当然,像任何现代的virtualenv设置一样,你与系统Python模块是绝缘的。
一些不错的教程:
使用pyenv和virtualenv——在选择Python版本时,使用pyenv global 3.9.1(对当前用户来说是全局的)或pyenv local 3.6.3(对当前目录来说是本地的)更容易。
Pyenv基础知识,并与virtualenv一起使用
pyenv-virtualenv插件现在是内置的- type pyenv命令| grep virtualenv检查。我不会一开始就使用pyenv- virtualenenv插件——看看你如何使用pyenv-virtualenv插件,它更集成到pyenv中,因为它涵盖了virtualenvwrapper所做的大部分工作。
pyenv是基于rbenv(一种用于Ruby版本切换的好工具)建模的,它唯一依赖的是bash。
pyenv与名称非常相似的pyvenv无关——pyvenv是一个虚拟的env,是最近Python 3版本的一部分,并且不处理Python版本切换
警告
关于pyenv的两个警告:
它只能从bash或类似的shell中工作-或者更具体地说,pyenv-virtualenv插件不喜欢dash,它在Ubuntu或Debian上是/bin/sh。
它必须从交互式登录shell运行(例如bash—使用终端登录),这并不总是容易实现自动化工具,如Ansible。
因此,pyenv最适合交互使用,不太适合脚本服务器。
旧的发行版—SSL模块问题
使用pyenv的一个原因是,在使用较旧的系统提供的Python版本时,升级Python SSL模块经常会出现问题。由于当前的Linux发行版支持Python 3.x,这可能不是什么问题。
如果你遵循我在这个答案中链接的几个教程中建议的步骤,你就会
就能得到想要的效果,而不需要沃克和维奈回答中有些复杂的“手动”步骤。如果你用的是Ubuntu:
sudo apt-get install python-pip python-dev
在OS X中,通过使用自制程序安装python可以实现相同的功能(更多细节请点击此处)。
brew install python
安装pip后,您可以使用它来获取剩余的包(在OS X中可以省略sudo,因为您正在使用本地python安装)。
sudo pip install virtualenvwrapper
(这些是你唯一需要在全球安装的包,我怀疑它会与任何系统级的操作系统发生冲突。如果你想要超级安全,你可以保留发行版的版本
注意:在Ubuntu 14.04中,我在pip安装时收到了一些错误,所以我使用pip3 install virtualenv virtualenvwrapper并将VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3添加到我的.bashrc/。zshrc中。
然后追加到.bashrc文件
export WORKON_HOME
source /usr/local/bin/virtualenvwrapper.sh
来源
. ~/.bashrc
基本上就是这样。现在唯一需要决定的是是否要创建一个virtualenv来包含系统级包
mkvirtualenv --system-site-packages foo
现有的系统包不需要重新安装,它们被符号链接到系统解释器的版本。注意:你仍然可以在没有sudo的情况下安装新的包和升级现有的系统包-我测试了它,它可以在没有任何系统解释器中断的情况下工作。
kermit@hocus-pocus:~$ sudo apt-get install python-pandas
kermit@hocus-pocus:~$ mkvirtualenv --system-site-packages s
(s)kermit@hocus-pocus:~$ pip install --upgrade pandas
(s)kermit@hocus-pocus:~$ python -c "import pandas; print(pandas.__version__)"
0.10.1
(s)kermit@hocus-pocus:~$ deactivate
kermit@hocus-pocus:~$ python -c "import pandas; print(pandas.__version__)"
0.8.0
如果你想要一个完全分离的环境,另一种选择是
mkvirtualenv --no-site-packages bar
或者假设这是默认选项,简单地
mkvirtualenv bar
结果是,您有了一个新的virtualenv,在那里您可以自由而缓慢地安装您最喜欢的软件包
pip install flask