一个命令 mkfs

讲文件系统前先介绍一个用于创建文件系统的命令:

mkfs

mkfs [options] [-t type fs-options] device [size]

描述

mkfs用来在设备上创建一个Linux文件系统,这个设备通常情况下是一个硬盘分区。上面的device参数要么是设备名(例如:/dev/hda1,/dev/sdb2),或者为包含文件系统的一个普通文件。size参数为此文件系统使用的block的数量。

返回值0代表成功,1代表失败。

选项(参数)

  • -t --type type

    指定将要创建的文件系统的类型。默认为ext2。
  • fs-options

    用来传递给文件系统生成器的特定选项。下面的选项被大多数文件系统生成器所支持。

-V,--verbose

产生详细输出,包括被执行的所有的文件系统的特定命令的输出。多次(大于一次)指定这个选项会抑制任意文件系统的特定命令的执行。这只在测试的情况下才会用到。

-V, --version

显示版本信息后退出。(选项-V只有在它是唯一参数的情况下才会显示版本信息,否则按照--verbose来工作。)

-h,--help

显示帮助信息

APUE中的文件系统

APUE中讲的是以Berkeley快速文件系统为基础的Unix文件系统。

我们可以把一个磁盘分为一个或多个分区。每个分区都可以包含一个文件系统,参照图4.13。

硬连接

问题:为什么删除一个目录项的函数被称之为unlink而不叫做delete。

i节点是固定长度的记录项,它包含有关文件的大部分信息。图4-14中的两个目录项指向同一个i节点。每个i 节点都有一个链接计数,其值是指向该i节点的目录项数。只有当链接计数减少至0时,才可删除该文件(也就是可以释放该文件占用的数据块)。这就是为什么删除一个目录项被称作unlink的原因。在stat结构中,链接计数包含在st_nlink成员中,其基本系统数据类型是nlink_t。这种类型称为硬连接

软链接(符号链接)

符号链接文件的实际内容包含了该符号链接所指向的文件的名字。看下面的例子:

lrwxrwxrwx 1 root 7 Sep 25 07:14 lib -> usr/lib

目录项中的文件名是3个字符的字符串lib,而在该文件中包含了7个字节的数据usr/lib。该i节点的文件类型是S_IFLINK,于是系统知道这是一个符号链接。

文件信息

i节点包含了文件有关的所有信息:文件类型、文件访问权限、文件长度和指向文件数据库的指针等。stat结构中的大多数信息都取自i节点。只有两项重要数据存放在目录项中:文件名和i节点编号。i节点标号的数据类型为ino_t。

ln命令和mv命令

ln命令用户创建链接(硬连接和软连接),因为目录项中的i节点编号指向同一文件系统中的相应i节点,一个目录项不能指向另一个文件系统的i节点。因此ln命令(构造一个指向一个现有文件的新目录项)不能跨文件系统。

在不跨文件系统为一个文件重命名时,该文件的实际内容并未移动,只需要构造一个指向现有i节点的新目录项,并删除老的目录项。链接计数不会变。这是mv(1)命令的通常操作方式。

目录文件的链接计数

假设我们创建了一个新目录

$mkdir testdir

图4-15显示结果。该图显示的显示了.和..目录项。图中显示了两个i节点:

  • 编号为2549的i节点,其字段类型表示这是一个目录,链接计数为2。任何一个页目录(不包含任何目录的目录)的链接计数总是2,它来自命名该目录的目录项以及在该目录中的.项。
  • 编号为1267的i节点,其字段类型表示它是一个目录,链接计数大于等于3。因为至少有三个目录项指向它,一个是命名它的目录项(图中没有显示),第二个是在该目录中的.项,第三个是在子目录testdir中的..项。

    注意: 在父目录中的每一个子目录都使该父目录的链接计数增加1。

函数link、linkat、unlink、unlinkat和remove

创建一个文件链接

任何一个文件可以有多个目录项指向其i节点。创建一个指向现有文件的链接的方法是使用link函数或者linkat函数。

#include <unistd.h>
int link(const char*existingpath,const char *newpath);
int linkat(int efd,const char*existingpath,int fd,const char*newpath,int flag);
成功返回0;出错返回-1

这两个函数创建一个新目录项newpath,它引用现有文件existingpath。如果newpath已经存在,则返回出错。只创建newpath中的最后一个分量,路径中的其他部分应该已经存在。

  • 大多数文件系统不支持跨越文件系统的链接。
  • 大多数文件系统不支持创建指向一个目录的硬链接,因为这样做可能在文件系统中形成循环。

删除一个文件链接

为了删除一个现有的目录项,可以调用unlink函数。

#include <unistd.h>
int unlink(const char*pathname);
int unlinkat(int fd,const char*pathname,int flag);
成功返回0,出错返回-1

什么情况下才会删除一个文件的内容

  • 使用unlink函数会将pathname所引用文件的链接计数减1。如果对该文件还有其他链接,则仍可通过其他文件访问该文件的数据。如果出错,则不对该文件做任何更改。
  • 使用unlink函数解除一个文件的链接,必须对包含该目录项的目录具有写和执行权限,此外,如果对该目录设置了粘着位,还需要具备下面三个条件之一:
    1. 拥有该文件;
    2. 拥有该目录;
    3. 具有超级用户权限。
  • 检查链接计数之前,内核会检查打开该文件的进程个数,如果进程数为0才会去检查链接计数,如果计数也是0,那么就会删除该文件的内容。

APUE-文件和目录(四)文件系统的更多相关文章

  1. [APUE]文件和目录(下)

    一.mkdir和rmdir函数 #include <sys/types.h> #include <sys/stat.h> int mkdir(const char *pathn ...

  2. [APUE]文件和目录(中)

    一.link.unlink.remove和rename 一个文件可以有多个目录项指向其i节点.使用link函数可以创建一个指向现存文件连接 #include <unistd.h> int ...

  3. [APUE]文件和目录(上)

    一.文件权限 1. 各种ID 我在读这一章时遇到了各种ID,根据名字完全不清楚什么意思,幸好看到了这篇文章,http://blog.csdn.net/ccjjnn19890720/article/de ...

  4. APUE 文件和目录

    文件和目录 Unix 所有的文件都对应一个 struct stat,包含了一个文件所有的信息. #include <sys/stat.h> struct stat { mode_t st_ ...

  5. APUE ☞ 文件和目录

    粘着位(Sticky Bit) S_ISVTX位被称为粘着位.如果一个可执行程序文件的这一位被设置了,程序第一次运行完之后,程序的正文部分的一个副本仍被保存在交换区(程序的正文部分是机器指令).这使得 ...

  6. (三) 一起学 Unix 环境高级编程 (APUE) 之 文件和目录

    . . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...

  7. 《UNIX环境高级编程》笔记——4.文件和目录

    一.引言 本章描述文件系统的其他特征和文件的性质.有些背景知识需要注意,例如用户ID与文件权限.文件系统等. 二.函数stat.fstat.fstatat和lstat #include <sys ...

  8. Linux学习-文件和目录管理 

    Linux文件和目录管理  文件系统架构  1.Linux文件系统具有层级性     1)文件或者目录起始于根目录"/"成为树状结构    2)最顶层由/开始   2 ...

  9. apue学习笔记(第四章 文件和目录)

    本章将描述文件系统的其他特性和文件的性质. 函数stat.fstat.fstatat和lstat #include <sys/stat.h> int stat(const char *re ...

  10. 《UNIX环境高级编程》(APUE) 笔记第四章 - 文件和目录

    4 - 文件和目录 1. 函数 stat.fstat.fstatat 和 lstat #inlcude <sys/stat.h> int stat(const char *restrict ...

随机推荐

  1. extj6.0写增删查改(1)-------查询

    本文主要实现的效果是:点击查询按钮,根据form中的条件,在Grid中显示对应的数据(如果form为空,显示全部数据) 一.静态页面 1.查询按钮 { text:'查询', handler: 'onS ...

  2. java获得路径的多种方式

    本文讲解java语言中获得运行时路径的多种方式,包括java项目.java web项目.jar.weblogic等多种场景. 一.this.getClass().getClassLoader().ge ...

  3. uoj #58 【WC2013】糖果公园

    题面:http://uoj.ac/problem/58 正解:树上带修改莫队. 首先Orz vfk大神,树上莫队的套路还是很厉害的..http://vfleaking.blog.163.com/blo ...

  4. hdu2767强连通加缩点

    https://vjudge.net/contest/156688#problem/B 题目说了一大堆,前面的没有用,就是让你判断要加几条边才能强连通,用到缩点的知识 二重循环,判断邻接表下一个点是不 ...

  5. 完全背包hdu1114

    https://vjudge.net/contest/68966#problem/F 初始化就行了:dp[0]=0: 这题还要刚好装满背包,输出时进行判断 #include<map> #i ...

  6. 关于制作C语言头文件的思考

    我们接触的第一个c语言代码是这个: #include<stdio.h> main() { printf("Hello World"); } 这是最简单的c代码,然而,它 ...

  7. 利用LinkedList生成一副扑克牌

    import java.util.LinkedList; import java.util.Random; //自定义一个Poker类,用于存储扑克的信息(花色.数字) class Poker{ St ...

  8. javascript 函数和作用域(闭包、作用域)(七)

    一.闭包 JavaScript中允许嵌套函数,允许函数用作数据(可以把函数赋值给变量,存储在对象属性中,存储在数组元素中),并且使用词法作用域,这些因素相互交互,创造了惊人的,强大的闭包效果.[upd ...

  9. js,jQuery和DOM操作的总结(二)

    jQuery的基本操作 (1)遍历键值对和数组 , , , , , ]; $.map(arr, function (ele, index) { alert(ele + '===' + index); ...

  10. 九思,OA协同九大设计要点

    伴随着产品线的丰富和客户数量的增加,我们发现烂尾项目也与日俱增,客户和OA公司之间的矛盾日益尖锐,一套好OA系统远非增加几个特色功能这么简单,套用孔子"君子有九思"的话,好的OA系 ...