web-dev-qa-db-ja.com

ディレクトリ内の2つの同一ファイルを示す「ls」

したがって、どういうわけか、コマンドlsは、ディレクトリ内の2つの同じファイルを表示しているようです。

$ ls -Blah /System/Library/LaunchDaemons
total 32                                                              
drwxr-xr-x  266 root  wheel   8.8K Jun 18 10:41 .
drwxr-xr-x   79 root  wheel   2.6K Mar 31 12:28 ..
[redacted]
-rw-r--r--    1 root  wheel   715B Jun 18 10:36 tftp.plist
-rw-r--r--    1 root  wheel   715B Jun 18 10:35 tftp.plist

ファイルの1つを移動、名前変更、編集などすることはできますが、もう1つはそこにないようです。 bashタブ補完では、同一のファイルも表示されます。

たとえば、次のように入力してから、 TAB

$ Sudo mv /System/Library/LaunchDaemons/tftp
tftp.plist   tftp.plist

ファイルの名前を変更した場合:

$ Sudo mv /System/Library/LaunchDaemons/tftp.plist /System/Library/LaunchDaemons/tftp.plist.derp

タブ補完はまだファイルを示しています:

$ ls -Blah /System/Library/LaunchDaemons/tf
tftp.plist       tftp.plist.derp 

しかし、元の変更されていないファイルは「ls」に表示されません

$ ls -Blah /System/Library/LaunchDaemons/tftp.plist
ls: /System/Library/LaunchDaemons/tftp.plist: No such file or directory

ただし、上記の最初のコードスニペットのようにファイルをリストするだけの場合は、次のようになります。

$ ls -Blah /System/Library/LaunchDaemons
total 32                                                              
drwxr-xr-x  266 root  wheel   8.8K Jun 18 10:41 .
drwxr-xr-x   79 root  wheel   2.6K Mar 31 12:28 ..
[redacted]
-rw-r--r--    1 root  wheel   715B Jun 18 10:35 tftp.plist
-rw-r--r--    1 root  wheel   715B Jun 18 10:36 tftp.plist.derp

ここで何が起こっているのか、そしてどのようにしてこのゴーストファイルを取り除くことができるのでしょうか?

問題に情報を追加する場合、これはOS Xを実行しているMacです。私は狂気が始まる直前にこのファイルでsedを使用していました。

編集する

blahフラグとBlahlsフラグの両方を使用しましたが、見かけ上の出力に変更はありません。

編集2

コメントでリクエストされた追加情報:

$ echo tftp* | xxd
0000000: 7466 7470 2e70 6c69 7374 2020 7466 7470  tftp.plist  tftp
0000010: 2e70 6c69 7374 2e64 6572 700a            .plist.derp.

もっと:

$ printf '<%q>\n' tftp*
<tftp.plist\ >
<tftp.plist.derp>

さらに:

$ locale                                                                                                                      │-rw-r--r--    1 root  wheel   495B Sep  9  2014 org.net-snmp.snmpd.plist
LANG="en_US.UTF-8"                                                                                                            │-rw-r--r--    1 root  wheel   498B Jan 15 23:15 org.ntp.ntpd.plist
LC_COLLATE="en_US.UTF-8"                                                                                                      │-rw-r--r--    1 root  wheel   1.0K Nov 13  2014 org.openldap.slapd.plist
LC_CTYPE="en_US.UTF-8"                                                                                                        │-rw-r--r--    1 root  wheel   572B Sep  9  2014 org.postfix.master.plist
LC_MESSAGES="en_US.UTF-8"                                                                                                     │-rw-r--r--    1 root  wheel   238B Sep  9  2014 Shell.plist
LC_MONETARY="en_US.UTF-8"                                                                                                     │-rw-r--r--    1 root  wheel   941B Sep  9  2014 ssh.plist
LC_NUMERIC="en_US.UTF-8"                                                                                                      │-rw-r--r--    1 root  wheel   260B Sep  9  2014 telnet.plist
LC_TIME="en_US.UTF-8"                                                                                                         │-rw-r--r--    1 root  wheel   715B Jun 18 10:36 tftp.plist
LC_ALL="en_US.UTF-8"

注意

以下の答えは、名前の後にスペースがあることを理解するのに役立ちました。

14
111---

末尾に空白があるか、ファイルシステムが破損しています。

試す

for i in tftp.plist*
do
    echo "'$i'"
done

それは次のようなものを出力するはずです

'tftp.plist'
'tftp.plist '

引用符と余分なスペースに注意してください。まったく同じものが2回出力される場合は、ファイルシステムが破損している可能性があります。

試す

ls -i tftp.plist*

これにより、ファイルのiノード番号がわかります。それらが同じ場合、ディレクトリに同じファイルが2回あります。それはReally Bad(tm)であり、fsck asapを実行する必要があります。しかし、それが問題だとは思いません。それはおそらく空白のことです。

22
Wouter Verhelst