Answers:
只需使用namei:
$ namei d
f: d
 l d -> c
   l c -> b
     l b -> a
       d a
ls。谢谢!
                    readlink -e <link>
readlink [选项] ...文件
- -e,--
canonicalize -existing canonicalize通过递归跟随给定名称的每个组件中的每个符号链接,所有组件必须存在
$ mkdir testlink
$ cd testlink
pjb@pjb-desktop:~/testlink$ ln -s c b
pjb@pjb-desktop:~/testlink$ ln -s b a
pjb@pjb-desktop:~/testlink$ ls -l 
total 0
lrwxrwxrwx 1 pjb pjb 1 2010-02-23 08:48 a -> b
lrwxrwxrwx 1 pjb pjb 1 2010-02-23 08:48 b -> c
pjb@pjb-desktop:~/testlink$ echo foo > c
pjb@pjb-desktop:~/testlink$ cat a
foo
pjb@pjb-desktop:~/testlink$ readlink -e a
/home/pjb/testlink/c
注意:readlink a本身返回b
注意#2:与find -l一起使用,可以很容易地用perl编写列出链的实用程序,但它也必须足够聪明以检测循环
如果您有循环,readlink将不会输出任何内容。我想这比卡住好。
pjb@pjb-desktop:~/testlink$ ln -sf a c
pjb@pjb-desktop:~/testlink$ ls -l 
total 0
lrwxrwxrwx 1 pjb pjb 1 2010-02-23 08:48 a -> b
lrwxrwxrwx 1 pjb pjb 1 2010-02-23 08:48 b -> c
lrwxrwxrwx 1 pjb pjb 1 2010-02-23 09:03 c -> a
pjb@pjb-desktop:~/testlink$ readlink -e a
pjb@pjb-desktop:~/testlink$ # (note: no output)
brew install coreutils和greadlink -e <link>
                    这是Bash中的递归函数:
chain() { export chain; local link target; if [[ -z $chain ]]; then chain="$1"; fi; link=$(stat --printf=%N $1); while [[ $link =~ \-\> ]]; do target="${link##*\`}"; target="${target%\'}"; chain+=" -> $target"; chain "$target"; return; done; echo "$chain"; unset chain; }
在多行中:
chain() {
    export chain
    local link target
    if [[ -z $chain ]]
    then
        chain="$1"
    fi
    link=$(stat --printf=%N "$1")
    while [[ $link =~ \-\> ]]
    do
        target="${link##*\`}"
        target="${target%\'}"
        chain+=" -> $target"
        if [[ ! $target =~ / && $1 =~ / ]]
        then
            target="${1%/*}/$target"
        fi
        chain "$target"
        return
    done
    echo "$chain"
    unset chain
}
例子:
$ chain d
d -> c -> b -> a
$ chain c
c -> b -> a
$ chain a
a
它要求stat(1)某些系统上可能不存在该功能。
如果名称包含反引号,单引号或“->”,它将失败。它陷入了一个具有symlink循环的循环中(可以使用Bash 4中的关联数组来解决)。它导出一个称为“链”的变量,而不管其是否已被使用。
可能还有其他问题。
编辑:
修复了一些相对符号链接的问题。有些仍然不起作用,但是下面的版本不需要链接的目标存在。
添加了使用readlink的版本:
chain ()
{
    export chain;
    local target;
    if [[ -z $chain ]]; then
        chain="$1";
    fi;
    target=$(readlink "$1");
    while [[ $target ]]; do
        chain+=" -> $target";
        if [[ ! $target =~ / && $1 =~ / ]]
        then
            target="${1%/*}/$target"
        fi
        chain "$target";
        return;
    done;
    echo "$chain";
    unset chain
}
readlink似乎并没有显示出来。Ubuntu上的Java是:/usr/bin/java -> /etc/alternatives/java -> /usr/lib/jvm/java-6-openjdk/jre/bin/java