Mac で root として pip を実行すると「アクセスが拒否されました」というメッセージが表示される 質問する

Mac で root として pip を実行すると「アクセスが拒否されました」というメッセージが表示される 質問する

私は職場のWindows PCと同じようにMacにPythonパッケージをインストールし始めましたが、Macでは頻繁に次のような問題に遭遇しました。許可が拒否されましたログ ファイルまたはサイト パッケージへの書き込み中にエラーが発生しました。

pip install <package>したがって、実行を検討しましたsudoが、現在のユーザー アカウントでインストールしたいだけなので、sudo の使用は安全/許容できるでしょうか?

ログファイル I/O エラーからのトレースバックの例:

Command /usr/bin/python -c "import setuptools;__file__='/Users/markwalker/build/pycrypto/setup.py';exec(compile(open(__file__).read().replace('\r\n', '\n'), __file__, 'exec'))" install --single-version-externally-managed --record /var/folders/tq/hy1fz_4j27v6rstzzw4vymnr0000gp/T/pip-k6f2FU-record/install-record.txt failed with error code 1 in /Users/markwalker/build/pycrypto
Storing complete log in /Users/markwalker/Library/Logs/pip.log
Traceback (most recent call last):
  File "/usr/local/bin/pip", line 8, in <module>
    load_entry_point('pip==1.1', 'console_scripts', 'pip')()
  File "/Library/Python/2.7/site-packages/pip-1.1-py2.7.egg/pip/__init__.py", line 116, in main
    return command.main(args[1:], options)
  File "/Library/Python/2.7/site-packages/pip-1.1-py2.7.egg/pip/basecommand.py", line 141, in main
    log_fp = open_logfile(log_fn, 'w')
  File "/Library/Python/2.7/site-packages/pip-1.1-py2.7.egg/pip/basecommand.py", line 168, in open_logfile
    log_fp = open(filename, mode)
IOError: [Errno 13] Permission denied: '/Users/markwalker/Library/Logs/pip.log'

アップデートこれはおそらく権限によるものですが、最善の方法は Python プロジェクトに仮想環境を使用することです。sudo pip絶対に必要な場合を除き、実行は避けてください。

ベストアンサー1

使う仮想環境:

$ virtualenv myenv
.. some output ..
$ source myenv/bin/activate
(myenv) $ pip install what-i-want

sudoグローバルなシステム全体の Python インストール用にインストールする場合にのみ、昇格された権限を使用します。

パッケージを分離する仮想環境を使用するのが最適です。そうすれば、グローバル Python インストールを汚染することなく、自由に操作できます。

ボーナスとして、virtualenv には昇格された権限は必要ありません。

おすすめ記事