Linux文件系统总结(7.4课上作业)

一、什么是文件系统

        文件系统是对一个存储设备上的数据和元数据进行组织的机制。它使用文件和树形目录的抽象逻辑概念代替了硬盘和光盘等物理设备使用的数据块的概念,用户使用文件系统来保存数据而不必关心数据实际保存在硬盘(or光盘)的地址为多少数据块上,只需要记住这个文件的所属目录和文件名。在写入数据前,用户也不必关系硬盘上的哪个块地址没有被使用,硬盘上的存储空间管理功能由文件系统自动完成,用户只需记住数据被写入到了哪个文件中。

        文件系统通常使用硬盘和光盘这样的存储设备,并维护文件在设备中的物理位置。但是,实际上文件系统也可能仅仅是一种访问数据的界面而已,实际的数据是通过网络协议,如NFS,SMB等提供的或者内存上,甚至可能根本没有对应的文件,如proc文件系统。

        严格地说,文件系统是一套实现了数据的存储,分级组织,访问和获取等操作的抽象数据类型。


二、常见的文件系统:

  • Linux文件系统:

ext2,ext3,ext4,xfs,btr,reiserfs,jfs,swap

swap:交换分区:将磁盘当作内存使用

光盘:iso9660

  • windows:fat32(vfat),ntfs

  • unix:FFS,UFS,JFS2

  • 网络文件系统:NFS,CIFS

  • 集群文件:GFS2,OCFS2

  • 分布式文件系统:ceph

moosefs,mogilegfs,GlusterFS,Lustre

  • 根据其是否支持“Journal”功能:

非日志型文件系统:ext2,vfat

日志型文件系统:ext3,ext4,xfs…

  • 文件系统的组成部分

内核中的模块:ext4

用户空间的管理工具:mkfs.ext4, mkfs.xfs, mkfs.vfat

  • Linux的虚拟文件系统:VFS

  • 查看支持的文件系统:# cat /proc/filesystems


三、创建文件系统:

        先创建一个环回设备用作临时文件系统:

        使用dd命令创建一个指定大小的用0填充的文件,并用losetup命令将一个环回设备与此文件关联起来,使其作为一个块设备而不是常规文件。

# dd if=/dev/zero of=file.img bs=1k count=10000
记录了10000+0 的读入
记录了10000+0 的写出
10240000字节(10 MB)已复制,0.0116915 秒,876 MB/秒
# losetup /dev/loop0 file.img

  此时/dev目录出现一个块设备文件/dev/loop0

# ls /dev |grep loop0
loop0

        命令:

    1)mkfs

        用法:1)mkfs [options] [-t type] [fs-options] device [size]

                  2)mkfs.ext3

        选项:     

            [-b 块大小] [-C 簇大小]

            [-i 为数据空间中每多少个字节创建一个inode索引节点;该大小不应该小于block的大小]

            [-N 为数据空间创建多少个inode]

            [-m 为管理人员预留的空间占据的百分比] 

            [-L 卷标] 

            [-O 启用制定特性[,…]]

            [-t 文件系统类型] 

            [-U UUID] 

# mkfs -t ext3 -L LOOP /dev/loop0 
mke2fs 1.42.9 (28-Dec-2013)
Discarding device blocks: 完成                            
文件系统标签=LOOP
OS type: Linux
块大小=1024 (log=0)
分块大小=1024 (log=0)
Stride=0 blocks, Stripe width=0 blocks
2512 inodes, 10000 blocks
500 blocks (5.00%) reserved for the super user
第一个数据块=1
Maximum filesystem blocks=10485760
2 block groups
8192 blocks per group, 8192 fragments per group
1256 inodes per group
Superblock backups stored on blocks: 
        8193

Allocating group tables: 完成                            
正在写入inode表: 完成                            
Creating journal (1024 blocks): 完成
Writing superblocks and filesystem accounting information: 完成

2)mke2fs:ext系列文件系统的专用管理工具

    选项同mkfs

# mke2fs -t ext3 -L Loop /dev/loop0
mke2fs 1.42.9 (28-Dec-2013)
Discarding device blocks: 完成                            
文件系统标签=Loop
OS type: Linux
块大小=1024 (log=0)
分块大小=1024 (log=0)
Stride=0 blocks, Stripe width=0 blocks
2512 inodes, 10000 blocks
500 blocks (5.00%) reserved for the super user
第一个数据块=1
Maximum filesystem blocks=10485760
2 block groups
8192 blocks per group, 8192 fragments per group
1256 inodes per group
Superblock backups stored on blocks: 
        8193

Allocating group tables: 完成                            
正在写入inode表: 完成                            
Creating journal (1024 blocks): 完成
Writing superblocks and filesystem accounting information: 完成

  

3)mkswap:创建一个交换空间

    选项:

     -c, –check               创建交换区前检查坏块

     -f, –force               允许交换区大于设备大小

     -p, –pagesize SIZE       指定页大小为 SIZE 字节

     -L, –label LABEL          指定标签为 LABEL

     -v, –swapversion NUM     指定交换空间版本号为 NUM

     -U, –uuid UUID           指定要使用的 UUID

     -V, –version             输出版本信息并退出

     -h, –help                显示此帮助并退出

# mkswap /dev/loop0
mkswap: /dev/loop0: warning: wiping old ext3 signature.
正在设置交换空间版本 1,大小 = 9996 KiB
无标签,UUID=1d6c45f5-bcd0-44fd-a39b-ec9826a8e008

四、修改文件系统

(1)blkid 显示分区的属性信息

         blkid [option]… [device]

            -U UUID:根据指定的UUID来查找对应的设备

            -L LABEL:根据指定的LABEL来查找对应的设备

# blkid 
/dev/sda1: UUID="1ae50cbe-2f3d-4394-a8dd-38804695c18c" TYPE="xfs" 
/dev/sda2: UUID="fiizVI-1uF2-XfxN-qiZM-So42-8Hju-dx8mld" TYPE="LVM2_member" 
/dev/mapper/centos-root: UUID="98023b04-500a-451c-8db5-e9f77d4b8a7c" TYPE="xfs" 
/dev/mapper/centos-swap: UUID="6de8f2e9-70ad-4956-884e-60d3dc632659" TYPE="swap" 
/dev/loop0: LABEL="point1" UUID="df4b5931-cde8-4842-8807-e7eec08608d2" TYPE="ext3" 
/dev/loop1: UUID="5156094a-a26e-46ce-aa18-57ea46d5900f" TYPE="ext2"

(2)e2label:管理ext系列文件系统的LABEL

            e2label DEVICE :查看设备的卷标

            e2label DEVICE [LABEL]:修改设备的卷标

# e2label /dev/loop0 POINT1 && e2label /dev/loop0
POINT1

(3)tune2fs:重新设定ext文件系统的可调整属性的值

-l:查看指定文件系统的超级块信息:super block

-L ’LABEL‘:修改卷标

-m #:修改预留给管理员的空间百分比

-j:将ext2升级为ext3

-O:文件系统属性的打开或禁用

-o:调整文件系统的默认挂载选项

-U UUID:修改UUID号

        -i:设置相邻两次文件系统检查的间隔时间

        -c:设置检查前文件系统最大加载次数

(4)dumpe2fs:

-h:查看超级块信息


五、挂载文件系统

        在linux中,将一个文件系统与一个存储设备关联起来的过程称为挂载(mount)。

        使用mount命令将一个文件系统附着到当前文件系统层次结构中(根)。在进行挂载时,要提供文件系统类型,文件系统和一个挂载点。

        这里将loop0设备挂载到挂载点/mnt/point1。

# mkdir /mnt/point1
# mount -t ext3 /dev/loop0 /mnt/point1/
# ls /mnt/point1
lost+found

        此时还可以重复进行挂载,比如在point1中继续创建新文件,与一个新的环回设备关联,再在上面创建另一个文件系统并挂载(详细信息略)

# dd if=/dev/zero of=/mnt/point1/file.img bs=1k count=1000
# losetup /dev/loop1 /mnt/point1/file.img 
# mkfs.ext3 /dev/loop1
# mkdir /mnt/point2
# mount -t ext2 /dev/loop1 /mnt/point2
# ls /mnt/point2
lost+found

可见Linux的文件系统和环回设备是多么强大,可按照此种方法在文件上用环回设备创建加密的文件系统。在需要的时候使用临时环回设备挂载文件,有助于保护数据。


注:资料来源(上课笔记、Wiki、IBM devloperworks、Linux命令大全等)

原创文章,作者:lichenhan,如若转载,请注明出处:http://www.178linux.com/23141

(1)
lichenhanlichenhan
上一篇 2016-07-10 12:17
下一篇 2016-07-10 12:17

相关推荐

  • N22-第一周(作业)

    马哥教育网络班22期-第一周课程练习:   一.描述计算机的组成及其功能       计算机组成:CPU :包含控制器,运算器,寄存器,缓存。通过时序复用的方式来处理加工来自输入设备的指令或数据,协调各组件之间的工作       存储器(内存):编址存储单元阵列,用于暂时存放CP…

    Linux干货 2016-08-13
  • Linux系统中的防火墙iptables

    iptables/netfilter——Linux系统下的防火墙 基本原理 防火墙主要功能 工作于主机或者网络边缘,对进出本主机或本网络的报文进行匹配检测,对匹配到规则的报文进行于规则相对应的处理。 防火墙主要分类 按功能分类 主机防火墙网络防火墙 按构成分类 软件防火墙硬件防火墙 Linux防火墙软件iptables/netfilter(以后简称iptab…

    Linux干货 2017-06-13
  • ansible学习笔记之2 ad-hoc篇

    ansible学习笔记之2 ad-hoc篇 ansible学习笔记之2 ad-hoc篇 ansible 学习笔记 ad-hoc ansible学习笔记之2 ad-hoc篇 使用ansible ad-hoc搭建lnmp/lamp 编辑host文件,通过秘钥认证ssh连接主机 前期环境准备 在lnmp上安装lnmp 其中 ad-hoc搭建mysql主从 配置文件…

    2016-11-21
  • 设计模式 ( 十九 ) 模板方法模式Template method(类行为型)

    设计模式 ( 十九 ) 模板方法模式Template method(类行为型) 1.概述 在面向对象开发过程中,通常我们会遇到这样的一个问题:我们知道一个算法所需的关键步骤,并确定了这些步骤的执行顺序。但是某些步骤的具体实现是未知的,或者说某些步骤的实现与具体的环境相关。例子1:银行业务办理流程在银行办理业务时,一般都包含几个基本固定步骤:取号排队->…

    Linux干货 2015-04-07
  • 运维挖坑埋坑之旅—-413 Request Entity Too Large

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1575160        好久没写博文了,天天忙的喘不过来气。最近是该总结总结前段时间的工作了,顺便缓解下这两天的霉…

    Linux干货 2016-08-15
  • Linux高级文件系统管理之磁盘配额、软RAID及LVM

    高级文件系统管理之磁盘配额、软RAID及LVM   本章内容: 设定文件系统配额 设定和管理软RAID设备 配置逻辑卷   一、文件系统配额:     执行软限制(soft limit) 硬限制(hard limit)     注:磁盘配额只能针对分区控制有效,不能对整个磁盘控制…

    Linux干货 2016-09-01