Linux系列教程(十八)——Linux文件系统管理之文件系统常用命令

  通过前面两篇博客,我们介绍了Linux系统的权限管理。Linux权限管理之ACL权限 介绍了通过设定 ACL 权限,我们为某个用户指定某个文件的特定权限,这在Linux只能对于一个文件只能有所有者权限,所属组权限和其他人权限时,设定 ACL 权限,能额外的为某个特定的用户设定权限。然后对于 文件系统系统属性chattr权限和sudo命令 ,chattr 命令能设定文件的系统属性,超级用户也能被限制,这个命令能更好的保护文件和目录不被破坏;而另一个命令 sudo,超级管理员赋予普通用户执行系统命令的权利,然后通过 sudo 命令去执行,因为我们有时候没有超级用户的使用权限,这时候又想使用一些系统命令,那么 sudo 命令能帮助我们。

  权限管理结束之后,我们开始进入Linux系统的文件系统管理学习。本篇博客我们首先介绍文件系统的常用命令。

1、为什么要给硬盘分区?

  前面我们讲解 Linux 系统的安装时,我们手动给硬盘划分了4个分区,分为了根目录/,/home 分区,/boot分区,还有/swap交换分区,那么为什么要给硬盘分区呢?

  ①、易于管理和使用

  一个没有分区的硬盘就像一个大柜子,如果我们在柜子里放些衣物和化妆品就会显得很杂乱没有规则更不容易管理和拿取,这时如果我们找来木匠把柜子分割成不同的空间,用来分别储存衣物和化妆品就会让我们很容易管理和拿取衣服和化妆品。同样的一个硬盘如果不分割空间而直接储存各种文件会让我们难以管理和使用。

  ②、有利于数据安全

  如果漏雨,一个没有分割的大柜子里面的东西肯定全部无法避免被雨水侵蚀的命运,而把柜子分割开来则会因每个空间相对独立,先侵蚀的只会是正好漏雨的空间如果及时采取措施那其它空间里的东西将得以保存。如果中病毒,一个没有分区的硬盘,里面保存的数据肯定全部都会被感染或者损坏,而如果把硬盘分区,然后把文件分开存放,在中毒后我们有充分的时间来采取措施防止病毒和清除病毒,即使需要重做系统也只会丢失系统所在的数据而其它数据将得以保存。

  ③、节约寻找文件的时间

  在没有分区的硬盘里面找文件就想在一个大柜子里面找衣服一样,总会翻动很多东西才能找到自己想要的。如果我们把硬盘分区,在需要某个文件时可以直接到特定的分区去寻找,这样避免了我们翻找过多的文件。

2、Linux系统分区类型

  ①、主分区:总共最多只能分 4 个。

  ②、扩展分区:只能有一个,也算作主分区的一种,也就是说主分区加上扩展分区最多有 4 个。但是扩展分区不能存储数据和格式化,必须在划分为逻辑分区才能使用。

  ③、逻辑分区:逻辑分区是扩展分区中划分的,如果是 IDE 硬盘,Linux 最多支持59个逻辑分区,如果是 SCSI 硬盘Linux最多支持 11 个逻辑分区。

注意:如果只有一个主分区,一个扩展分区,扩展分区下有三个逻辑分区。那么主分区的设备文件名为/dev/sda1,扩展分区的设备文件名为 /dev/sda2。而逻辑分区直接是 /dev/sda5,也就是说系统默认的设备文件名从/dev/sda1——/dev/sda4是给主分区和扩展分区命名的,而逻辑分区的设备文件名是从/dev/sda5开始的。

3、Linux 文件系统的格式

 4、文件系统的常用命令  

  ①、文件系统查看命令:df

df 【选项】【挂载点】

  使用的比较多的就是 df -h

  ②、统计目录或文件大小:du

du 【选项】【目录或文件名】

  我们说通过 ls 命令也能统计文件大小,但是ls 命令只是文件的一级目录,而du能显示目录以及所有子目录和文件的大小。

  df命令能统计文件或目录大小,而前面讲的df命令也能查看分区大小,这里我们以 /home分区为例:

  df 统计的/home分区使用大小为 760M,而du 命令统计的/home分区使用大小为 751M,这是为什么呢?

  ①、df 命令是从文件系统考虑的,不管要考虑文件占用的空间,还要统计被命令或程序占用的空间(最常见的就是文件已经删除,但是程序并没有释放空间)。

  ②、du 命令是面向文件的,只会计算文件或目录占用的空间。

  也就是说,实际系统的剩余空间大小是以 df 命令统计为准的。这也告诉我们 Linux 虽然系统很稳定,但是对于经常高负载的服务器,还是应该定期重启,维护服务器的高效运转。

  ③、文件系统修复命令:fsck

fsck 【选项】分区设备文件名

  系统在启动时会自动进行文件系统修复,这里我们最好不要手动执行文件系统修复命令,很容易造成意外的错误。

  ④、显示磁盘状态命令:dumpe2fs

dumpe2fs 分区设备文件名

5、挂载命令

  ①、查询系统中已经挂载的设备:mount 

mount 【-l】

  选项:-l 会显示卷标名称,也就是设备文件名的别名

  ②、依据配置文件 /etc/fstab 的内容自动挂载:mount -a

  下面是 /etc/fstab 的文件内容:

  注意:我们最好不要将光盘或者U盘的挂载配置写在 /etc/fstab 文件中,因为系统启动的时候会自动挂载这个文件中配置好的内容,你不可能光盘或者U盘一直都和系统连着,如果没有,则挂载出错,系统有可能奔溃。

  ③、挂载命令格式

  范例:我们重新挂载 /home 分区,加上-o noexec,也就是说使得 /home 分区的可执行文件不能执行。然后创建一个脚本(后面会讲解,这里只需要知道是一个可执行文件),然后看其是否能执行。

  第一步:在/home目录下创建脚本hello.sh,简单的输出 hello world

  我们给其赋予可执行权限,然后执行此脚本:

  第二步:重新挂载 /home分区,加上 -o noexec,在执行此脚本发现权限不够了,注意我们还是使用的超级用户root

  第三步:将/home分区还原,然后在执行此脚本,发现又可以了

6、挂载光盘与U盘

  ①、挂载光盘

  一、建立挂载点

mkdir /mnt/cdrom

  二、将光盘放入光驱

  对于虚拟机我们执行以下操作即可:

  三、挂载光盘

mount -t iso9660 /dev/cdrom /mnt/cdrom

  或者执行下面命令

mount /dev/sr0 /mnt/cdrom

  为什么有两个设备文件名/dev/cdrom 和/dev/sr0 呢?

  我们可以看到这是一个软链接,光盘的设备文件名是系统自动检测的,以及固定了,我们只需要记住就好了。

  ②、挂载 U 盘

  第一步:让虚拟机识别到 U 盘

  注意我们是在真实物理机上安装的虚拟Linux系统,为了让虚拟机能检测到U盘,我们要鼠标点进到虚拟机中,不能用远程连接工具。

  第二步:执行 fdisk -l 查看U 盘的设备文件名

  第三步:挂载 U 盘

mount -t vfat /dev/sdb1 /mnt/usb

  ③、卸载命令

umount 设备文件名或者挂载点

7、支持 NTFS 文件系统

  我们知道 Linux 默认是不支持 NTFS 文件系统的,所以早期的苹果笔记本如果插上移动硬盘,是不能对硬盘的内容进行修改,只能读取的。

  那么如何解决 Linux 系统不支持 NTFS 文件系统呢?

  第一种方法是重新编译内核,这种方法要求较高,这里我们就不做演示了。

  第二种方法是安装 NTFS-3G 插件,如下:

  安装完成之后,如下进行使用:

8、总结

  本篇博客我们首先介绍了硬盘为什么要分区,以及Linux系统的几种分区类型,然后介绍了Linux系统几个常用的文件系统命令,最后讲解了挂载命令,并通过实例演示了如何挂载光盘和U盘。下篇博客我们将介绍linux文件系统的fdisk分区。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏北京马哥教育

Python之包管理工具快速入门

学Python最简单的方法是什么?推荐阅读:30万年薪Python开发工程师成长魔法 在Python环境中已经有很多成熟的包,可以通过安装这些包来扩展我们的程序...

2875
来自专栏Java技术分享

关于RBAC(Role-Base Access Control)的理解

基于角色的访问控制(Role-Base Access Control) 有两种正在实践中使用的RBAC访问控制方式:隐式(模糊)的方式和显示(明确)的方式。 今...

2075
来自专栏Java技术分享

关于RBAC(Role-Base Access Control)的理解

有两种正在实践中使用的RBAC访问控制方式:隐式(模糊)的方式和显示(明确)的方式。

2308
来自专栏BeJavaGod

分布式系统的那些事儿(三) - 系统与系统之间的调用

系统与系统之间的调用通俗来讲,分为本地同一台服务器上的服务相互调用与远程服务调用,这个都可以称之为RPC通信。浅白点讲,客户访问服务器A,此时服务器要完成某个动...

3454
来自专栏FreeBuf

爬虫代理搭建与批量安装

代理对于搞爬虫的都不会陌生。公司有一批阿里云服务器用于分布式增量抓取,但对于一些封ip且只需进行一次全量抓取的数据源,或数据量级较小时,如果部署到爬虫集群上又太...

4915
来自专栏施炯的IoT开发专栏

Windows 10 IoT Serials 6 - 如何修改IoTStartupOnBoot.cmd文件

    使用Windows 10 IoT Core系统的朋友应该会比较熟悉IoTStartupOnBoot.cmd文件,该文件是系统启动以后加载的批处理文件,一...

2518
来自专栏伦少的博客

HDFS DataNode启动异常:/opt/jdk1.8.0_151/bin/java:权限不够

1393
来自专栏IT技术精选文摘

Java I/O底层是如何工作的?

本博文主要讨论I/O在底层是如何工作的。本文服务的读者,迫切希望了解Java I/O操作是在机器层面如何进行映射,以及应用运行时硬件都做了什么。 假定你熟悉基...

2868
来自专栏微服务

微服务实践分享与探讨

服务调用关系 ? API网关优缺点 简化沟通方式 API网关对所有微服务提供单一的访问点 安全性 对客户端隐藏了服务发现和服务版本 阻止大规模攻击,包括S...

3417
来自专栏PHP在线

6个常见的 PHP 安全性攻击

  了解常见的PHP应用程序安全威胁,可以确保你的PHP应用程序不受攻击。因此,本文将列出 6个常见的 PHP 安全性攻击,欢迎大家来阅读和学习。   ...

3735

扫码关注云+社区