Linux新手学习资料一篇(3)

符号链接

 

 

实际上,符号链接(symbolic link,或“symlinks”)比硬链接更常用到。符号链接是一种专门的文件类型,在这种文件类型中,链接通过名称引用另一个文件,而不是直接引用索引节点。符号链接不阻止文件被删除;如果目标文件消失,那么符号链接仅仅是不可用,或“被破坏”。

 

通过将 -s 选项传给 ln,可以创建符号链接。

 

 

$ ln -s secondlink thirdlink

$ ls -l firstlink secondlink thirdlink

-rw-rw-r-- 2 agriffis agriffis 0 Dec 31 19:

08 firstlink

-rw-rw-r-- 2 agriffis agriffis 0 Dec 31 19:

08 secondlink

lrwxrwxrwx 1 agriffis agriffis 10 Dec 31 19:

39 thirdlink -> secondlink

 

 

在 ls -l 输出中,可以用三种方式区分符号链接和一般文件。第一,请注意第一栏包含一个 l 字符的输出表明是符号链接。第二,符号链接的大小是目标文件(本例是 secondlink)的字符数。第三,输出的最后一栏显示目标文件名。

 

符号链接通常比硬链接更灵活。您可以给任何类型的文件系统对象(包括目录)创建符号链接。又因为符号链接的实现是基于路径的(而不是索引节点),所以创建指向另一个文件系统上的对象的符号链接是完全可行的。但是,这一事实也使符号链接理解起来很复杂。请考虑我们想要在/tmp中创建一个指向 /usr/local/bin的链接的情况。我们应该输入:

 

 

$ ln -s /usr/local/bin bin1

$ ls -l bin1

lrwxrwxrwx 1 root root 14 Jan 1 15:

42 bin1 -> /usr/local/bin

 

 

或者还可以输入:

 

 

$ ln -s ../usr/local/bin bin2

$ ls -l bin2

lrwxrwxrwx 1 root root 16 Jan 1 15:

43 bin2 -> ../usr/local/bin

 

 

您可以看到,两个符号链接都指向同一目录。但是,如果我们的第二个符号链接在任何时刻被移动到另一个目录,由于相对路径的缘故,它将遭到“破坏”。

 

 

$ ls -l bin2

lrwxrwxrwx 1 root root 16 Jan 1 15:

43 bin2 -> ../usr/local/bin

$ mkdir mynewdir

$ mv bin2 mynewdir

$ cd mynewdir

$ cd bin2

bash: cd: bin2: No such file or directory

 

 

因为/tmp/usr/local/bin这个目录不存在,我们不能再把目录转到bin2;换句话说,bin2 现在被破坏了。

 

由于这个原因,有时避免用相对路径信息来创建符号链接是个好主意。但是,在许多情况下,相对的符号链接很管用。请考虑一个示例,在这个示例中您想要给 /usr/bin 中的一个程序创建一个别名:

 

 

# ls -l /usr/bin/keychain

-rwxr-xr-x 1 root root 10150 Dec 12 20:09 /usr/bin/keychain

 

 

作为 root 用户,您可能想要给“keychain”创建一个别名,比如“kc”。在这个示例中,我们有 root 访问权,由 bash 提示符改变为“#”可以证明。我们之所以需要 root 访问权是因为一般用户不能在 /usr/bin 中创建文件。作为 root 用户,我们可以像下面这样给 keychain 创建一个别名:

 

 

# cd /usr/bin

# ln -s /usr/bin/keychain kc

 

 

当这个解决方法起作用时,如果我们想要把两个文件都移到 /usr/local/bin 时,它将会出现问题。

 

 

# mv /usr/bin/keychain

/usr/bin/kc /usr/local/bin

 

 

因为在符号链接中,我们使用了绝对路径,而我们的kc符号链接仍然指向/usr/bin/keychain,它已不存在了——另一个被破坏的符号链接。符号链接中的相对路径和绝对路径都各具优点,您应该使用适合于您的特殊应用的路径类型。一般情况下,相对路径或绝对路径都能工作得很好。在这种情况下,下面的示例将起作用:

 

# cd /usr/bin

# ln -s keychain kc

# ls -l kc

lrwxrwxrwx 1 root root 8 Jan 5 12:

40 kc -> keychain

 

 

rm

 

既然我们知道怎样使用 cp、mv 和 ln,现在我们该学习怎样把对象从文件系统中删除了。通常,这用 rm 命令来完成。要删除文件,只需在命令行中指定它们:

 

 

$ cd /tmp

$ touch file1 file2

$ ls -l file1 file2

-rw-r--r-- 1 root root 0 Jan 1 16:41 file1

-rw-r--r-- 1 root root 0 Jan 1 16:41 file2

$ rm file1 file2

$ ls -l file1 file2

ls: file1: No such file or directory

ls: file2: No such file or directory

 

 

rmdir

 

要删除目录,您有两种选择。您可以删除目录中所有的对象,然后使用 rmdir 来删除目录本身:

 

 

$ mkdir mydir

$ touch mydir/file1

$ rm mydir/file1

$ rmdir mydir

 

 

rm 和目录

 

或者,您可以使用 rm 命令的 recursive force选项来告诉rm删除您指定的目录以及目录中包含的所有对象:

 

 

$ rm -rf mydir

 

 

一般情况下,rm -rf 是删除目录树的首选方法。在使用 rm -rf 时要十分小心,因为它的功能可以被很好地利用,也可能会因使用不当造成恶果。

 

介绍通配符

 

在您日常的 Linux 使用中,有很多时候您可能需要一次对多个文件系统对象执行单一操作(比如 rm)。在这些情况下,在命令行中输入许多文件通常让人感到厌烦,为了解决这个问题,您可以利用 Linux 内置的通配符支持。这种支持也叫做“globbing”(由于历史原因),允许您通过使用通配符模式一次指定多个文件。

 

Bash 和其它 Linux 命令将通过在磁盘上查找并找到任何与之匹配的文件来解释这种模式。因此,如果在当前工作目录中,您有从 file1 到 file8 的文件,那么您可以输入下面的命令来删除这些文件:

 

 

$ rm file[1-8]

 

 

或者,如果您只想要删除文件名以 file 开头的所有文件,您可以输入:

 

 

$ rm file*

 

 

理解不匹配

 

或者,如果您想要列出 /etc 中以 g 开头的所有文件系统对象,您可以输入:

 

 

$ ls -d /etc/g*

/etc/gconf /etc/ggi /etc/gimp /etc/gnome

/etc/gnome-vfs-mime-magic /etc/gpm

/etc/group /etc/group-

 

 

现在,如果您指定了没有任何文件系统对象与之匹配的模式,会怎么样呢?在下面的示例中,我们试图列出 /usr/bin 中以 asdf 开头并且以 jkl 结尾的所有文件:

 

 

$ ls -d /usr/bin/asdf*jkl

ls: /usr/bin/asdf*jkl:

No such file or directory

 

 

这里是对所发生情况的说明。通常,当我们指定一种模式时,该模式与底层系统上的一个或多个文件匹配,bash 以空格隔开的所有匹配对象的列表来替换该模式。

 

但是,当模式不能找到匹配对象时,bash 将不理会参数、通配符等等,保留原样。因此,当“ls”不能找到文件 /usr/bin/asdf*jkl 时,它会报错。此处的有效的规则是:glob 模式只在与文件系统中的对象匹配时才可以进行扩展。

posted @ 2012-02-29 23:17  福。oO  阅读(128)  评论(0编辑  收藏  举报