RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 651860
Accepted
hedgehogues
hedgehogues
Asked:2020-04-10 20:46:34 +0000 UTC2020-04-10 20:46:34 +0000 UTC 2020-04-10 20:46:34 +0000 UTC

为什么不使用 sudo pip?

  • 772

你为什么不应该使用sudo pip?这方面我不是很了解。我被要求问一个单独的问题。许多其他人也可能会发现这很有用。

python
  • 4 4 个回答
  • 10 Views

4 个回答

  • Voted
  1. Best Answer
    Nofate
    2020-04-10T23:33:39Z2020-04-10T23:33:39Z

    为什么不使用sudo pip install?

    当你安装一个包时,你不只是把它放在你的文件系统上,你还执行一个setup.py. 因为任何人都可以将包上传到 PyPI,所以您不能确定它setup.py不包含以 root 身份运行时不受欢迎/危险/不可接受的代码。

    就危险级别而言,这相当于在超级用户下“从云端”执行 shell 脚本:

    wget -O - http://example.com/some/unsafe/script.sh | bash
    

    怎样成为?

    选项1

    除非你绝对需要从root-a下安装一个包,你可以使用

    pip install --user mypackage
    

    将包安装到当前用户的存储库$HOME/.local/lib/pythonx.y/site-packages/。

    选项 2

    使用隔离环境,如virtualenv. 在这种情况下,您将拥有无限数量的工作环境(例如,对于每个项目,使用不同版本的 python),它们不会相互干扰。

    包将$HOME/.virtualenvs/$ENVNAME/lib/pythonx.y/site-packages/与所需的 python 版本和第三方二进制文件一起存储在 中,环境切换是通过workon $ENVNAME.

    像 PyCharm 这样的 IDE 可以感知虚拟环境并知道如何使用它们。

    • 22
  2. jfs
    2020-04-10T23:30:49Z2020-04-10T23:30:49Z

    virtualenv 存在的主要原因是,如果您有需要不同版本库的 Python 包foo,它可以通过破坏系统包中需要旧版本的包来更新版本。barlibbazsudo pip install barlibbazfoo

    假设场景但有真实的包:假设你安装了一个python-matplotlibUbuntu 包,你使用sudo pip. 乍一看,一切都很好,您已经成功构建了所需的时间表。几天后,你发现在中搜索书籍calibre开始不稳定(你无法找到用于查找它的查询的书籍)。花一些时间调试问题后,如果幸运的话,您可以将其定位为两者pyparsing中使用的模块版本的问题。calibrematplotlib

    也就是说,问题sudo pip install matplotlib -U不是以 root 身份执行 PyPI 代码(从安全的角度来看,问题比 with 更严重sudo apt-get install python-matplotlib,但对于典型的开发人员而言并非如此——您甚至可以检查下载的 matplotlib 的 gpg 签名轮子,如果你愿意的话)。

    问题在于,sudo pip难以诊断的问题可能是由为 apt-get 打包的软件包和 PyPI 版本的软件包的预期不匹配引起的。

    这就是为什么应该特别独立的包,例如pip,pkg_resources使用它们的本地副本: <package>._vendor.pyparsing。

    有时你可以采取激进的方法,将每个实用程序放在自己的 virtualenv 中,例如,使用pipx命令:

    $ pipx install youtube-dl
    

    这使您可以在youtube-dl不接触系统上其他软件可能使用的软件包的情况下进行更新。相反,更新其他软件包不会破坏 youtube-dl 命令。

    这种方法的缺点是,在修复依赖项中的安全漏洞时,必须在每个 virtualenv 中单独更新它。

    本质上,通过使用sudo pip,您承担了您安装的所有包版本及其依赖项将与系统包管理器现在和将来安装的包兼容的责任。这通常是像 Ubuntu 这样的 Linux 发行版的创建者的工作——他们确保发行版中分发的包的版本可以相互工作。

    通过安装pip install --user <package>,您不会破坏其他用户启动的程序。通过在 virtualenv 中安装,您可以将系统与可能的更改隔离开来,反之亦然(如果--system-site-packages在创建过程中未指定该选项)将 virtualenv 中的包与系统中的更改隔离开来。

    为了方便管理 virtualenv,你可以virtualenvwrapper把.

    • 16
  3. fellzo
    2020-04-10T20:55:43Z2020-04-10T20:55:43Z

    这不仅适用于 pip,使用 root 权限可能会执行可能损害系统的任意代码。

    如果没有 root 无法安装某些包,那么可能只是错误地设置了 python 包目录的权限

    • 6
  4. gecube
    2020-06-24T07:00:31Z2020-06-24T07:00:31Z

    由于某种原因没有写出正确的答案 -sudo pip当需要将 python 包安装到系统范围的 python 安装时,人们很想使用它。同时,答案中上面写的一切都是真实的——这简直是危险的,你可以混淆系统上安装的 python 版本(通常 python2 和 python3 以及其他版本可以在同一个节点上共存) . 怎样成为?尽管如此,如果无法以任何方式避免 pip,那么对于初学者来说,请明确指出我们使用的是哪个版本的 python:

    python3 -m pip install ...

    或者

    python -m pip install ...

    第二件重要的事情——如果你需要在系统 python 中安装一些东西——而不是pip install严格地建议使用操作系统的内置包管理器。为什么?因为它pip install没有在系统包管理器中规定任何东西,下次你更新系统时,你会得到一个大杂烩的包,或者它们将被简单地重写。

    比如pip install docker我们不在on-debian-based,而是进入apt install python-docker(或者apt install python3-docker如果我们需要在第三个python的环境下安装包)。

    在所有其他情况下,最好考虑通过pip --user install用户的本地环境或虚拟环境安装软件包。

    此外,我可以补充一点,当使用pip install -r requirements.txtREGULARLY 时,会出现一个问题,根据包的安装顺序,pip 可以拖动不同版本的依赖包(例如,A 依赖 B 版本 10,但不高于 11, C 依赖于比 11 更新的 B - 因此我们有比 11 更新的 A、C 和 B 版本)。似乎正在进行工作以确保 pip 学会正确解决依赖关系(根据图表),但它们肯定还没有完成。

    • 0

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    Python 3.6 - 安装 MySQL (Windows)

    • 1 个回答
  • Marko Smith

    C++ 编写程序“计算单个岛屿”。填充一个二维数组 12x12 0 和 1

    • 2 个回答
  • Marko Smith

    返回指针的函数

    • 1 个回答
  • Marko Smith

    我使用 django 管理面板添加图像,但它没有显示

    • 1 个回答
  • Marko Smith

    这些条目是什么意思,它们的完整等效项是什么样的

    • 2 个回答
  • Marko Smith

    浏览器仍然缓存文件数据

    • 1 个回答
  • Marko Smith

    在 Excel VBA 中激活工作表的问题

    • 3 个回答
  • Marko Smith

    为什么内置类型中包含复数而小数不包含?

    • 2 个回答
  • Marko Smith

    获得唯一途径

    • 3 个回答
  • Marko Smith

    告诉我一个像幻灯片一样创建滚动的库

    • 1 个回答
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Алексей Шиманский 如何以及通过什么方式来查找 Javascript 代码中的错误? 2020-08-03 00:21:37 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5