質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.93%

環境変数PATHが左から参照されない?

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 682
退会済みユーザー

退会済みユーザー

Linuxの環境変数PATHは左から順に優先される認識でおりました。
反例となる以下の事象に出くわしたため、なぜ以下の挙動となるのか、是非教えて頂けないでしょうか。
環境情報は末尾に記載しております。

  1. Python3.7.3をソースコードからビルドし、 /opt 配下にインストールしました。
  2. シンボリックリンクが /usr/local/bin にあることを確認しました。
  3. シンボリックリンクが /usr/bin にあることを確認しました。
  4. PATHを表示し、 /usr/local/bin => /usr/bin の順に参照されると考えました。
  5. /usr/bin のシンボリックリンクを削除しました。
  6. python3 コマンドは /usr/local/bin を参照しています。
  7. 実際に python3 を実行すると、なぜか /usr/bin を探しにいって、「見つからない」とエラーになります。
root@ubuntu:~# /opt/python3.7.3/bin/python3.7 -V
Python 3.7.3

root@ubuntu:~# ls -l /usr/local/bin/ | grep python
lrwxrwxrwx 1 root root 30 Jun 30 09:11 python3 -> /opt/python3.7.3/bin/python3.7

root@ubuntu:~# ls -l /usr/bin/ | grep python
lrwxrwxrwx 1 root root        30 Jun 30 09:10 python3 -> /opt/python3.7.3/bin/python3.7

root@ubuntu:~# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

root@ubuntu:~# rm /usr/bin/python3

root@ubuntu:~# which python3
/usr/local/bin/python3

root@ubuntu:~# python3
bash: /usr/bin/python3: No such file or directory

環境情報:
UbuntuはDockerコンテナ上で動いているものです。DockerはMac Docker Desktopを使用しています。
Docker Desktop: Version 2.0.0.3 (31259)

docker-man:~$ docker -v
Docker version 18.09.2, build 6247962

root@ubuntu:~# cat /etc/os-release
NAME="Ubuntu"
VERSION="18.04.2 LTS (Bionic Beaver)"
ID=ubuntu
ID_LIKE=debian
PRETTY_NAME="Ubuntu 18.04.2 LTS"
VERSION_ID="18.04"
HOME_URL="https://www.ubuntu.com/"
SUPPORT_URL="https://help.ubuntu.com/"
BUG_REPORT_URL="https://bugs.launchpad.net/ubuntu/"
PRIVACY_POLICY_URL="https://www.ubuntu.com/legal/terms-and-policies/privacy-policy"
VERSION_CODENAME=bionic
UBUNTU_CODENAME=bionic

root@ubuntu:~# echo $SHELL
/bin/bash

otnさんよりご教授頂きキャッシュをクリアしてみると、無事現在のPATHが参照されるようになりました。

root@ubuntu:~# hash -l
builtin hash -p /usr/bin/python3 python3

root@ubuntu:~# python3
bash: /usr/bin/python3: No such file or directory

root@ubuntu:~# hash -r

root@ubuntu:~# python3 -V
Python 3.7.3

さらにotnさんよりご教授頂き、bashの checkhash を設定すると上記の事象が発生しないか確かめてみました。
先ほどのDockerコンテナを破棄して新しいコンテナを作成し、同じ状態まで進めた段階で以下を実行しています。

root@ubuntu:/Python-3.7.3# /opt/python3.7.3/bin/python3.7 -V
Python 3.7.3

root@ubuntu:/Python-3.7.3# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

root@ubuntu:/Python-3.7.3# ln -s /opt/python3.7.3/bin/python3.7 /usr/local/bin/python3
root@ubuntu:/Python-3.7.3# ls -l /usr/local/bin | grep python
lrwxrwxrwx 1 root root 30 Jun 30 10:45 python3 -> /opt/python3.7.3/bin/python3.7

root@ubuntu:/Python-3.7.3# ls -l /usr/bin/ | grep python
lrwxrwxrwx 1 root root         9 Oct 25  2018 python3 -> python3.6

root@ubuntu:/Python-3.7.3# which python3
/usr/bin/python3

root@ubuntu:/Python-3.7.3# rm /usr/bin/python3

root@ubuntu:/Python-3.7.3# which python3
/usr/local/bin/python3

root@ubuntu:/Python-3.7.3# python3 -V
bash: /usr/bin/python3: No such file or directory

root@ubuntu:/Python-3.7.3# shopt -s checkhash

root@ubuntu:/Python-3.7.3# python3 -V
Python 3.7.3
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+4

シェルがコマンドの位置(フルパス)をキャッシュしています。

Bashだと、hash -lでその状況が分かります。
キャッシュクリアは、hash -rです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/06/30 10:08 編集

    早速のご回答、誠にありがとうございます。
    キャッシュ機能があるとは知りませんでした!
    とても勉強になりました。ありがとうございます。

    キャンセル

  • 2019/06/30 10:22

    なんかオプションがあったはずだとman bashを見ると、
    shopt -s checkhash
    しておくと、ハッシュしたファイルが見つからない場合は、PATHを探索し直すようです。

    キャンセル

  • 2019/06/30 10:31

    manual確認しました。そのようですね。
    ご教授ありがとうございます。

    キャンセル

  • 2019/06/30 12:04

    +10

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.93%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る