一、Linux命令的基本格式
1、命令提示符
登录Linux后,我们可以看到如下内容:[root@localhost ~ ]#
这就是Linux系统的命令提示符。其中:
- []:这是提示符的分割符号,没有特殊含义;
- root:显示的是当前的登录用户,使用root用户登录;
- @:分割符号,没有特殊含义;
- localhost:当前系统的简写主机名(完整主机名是:localhost.localdomain);
- ~ :代表用户当前所有目录,~表示用户当前所在的目录是家目录;
- #:命令提示符,如果是超级用户,提示符就是#;如果是普通用户,提示符就是$。
3、命令的基本格式
[root@localhost ~ ]# 命令 [选项] [参数]
- 选项和参数是可选的(空格不可少)
- 选项:用于调节命令的具体功能
- 以 “ - ”引导短格式选项(单个字符),例如 “ -l ”;
- 单个命令,书写简单,两个短格式命令可以写到一起;
- 以“ – ”引导长格式选项(多个字符),例如 “ --color”含义明确;
- 多个短格式选项可以写在一起,只用一个“ - ”引导,例如“ -al ”
- 参数:命令操作的对象,如文件,目录名等
例如:[root@localhost ~ ]# ls -ls /etc
- 命令格式中的[]代表可选项,也就是有些命令可以不写选项或参数,也可以执行;
- 命令的选项用于调整命令功能,而命令的参数是这个命令的操作对象,一般文件、>目录、用户和进程等可以作为参数被命令操作;
注意:
命令编辑的几个辅助操作:
- Tab键:自动补全;
- 反斜杠 “ \ ”:强制换行;
- 快捷键 Ctrl+U:清空至行首;
- 快捷键 Ctrl+K:清空至行尾;
- 快捷键 Ctrl+L:清屏;
- 快捷键 Ctrl+C:取消本次命令编辑;
二、内部命令,外部命令和查看命令的帮助
1、内部命令与外部命令的区别
- 内部命令存在于Linux系统Shell中,而非磁盘中;Shell被Linux系统加载到内存中,内部命令处于随时调用状态,用户可直接使用;
- 外部命令一文件形式存在:通常存放在硬盘中,主要在“/bin,/sbin”等目录中;
- 在Linux系统中绝大多数命令是外部命令;
2.常见的帮助命令
(1)man命令:可以查看命令或配置的帮助信息;
[root@redhat tmp]# man ls
[root@redhat tmp]# man yum.conf
#注:使用man查看配置文件的帮助信息时,不需使用绝对路径,只需要写配置文件名即可
(2)help命令:显示Shell内置命令的帮助信息;
[root@redhat tmp]# which cd
/usr/bin/which: no cd in (/usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/sbin:/sbin:/usr/local/bin:/usr/bin:/bin:/root/bin)
[root@redhat tmp]# help cd
cd: cd [-L|-P] [dir]
Change the shell working directory.
......
#注:使用which命令或者whereis命令查找不到的命令为内部命令
(3)whatis命令:简单查看命令的帮助信息;
[root@redhat tmp]# whatis ls
ls (1) - list directory contents
ls (1p) - list directory contents
(4)apropos命令:简单查看配置文件的帮助信息;
[root@redhat tmp]# apropos yum.conf
yum.conf [yum] (5) - Configuration file for yum(8)
三、Linux常用命令
1、ls命令:显示当前目录下的文件
ls是最常见的目录操作命令,主要是显示目录下的内容。命令的基本信息如下:
- 命令名称:ls
- 所在路径:/bin/ls
- 执行权限:所在用户
- 功能描述:显示目录下的内容
(1)“ -a ”选项:-a选项中的 a 是 all 的意思,也就是显示全部的文件,包含被隐藏的文件。
在Linux中以 “ . ” 开头的文件是隐藏文件,只有通过 “ -a ”选项才能查看。隐藏文件不是为了把文件藏起来不让用户找到,而是为了告诉用户这些文件都是重要的系统文件,如非特殊需求,尽量不要修改文件的内容;
[root@redhat ~]# ls
anaconda-ks.cfg install.log.syslog z 模板 图片 下载 桌面
install.log j 公共的 视频 文档 音乐
[root@redhat ~]# ls -a
. .esd_auth install.log .viminfo
.. .gconf install.log.syslog z
.abrt .gconfd j 公共的
anaconda-ks.cfg .gnome2 .local 模板
[root@redhat ~]#
(2)“ -l ”选项:显示文件的详细信息,包括:权限(所有者,所属组,其他人权限),引用计数,所有者,大小,文件修改时间,文件名:
注:在权限面前:— 表示文件;d 表示目录;l 表示软连接;
关于以上的说明:
- 在权限面前:— 表示文件;d 表示目录;l 表示软连接;
- 链接数:表示引用计数,代表这个文件曾经被调用或者被引用过几次,只在硬链接在使用;
- 在Linux当中每个文件把用户都分为三类:u(user)所有者、g(group)所属组,o(other)其他人。用户的所有者、所属组和其他人指的是用户和文件之间的关系,即这个文件和用户之间它们存在什么样的身份属性。
- 一般情况下,创建该文件的用户为该文件的所有者,所有者只能有一个;所属组是一个用户集合,定义一组用户拥有什么样的权限,所属组也只能有一个;即不是所有者也不是所属组的就为其他人;
[root@root ~]# ls -l
总用量 100
-rw-------. 1 root root 1498 6月 22 19:26 anaconda-ks.cfg
-rw-r--r--. 1 root root 47922 6月 22 19:26 install.log
-rw-r--r--. 1 root root 10033 6月 22 19:23 install.log.syslog
drwxr-xr-x. 2 root root 4096 6月 22 19:30 公共的
drwxr-xr-x. 2 root root 4096 6月 22 19:30 模板
drwxr-xr-x. 2 root root 4096 6月 22 19:30 视频
drwxr-xr-x. 2 root root 4096 6月 22 19:30 图片
drwxr-xr-x. 2 root root 4096 6月 22 19:30 文档
drwxr-xr-x. 2 root root 4096 6月 22 19:30 下载
drwxr-xr-x. 2 root root 4096 6月 22 19:30 音乐
drwxr-xr-x. 3 root root 4096 6月 22 19:43 桌面
(3)“ -d ”选项:“ -l ”选项可以显示目录中每一个文件的详细信息,但是显示不出来目录的详细信息,如果想显示本身的信息,就必须加入“ -d ”选项。
[root@root ~]# ls -ld
dr-xr-x---. 28 root root 4096 6月 30 21:14 .
(4)“ -h ”选项:习惯以人们的习惯显示文件的大小。“ ls -l ”显示的文件大小是字节,但是我们更加习惯的是千字节用KB显示,兆字节用MB显示,而“ -h ”选项就是按照人们习惯的单位显示文件大小的。
[root@root ~]# ls -lh
总用量 100K
-rw-------. 1 root root 1.5K 6月 22 19:26 anaconda-ks.cfg
-rw-r--r--. 1 root root 47K 6月 22 19:26 install.log
-rw-r--r--. 1 root root 9.8K 6月 22 19:23 install.log.syslog
drwxr-xr-x. 2 root root 4.0K 6月 22 19:30 公共的
drwxr-xr-x. 2 root root 4.0K 6月 22 19:30 模板
drwxr-xr-x. 2 root root 4.0K 6月 22 19:30 视频
drwxr-xr-x. 2 root root 4.0K 6月 22 19:30 图片
drwxr-xr-x. 2 root root 4.0K 6月 22 19:30 文档
drwxr-xr-x. 2 root root 4.0K 6月 22 19:30 下载
drwxr-xr-x. 2 root root 4.0K 6月 22 19:30 音乐
drwxr-xr-x. 3 root root 4.0K 6月 22 19:43 桌面
(5)“ -i ”选项:每个文件都有一个被称作 inode (i 字节) 的隐藏属性,可以看成系统搜索这个文件的ID,而“ -i ”选项就是用来查看文件的 inode 号的。
[root@root ~]# ls -i
272222 anaconda-ks.cfg 272242 公共的 272245 图片 272244 音乐
261123 install.log 272241 模板 272243 文档 272239 桌面
261124 install.log.syslog 272246 视频 272240 下载
2、mkdir命令:创建目录(文件夹)
mkdir命令主要功能是创建目录,基本信息如下:
- 命令名称:mkdir
- 所在路径:/bin/mkdir
- 执行权限:所在用户
- 功能描述:创建空目录
(1)创建一个空目录:mkdir 目录名
[root@root ~]# ls /tmp
_cafenv-appconfig_ pulse-h68wANV588jC VMwareDnD
dir1 pulse-HYwFHd4subTQ vmware-root
keyring-CfdIfM virtual-root.4CXsBj vmware-root_1498-2966037825
keyring-hlsUKj virtual-root.INHC9Z vmware-root_1589-2083797903
keyring-lfvBms virtual-root.pFxtSf vmware-root_1594-834905688
orbit-gdm virtual-root.pjI95j vmware-root_18917-1848395183
orbit-root vmware-config-8182.0 yum.log
(2)如果需要建立一系列的新递归目录,则需要加入“ -p ”选项,递归建立才可以进行创建;
[root@root ~]# mkdir /tmp/dirs/dirs1
mkdir: 无法创建目录"/tmp/dirs/dirs1": 没有那个文件或目录
[root@root ~]# mkdir -p /tmp/dirs/dirs1
[root@root ~]# ls /tmp
_cafenv-appconfig_ pulse-h68wANV588jC vmware-root
dir1 pulse-HYwFHd4subTQ vmware-root_1498-2966037825
dirs virtual-root.4CXsBj vmware-root_1589-2083797903
keyring-CfdIfM virtual-root.INHC9Z vmware-root_1594-834905688
keyring-hlsUKj virtual-root.pFxtSf vmware-root_18917-1848395183
keyring-lfvBms virtual-root.pjI95j yum.log
orbit-gdm vmware-config-8182.0
orbit-root VMwareDnD
[root@root ~]# ls /tmp/dirs
dirs1
(3)使用mkdir,可以同时创建多个目录;
[root@root ~]# mkdir /tmp/dirs/yuwen /tmp/dirs/shuxue /tmp/dirs/yingyu
[root@root ~]# ls /tmp/dirs
dirs1 shuxue yingyu yuwen
3、cd命令:切换目录
cd命令的主要功能是切换所在目录,命令的基本信息如下:
- 命令名称:cd
- 所在路径:shell内置命令
- 执行权限:所有用户
- 功能描述:切换所在目录
(1)cd命令用来切换用户工作目录到一个指定的目录下,这个指定目录你可以使用绝对路径或者是相对路径,并且切换目录之后,在前面的提示符中只保留了最近以及目录;
注:绝对路径代表从根目录开始,相对路径代表以当前目录为起点
[root@root ~]# cd /tmp/dirs/yuwen
[root@root yuwen]# cd /etc
[root@root etc]# cd /tmp/dirs/shuxue
[root@root shuxue]#
(2)cd命令可以识别一些特殊符号,用于快速的切换所在目录;
- cd ——>不加任何参数,会切换到登录用户的主目录;
- cd ~ ——>代表home directory(家目录或者用户目录);
- cd - ——>代表上次所在目录;
- cd … ——>代表上级目录;
- cd . ——>代表当前目录;
- cd …/… ——>返回上两级目录;
[root@root shuxue]# cd
[root@root ~]# cd -
/tmp/dirs/shuxue
[root@root shuxue]# cd..
bash: cd..: command not found
[root@root shuxue]# cd ..
[root@root dirs]# cd .
[root@root dirs]# cd ../..
[root@root /]#
4、pwd:显示用户当前的工作目录
pwd命令的主要功能是显示 目录,命令的基本信息如下:
- 命令名称:pwd
- 所在路径:/bin/pwd
- 执行权限:所有用户
- 功能描述:显示当前目录
以绝对路径的形式呈现工作目录:
[root@root 桌面]# cd /etc
[root@root etc]# pwd
/etc
[root@root etc]# pwd
/etc
[root@root etc]# cd /etc/abrt
[root@root abrt]# pwd
/etc/abrt
5、rmdir命令:删除空目录(文件夹)
rmdir命令主要功能是删除目录,基本信息如下:
- 命令名称:rmdir
- 所在路径:/bin/rmdir
- 执行权限:所有用户
- 功能描述:删除空目录
删除一个空目录:rmdir 目录名
[root@root abrt]# ls /tmp/dirs
dirs1 shuxue yingyu yuwen
[root@root abrt]# rmdir /tmp/dirs/yuwen
[root@root abrt]# ls /tmp/dirs
dirs1 shuxue yingyu
注:rmdir命令只能删除空目录,如果目录中有内容,就会报错;所以,不论删除的是文件还是目录,经常使用rm命令。
6、cp命令:复制操作
cp命令的功能是用于复制,基本信息如下:
- 命令名称:cp
- 所在路径:/bin/cp
- 格式:cp [选项] 源文件 目标路径(若没有目标路径,则默认为当前路径)
- 执行权限:所有用户
- 功能描述:复制文件和目录
(1)cp命令复制文件,也可以进行更名复制,如果复制的目录文件存在,则会提示师傅覆盖,因为cp默认执行的是“cp -i”的别名;
[root@root ~]# ls /tmp
_cafenv-appconfig_ pulse-h68wANV588jC vmware-root
dir1 pulse-HYwFHd4subTQ vmware-root_1498-2966037825
dirs virtual-root.4CXsBj vmware-root_1579-2084322198
......
[root@root ~]# cp /etc/grub.conf /tmp
[root@root ~]# ls /tmp
_cafenv-appconfig_ orbit-root VMwareDnD
dir1 pulse-h68wANV588jC vmware-root
dirs pulse-HYwFHd4subTQ vmware-root_1498-2966037825
grub.conf virtual-root.4CXsBj vmware-root_1579-2084322198
......
[root@root ~]# cp /etc/grub.conf /tmp
cp:是否覆盖"/tmp/grub.conf"? yes
[root@root ~]# ls /tmp
_cafenv-appconfig_ orbit-root VMwareDnD
dir1 pulse-h68wANV588jC vmware-root
dirs pulse-HYwFHd4subTQ vmware-root_1498-2966037825
grub.conf virtual-root.4CXsBj vmware-root_1579-2084322198
......
(2)cp 可以一次复制多个文件
[root@root ~]# cp /etc/csh.cshrc /etc/auto.net /tmp/dir1
cp:是否覆盖"/tmp/dir1/csh.cshrc"? y
[root@root ~]# ls /tmp/dir1
auto.net csh.cshrc
(3)-r 选项:递归复制,用于复制目录
[root@root ~]# cp /etc/yum /tmp
cp: 略过目录"/etc/yum"
[root@root ~]# cp -r /etc/yum /tmp
[root@root ~]# ls /tmp
_cafenv-appconfig_ pulse-h68wANV588jC vmware-root_1498-2966037825
dir1 pulse-HYwFHd4subTQ vmware-root_1579-2084322198
dirs virtual-root.4CXsBj vmware-root_1589-2083797903
grub.conf virtual-root.cyXob3 vmware-root_1591-2092251661
keyring-CfdIfM virtual-root.INHC9Z vmware-root_1594-834905688
keyring-hlsUKj virtual-root.pFxtSf vmware-root_18917-1848395183
keyring-lfvBms virtual-root.pjI95j yum
keyring-NPtwuF vmware-config-8182.0 yum.log
orbit-gdm VMwareDnD
orbit-root vmware-root
(4)-p 选项:复制后目标文件保留源文件的属性(包括所有者、所属组、权限和时间)
[root@root ~]# ls -lh /etc/csh.login
-rw-r--r--. 1 root root 794 8月 20 2013 /etc/csh.login
[root@root ~]# cp /etc/csh.login /tmp
[root@root ~]# ls -lh /tmp/csh.login /tmp
-rw-r--r--. 1 root root 794 7月 1 20:50 /tmp/csh.login
[root@root ~]# cp -p /etc/csh.login /tmp
cp:是否覆盖"/tmp/csh.login"? y
[root@root ~]# ls -lh /tmp/csh.login
-rw-r--r--. 1 root root 794 8月 20 2013 /tmp/csh.login
7、mv命令:剪贴和更名
mv命令的功能是用来剪贴和更名的,基本信息如下:
- 命令名称:mv
- 所在路径:/bin/mv
- 语法:mv [原文件或目录] [ 目标目录]
- 执行权限:所有用户
- 功能描述:移动文件或改名
(1)剪贴文件或目录(不需要加 -r)
[root@root ~]# mv /tmp/csh.login /root
[root@root ~]# mv /tmp/dir1 /root
[root@root ~]# ls /root
anaconda-ks.cfg dir1 install.log.syslog 模板 图片 下载 桌面
csh.login install.log 公共的 视频 文档 音乐
(2)剪贴的同时进行改名
[root@root ~]# mv /root/dir1 /root/mv_dir
[root@root ~]# ls /root
anaconda-ks.cfg install.log mv_dir 模板 图片 下载 桌面
csh.login install.log.syslog 公共的 视频 文档 音乐
(3)使用“ -v ”选项来查看详细的移动信息
[root@root tmp]# mv -v grub.conf /root/
"grub.conf" -> "/root/grub.conf"
8、rm命令:删除文件或目录
rm命令不仅可以删除文件,也可以删除目录。命令的基本信息如下:
- 命令名称:rm
- 所在路径:/bin/rm
- 执行权限:所有用户
- 功能描述:删除文件或目录
(1)删除文件,rm文件名;rm命令默认执行的是 “ rm -i ” 命令,所以会提示是否删除;
[root@root tmp]# rm yum.log
rm:是否删除普通空文件 "yum.log"?y
(2)删除多个文件时,如果不想进行提示,可以强制删除,使用 -f 参数;
[root@root tmp]# ls
auto.net keyring-NPtwuF vmware-config-8182.0
auto.net~ orbit-gdm VMwareDnD
dirs pulse-h68wANV588jC vmware-root_1498-2966037825
grub.conf pulse-HYwFHd4subTQ vmware-root_1579-2084322198
grub.conf~ virtual-root.4CXsBj vmware-root_1589-2083797903
[root@root tmp]# rm auto.net grub.conf
rm:是否删除普通文件 "auto.net"?n
rm:是否删除普通文件 "grub.conf"?n
[root@root tmp]# rm -f auto.net grub.conf
[root@root tmp]# ls
auto.net~ orbit-root vmware-root
dirs pulse-HYwFHd4subTQ vmware-root_1579-2084322198
grub.conf~ virtual-root.4CXsBj vmware-root_1589-2083797903
(3)删除目录,需要加入 -r 选项,如果要删除的目录下面有很多子文件时,可以强制删除,否则就会一直提示是否删除该文件;
[root@root tmp]# rm -r etc
rm:是否进入目录"etc"? y
rm:是否进入目录"etc/iproute2"? y
rm:是否删除普通文件 "etc/iproute2/rt_dsfield"?^C
[root@root tmp]#
[root@root tmp]# rm -rf etc
[root@root tmp]# ls
auto.net~ orbit-root vmware-root
_cafenv-appconfig_ pulse-h68wANV588jC vmware-root_1498-2966037825
dirs pulse-HYwFHd4subTQ vmware-root_1579-2084322198
grub.conf~ virtual-root.4CXsBj vmware-root_1589-2083797903
grub_copy.conf virtual-root.cyXob3 vmware-root_1591-2092251661
keyring-CfdIfM virtual-root.INHC9Z vmware-root_1594-834905688
keyring-hlsUKj virtual-root.pFxtSf vmware-root_18917-1848395183
keyring-lfvBms virtual-root.pjI95j yum
keyring-NPtwuF vmware-config-8182.0
orbit-gdm VMwareDnD
9、touch命令:创建空文件或修改文件的时间戳
touch命令的作用是创建空文件或修改文件的时间戳,命令的基本信息如下:
- 命令名称:touch
- 所在路径:/bin/touch
- 执行权限:所有用户
- 功能描述:创建空文件或修改文件的时间戳
如果文件不存在,则会建立空文件;如果文件已经存在,则会修改文件的时间戳(“ 访问时间,数据修改时间,状态修改时间 ” 都会改变)
[root@root 桌面]# touch test
[root@root 桌面]# ls -l test
-rw-r--r--. 1 root root 0 7月 1 22:28 test
[root@root 桌面]# touch test
[root@root 桌面]# ls -l test
-rw-r--r--. 1 root root 0 7月 1 22:31 test
10、cat命令:显示文件内容
- 命令名称:cat
- 所在路径:/bin/cat
- 执行权限:所在用户
- 功能描述:显示文件内容
cat命令可以显示文件的内容,也可以给内容加上行号(-n),不管文件内容多少,都会一次的显示,当文件内容比较长时,就不适合用cat命令显示,因为cat命令显示最后一屏的内容,不能看到前面的内容;
[root@root tmp]# cat /etc/issue
Red Hat Enterprise Linux Server release 6.5 (Santiago)
Kernel \r on an \m
[root@root tmp]# cat -n /etc/issue
1 Red Hat Enterprise Linux Server release 6.5 (Santiago)
2 Kernel \r on an \m
3
11、more命令:分页显示文件内容
当文件过大时,cat命令就不适合适用,就可以使用more命令分屏显示文件内容;基本信息如下:
- 命令名称:more
- 所在路径:/bin/more
- 执行权限:所有用户
- 描述功能:分屏显示文件内容
more命令可以分屏显示文件内容,进入more命令的浏览器以后,可以使用空格(或f键)进行翻页,使用enter进行换行,q退出浏览;但是使用more命令浏览文件内容时,浏览器的内容不能再次查看,只能向下翻页,不能向上翻页;
[root@root tmp]# more /etc/services
# /etc/services:
# $Id: services,v 1.48 2009/11/11 14:32:31 ovasik Exp $
#
.......
# http://www.iana.org/assignments/port-numbers
--More--(0%)
12、less命令:分页显示文件内容(可向上向下翻页)
当文件过大时,使用less命令分屏显示文件内容,可向上向下翻页。基本信息如下:
- 命令名称:less
- 所在路径:/bin/less
- 执行权限:所有用户
- 功能描述:分屏显示文件内容(可向上向下翻页)
less命令可以分屏显示文件内容,进入less命令的浏览器状态以后,可以使用空格(或f)进行翻页,上箭头向上查看,使用enter进项换行,q退出浏览器,除此之外,还可以进行搜索,格式:/搜索内容,搜索的内容就会被标记出来,可以按n进行下一次查找;
[root@root tmp]# less /etc/services
# unfortunately the poppassd (Eudora) uses a port which has already
# been assigned to a different service. We list the poppassd as an
# alias here. This should work for programs asking for this service.
# (due to a bug in inetd the 3com-tsmux line is disabled)
......
:
13、head命令:显示文件前几行的内容
head是用来显示文件的命令,基恩信息如下:
- 命令名称:head
- 所在路径:/usr/bin/head
- 执行权限:所有用户
- 功能描述:显示文件开头的内容
(1)head命令默认显示文件的前10行,-n 参数可以指定具体的行数;
[root@root 桌面]# cd /tmp
[root@root tmp]# head /etc/services
# /etc/services:
# $Id: services,v 1.48 2009/11/11 14:32:31 ovasik Exp $
#
# Network services, Internet style
# IANA services version: last updated 2009-11-10
#
# Note that it is presently the policy of IANA to assign a single well-known
# port number for both TCP and UDP; hence, most entries here have two entries
# even if the protocol doesn't support UDP operations.
# Updated from RFC 1700, ``Assigned Numbers'' (October 1994). Not all ports
[root@root tmp]# head -n 4 /etc/services
# /etc/services:
# $Id: services,v 1.48 2009/11/11 14:32:31 ovasik Exp $
#
# Network services, Internet style
(2)-v 参数可以显示文件名;
[root@root tmp]# head -v -n 4 /etc/services
==> /etc/services <==
# /etc/services:
# $Id: services,v 1.48 2009/11/11 14:32:31 ovasik Exp $
#
# Network services, Internet style
14、tail命令:显示文件后几行的内容
tail 命令的基本信息如下:
- 命令名称:tail
- 所在路径:/usr/bin/tail
- 执行权限:所有用户
- 功能描述:显示文件后几行的内容
(1)tail 命令默认显示文件的后10行,-n 参数可以指定具体的行数;-v 参数可以显示文件名;
[root@root tmp]# tail -n 4 /etc/services
com-bardac-dw 48556/tcp # com-bardac-dw
com-bardac-dw 48556/udp # com-bardac-dw
iqobject 48619/tcp # iqobject
iqobject 48619/udp # iqobject
[root@root tmp]# tail -v -n 4 /etc/services
==> /etc/services <==
com-bardac-dw 48556/tcp # com-bardac-dw
com-bardac-dw 48556/udp # com-bardac-dw
iqobject 48619/tcp # iqobject
iqobject 48619/udp # iqobject
(2)选项 -f 可以动态显示文件末尾的内容
15、ln命令:生成连接文件
ln命令的基本信息如下:
- 命令名称:ln
- 所在路径:/bin/ln
- 执行权限:所有用户
- 功能描述:在文件之间建立链接
(1)软链接:类似于Windows快捷方式,是一个符号链接,便于管理和规划,而且软链接的权限是rwxrwxrwx,权限前面是 | ,除此之外,软连接很小(类似于快捷方式),而且有箭头会指向原文件;如果原文件被删除,软链接就会失效(显示没有这个文件或目录);
[root@root 桌面]# ln -s /etc/issue /tmp/issue_soft
[root@root 桌面]# ls -l /etc/issue
-rw-r--r--. 1 root root 75 10月 30 2013 /etc/issue
[root@root 桌面]# ls -l /tmp/issue_soft
lrwxrwxrwx. 1 root root 10 7月 2 10:28 /tmp/issue_soft -> /etc/issue
(2)硬链接:硬链接于原文件出来所在文件夹信息不同,其他任何信息都相同,类似于保存了文件属性的拷贝,但也有不同,硬链接可以与原文件保持同步更新,如果原文件被删除了,硬链接文件依然可以访问,不受影响;
[root@redhat 桌面]# ln /etc/issue /tmp/issue_hard
[root@redhat 桌面]# ls -l /etc/issue
-rw-r--r--. 2 root root 75 10月 30 2013 /etc/issue
[root@redhat 桌面]# ls -l /tmp/issue_hard
-rw-r--r--. 2 root root 75 10月 30 2013 /tmp/issue_hard
(3)软链接与原文件的 i 结点不同,但是硬链接文件与原文件的 i 结点相同;一个文件只有一个 i 结点,但是一个 i 结点不一定只对应一个文件;
[root@redhat 桌面]# ls -i /etc/issue /tmp/issue_hard /tmp/issue_soft
54395563 /etc/issue 54395563 /tmp/issue_hard 38273166 /tmp/issue_soft
(4)硬链接不能跨分区,也不能针对目录使用
[root@redhat 桌面]# ln /etc/issue /boot/issue_hard
ln: 创建硬链接"/boot/issue_hard" => "/etc/issue": 无效的跨设备连接
[root@redhat 桌面]# ln -s /etc/issue /boot/issue_soft
[root@redhat 桌面]# ls -l /boot/issue_soft
lrwxrwxrwx. 1 root root 10 3月 24 02:07 /boot/issue_soft -> /etc/issue
[root@redhat 桌面]# ln /etc /tmp/issue_hard
ln: "/etc": 不允许将硬链接指向目录
[root@redhat 桌面]# ln -s /etc /tmp/etc_soft
[root@redhat 桌面]# ls -l /tmp/etc_soft
lrwxrwxrwx. 1 root root 4 3月 24 02:10 /tmp/etc_soft -> /etc