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

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

新規登録して質問してみよう
ただいま回答率
85.50%
bash

bash(Bourne-again-Shell)は sh(Bourne Shell)のインプリメンテーションに様々な機能が追加されたシェルです。LinuxやMac OS XではBashはデフォルトで導入されています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

Ubuntu

Ubuntuは、Debian GNU/Linuxを基盤としたフリーのオペレーティングシステムです。

Q&A

解決済

1回答

769閲覧

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

退会済みユーザー

退会済みユーザー

総合スコア0

bash

bash(Bourne-again-Shell)は sh(Bourne Shell)のインプリメンテーションに様々な機能が追加されたシェルです。LinuxやMac OS XではBashはデフォルトで導入されています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

Ubuntu

Ubuntuは、Debian GNU/Linuxを基盤としたフリーのオペレーティングシステムです。

0グッド

0クリップ

投稿2019/06/30 00:44

編集2019/06/30 01:59

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 を探しにいって、「見つからない」とエラーになります。

bash

1root@ubuntu:~# /opt/python3.7.3/bin/python3.7 -V 2Python 3.7.3 3 4root@ubuntu:~# ls -l /usr/local/bin/ | grep python 5lrwxrwxrwx 1 root root 30 Jun 30 09:11 python3 -> /opt/python3.7.3/bin/python3.7 6 7root@ubuntu:~# ls -l /usr/bin/ | grep python 8lrwxrwxrwx 1 root root 30 Jun 30 09:10 python3 -> /opt/python3.7.3/bin/python3.7 9 10root@ubuntu:~# echo $PATH 11/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin 12 13root@ubuntu:~# rm /usr/bin/python3 14 15root@ubuntu:~# which python3 16/usr/local/bin/python3 17 18root@ubuntu:~# python3 19bash: /usr/bin/python3: No such file or directory

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

bash

1docker-man:~$ docker -v 2Docker version 18.09.2, build 6247962 3 4root@ubuntu:~# cat /etc/os-release 5NAME="Ubuntu" 6VERSION="18.04.2 LTS (Bionic Beaver)" 7ID=ubuntu 8ID_LIKE=debian 9PRETTY_NAME="Ubuntu 18.04.2 LTS" 10VERSION_ID="18.04" 11HOME_URL="https://www.ubuntu.com/" 12SUPPORT_URL="https://help.ubuntu.com/" 13BUG_REPORT_URL="https://bugs.launchpad.net/ubuntu/" 14PRIVACY_POLICY_URL="https://www.ubuntu.com/legal/terms-and-policies/privacy-policy" 15VERSION_CODENAME=bionic 16UBUNTU_CODENAME=bionic 17 18root@ubuntu:~# echo $SHELL 19/bin/bash

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

bash

1root@ubuntu:~# hash -l 2builtin hash -p /usr/bin/python3 python3 3 4root@ubuntu:~# python3 5bash: /usr/bin/python3: No such file or directory 6 7root@ubuntu:~# hash -r 8 9root@ubuntu:~# python3 -V 10Python 3.7.3

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

bash

1root@ubuntu:/Python-3.7.3# /opt/python3.7.3/bin/python3.7 -V 2Python 3.7.3 3 4root@ubuntu:/Python-3.7.3# echo $PATH 5/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin 6 7root@ubuntu:/Python-3.7.3# ln -s /opt/python3.7.3/bin/python3.7 /usr/local/bin/python3 8root@ubuntu:/Python-3.7.3# ls -l /usr/local/bin | grep python 9lrwxrwxrwx 1 root root 30 Jun 30 10:45 python3 -> /opt/python3.7.3/bin/python3.7 10 11root@ubuntu:/Python-3.7.3# ls -l /usr/bin/ | grep python 12lrwxrwxrwx 1 root root 9 Oct 25 2018 python3 -> python3.6 13 14root@ubuntu:/Python-3.7.3# which python3 15/usr/bin/python3 16 17root@ubuntu:/Python-3.7.3# rm /usr/bin/python3 18 19root@ubuntu:/Python-3.7.3# which python3 20/usr/local/bin/python3 21 22root@ubuntu:/Python-3.7.3# python3 -V 23bash: /usr/bin/python3: No such file or directory 24 25root@ubuntu:/Python-3.7.3# shopt -s checkhash 26 27root@ubuntu:/Python-3.7.3# python3 -V 28Python 3.7.3

気になる質問をクリップする

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

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

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

投稿2019/06/30 01:01

otn

総合スコア84423

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2019/06/30 01:09 編集

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

2019/06/30 01:22

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

退会済みユーザー

2019/06/30 01:31

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問