『学了就忘』Linux基础命令 — 37、Linux中挂载操作的相关命令
挂载就是把设备文件名和已经建立的空目录链接起来的过程,就叫做挂载。
1、mount命令介绍
(1)mount命令说明
Linux系统中所有存储设备都必须挂载才能使用,包括硬盘。
- 命令名称:
mount
- 命令所在路径:
/bin/mount
- 执行权限:所有用户
mount
命令的使用示例:
# 查询系统中已经挂我的设备,-l会显示卷标名称
[root@localhost ~]# mount [-l]
(2)mount命令格式
[root@localhost ~]# mount [-t 文件系统] [-L卷标名] [-o特殊选项] 设备文件名 挂载点
# 注意:在Linux系统中\ 的意思表示换行符, 代表上边两行是一行内容。
选项:
-t文件系统:加入文件系统类型来指定挂载的类型,可以ext3、ext4、iso9660等文件系统。(不写也没事,Linux系统默认光盘U盘都能自动识别)。
-L卷标名:挂载指定卷标的分区,而不是安装设备文件名挂载。(现在基本上用不到了,可以不关注。)
-o特殊选项:可以指定挂载的额外选项,比如读写权限、同步异步等,如果不指定则默认值生效。
举例:
[root@localhost ~]# mount -t iso9660 /dev/sr0 /mnt/cdrom/
2、mount命令示例
直接输入mount
命令,就是查询系统中已经存在的挂载设备。
[root@localhost ~]# mount
/dev/sda3 on / type ext4 (rw)
proc on /proc type proc (rw)
sysfs on /sys type sysfs (rw)
devpts on /dev/pts type devpts (rw,gid=5,mode=620)
tmpfs on /dev/shm type tmpfs (rw,rootcontext="system_u:object_r:tmpfs_t:s0")
/dev/sda1 on /boot type ext4 (rw)
none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
# 其中只有
# /dev/sda3 on / type ext4 (rw)-->/dev/sda3挂载到根目录下,文件系统是ext4,权限是读写。
# /dev/sda1 on /boot type ext4 (rw) 有用,其他都是干扰项.
# 还要注意,swap分区是不需要挂载点的,是给系统内核直接访问的分区,mount命令是查看不到的。
3、mount -a命令说明
# 依据配置文件/etc/fstab的内容,自动挂载
[root@localhost ~]# mount -a
-a
的a
是auto
,自动的意思。
Linux系统的硬盘是开机自动挂载的。但是光盘和U盘这类移动存储设备,是不推荐开机自动挂载的。
如果光盘和U盘这类移动存储设备设置了开机自动挂载,开机时一旦你忘记放光盘或者U盘,系统就会无条件的寻找这个分区,如果找不到的话,就会系统启动错误。这样的错误其实修复起来并不难,但是一定要在本机上进行操作。
Linux系统自动挂载就是依照/etc/fstab
文件进行自动挂载的。这个文件是一个非常脆软的文件,一旦这个文件写错,系统会启动报错。
执行查看/etc/fstab
文件命令:[root@localhost ~]# vim /etc/fstab
如下图所示:
而mount -a
命令可以看作是扫描一下/etc/fstab
文件,看看里边的内容有没有写错,如果写错会报错。
在Red Hat 6
以后的Linux系统中,/etc/fstab
文件的容错性明显的增强了。Red Hat 5
以前出现一个字母的拼写错误都是不行的,Red Hat 6
以后除了关键位置的信息不能有错误,其他的出现错误也不会报错,所以有时候用mount -a
命令扫描,不一定会出现错误,,所以不能盲目信任mount -a
命令的结果。这个记住就好。(后边会说如果该文件有错误怎么修复)
4、-o特殊选项说明
我们先查看一下前面说的/etc/fstab
文件,Linux系统的自动挂载配置文件。
上图中红框内就是分区挂载的默认权限。下面详细说明一下挂载的权限:
atime/noatime
:更新访问时间或不更新访问时间。访问分区文件时,是否更新文件的访问时间,默认为更新。async/sync
:异步/同步,默认为异步。auto/noauto
:自动/手动,mount -a
命令执行时,是否会自动安装/etc/fstab
文件内容挂载,默认为自动。exec/noexec
:执行或不执行,设定是否允许在文件系统中执行可执行文件,默认是exec
允许。rw/ro
:读写/只读,文件系统挂载时,是否具有读写权限,默认是rw
。suid/nosuid
:具有或不具有SUID
权限,设定文件系统是否具有SUID
和SGID
的权限,默认是具有。user/nouser
:允许或不允许普通用户挂载,设定文件系统是否允许普通用户挂载,默认是不允许,只有root
可以挂载分区。defaults
:定义默认值,相当于rw
,suid
,dev
,exec
,auto
,nouser
,async
这七个选项。remount
:重新挂载已经挂载的文件系统,一般用于指定修改特殊权限。usrquota
:写入代表文件系统支持用户磁盘配额,默认不支持。grpquota
:写入代表文件系统支持组磁盘配额,默认不支持。
说明:
defaults
权限代表最上边7种权限中,有一个是默认值。这个默认值一般不需要进行修改,默认选项就很好。- 比如
exec/noexec
选项,如果选择noexec
,那整个分区中的文件都不能执行,如果是根目录定义成noexec
,那整个系统都无法启动,即使想修改也不行,因为mount
命令都执行不了了。
5、exec/noexec选项说明
请看下面示例:
# 1、查看系统中已经挂载的文件系统,注意有虚拟文件系统
# 命令结果是代表:/dev/sda3分区挂载到/目录,文件系统是ext4,权限是读写
[root@localhost] # mount
/dev/sda3 on/type ext4(rw)proc on/proc type proc(rw)
sysfs on/sys type sysfs(rw)
devpts on/dev/pts type devpts(rw,gid=5,mode=620)
tmpfs on/dev/shm type tmpfs(rw)
/dev/sdal on/boot type ext4(rw)
none on/proc/sys/fs/binfmt_misc type binfmt_misc(rw)
sunrpe on/var/lib/nfs/rpe_pipefs type rpc_pipefs(rw)
# 2、修改特殊权限
# 我们查看到/boot分区已经被挂载,而且采用的defaults 选项,那么我们重新挂载分区,并采用 noexec
[root@localhost ~]# mount -o remount,noexec /boot(临时生效)
# 然后用mount命令查询一下分区,boot分区多了noexec权限
# /dev/sdal on /boot type ext4 (rw,noexec)
# 权限禁止执行文件执行,看看会出现什么情况(注意不要用根分区做试验,#不然系统命令也不能执行了)。
# 执行一个shell脚本
[root@localhost boot]# ./hello.sh
-bash:./hello.sh:权限不够
# 再修改回来权限,就可以执行了。
[root@localhost ~]# mount -o remount,exec /boot
这个练习也要记住remount
的作用和使用方法。