文件系统

文件系统
文件和目录被组织成一个单根倒置树结构
文件系统从根目录下开始,用“/”表示
文件名称区分大小写
以.开头的文件为隐藏文件   一个.表示本目录。 两个..表示根目录
路径分隔的/      路径分割为正斜线分割
文件有两类数据:
       元数据:metadata    属性
       数据:data
-rw-r–r–        .                  1               root               root                 0       Mar 27 08:35       1 
权限相关      权限相关     连接数       文件所有者    文件组             大小          修改时间         文件
文件系统分层结构:LSB Linux Standard Base
                                简写                 标准库
FHS:(Filesystem Hierarchy Standard)
     http:www.pathname.com/fhs/
文件名规则
文件名最长255个字节       可以加文字 符号  但是不能超过255个字节
包括路径在内文件名称最长4095个字节    
蓝色—->目录     绿色—>可执行文件      红色—->压缩文件     浅蓝色—>连接文件     灰色—>其他文件
除了斜杠和NUL,所有字符都有效。但使用特殊字符的目录名和文件不推荐使用,有些字符需要用引号来引用它们。
标准Linux文件系统(ext4),文件名称大小写敏感。例如:MAIL,Mail,mail, mAiL.
linux 下的文件类型
– :普通文件     [root@localhost run]# ll
-rw——-.  1 root           root              4 Apr 25 09:15 gssproxy.pid
d :目录文件      [root@localhost run]# ll
drwxr-xr-x.  4 root           root            120 Apr 25 09:14 initramfs
b: 块设备     ll /dev/sda*
brw-rw—-. 1 root disk 8, 0 Apr 25 09:14 /dev/sda
c:字符设备     ll /dev/zero
crw-rw-rw-. 1 root root 1, 5 Apr 25 09:14 /dev/zero
crw-rw-rw-. 1 root root 1, 3 Apr 25 09:14 /dev/null
l :符号连接文件    ll /etc/redhat-release
lrwxrwxrwx. 1 root root 14 Mar 27 08:22 /etc/redhat-release -> centos-release
p :管道文件pipe         [root@localhost run]# ll
prw——-.  1 root           root              0 Apr 25 09:14 dmeventd-server
s :套接字文件socket         [root@localhost run]# ll
srw-rw-rw-.  1 root           root              0 Apr 25 09:15 gssproxy.sock
删除文件名“-”
rm -f /root/-h
文件系统结构
/boot:引导文件存放目录,内核文件(Vmlinuz),引导加载器(boottloader,grub)
都存放于此目录
/bin:供所有用户使用的基本命令;不能关联至独立分区,OS启动即会用到的程序
/sbin:管理类的基本命令;不能关联至独立分区,OS启动即会用到的程序
/lib:启动时程序依赖的基本共享文件以及内核模块文件(/lib/modules)
/lib64:专用于x86_64系统上的辅助共享库文件存放位置
/etc:配置文件目录
/home/USERNAME:普通用户家目录
/root:管理员的家目录
/media:便携式移动设备挂载点
/mnt:临时文件系统挂载点
/dev:设备文件及特殊文件存储位置
     b:block device,  随机访问
     c:character device, 线性访问
/opt:第三方应用程序的安装位置
/srv:系统上运行的服务用到的数据
/tmp:临时文件存储位置
/usr:universal shared , read-only data
     bin:保证系统拥有完整功能而提供的应用程序
     sbin:
     lib:32位使用
     lib64:只存在64位系统
     include:C程序的头文件(header files)
     share:结构化独立的数据,例如doc, man等
     local:第三方应用程序的安装位置
           bin,sbin,lib,lib64,etc, share
/var:variabie data files
cache:应用程序缓存数据目录
lib:应用程序状态信息数据
local:专用于为/usr/local下的应用程序存储可变数据;
lock:锁文件
log:日志目录及文件
opt:专用于为/opt下的应用程序存储可变数据
run:运行中的进程相关数据,通常用于存储进程pid文件
spool:应用程序数据池
tmp:保存系统两次重启之间产生的临时数据
/proc:用于输出内核与进程信息相关的虚拟文件系统
/sys:用于输出当前系统上的硬件设备相关信息虚拟文件系统
/selinux:security enhanced linux, selinux相关的安全策略等信息的存储位置
Linux上的应用程序的组成部分
二进制程序:/bin,/sbin,/usr/bin,/usr/sbin ,/usr/local/bin,/usr/local/sbin
库文件:/lib,/lib64,/usr/lib,/usr/lib64,/usr/local/lib,/usr/local/lib64
配置文件:/etc,/etc/DIRECTORY,/usr/local/etc
帮助文件:/usr/share/man,/usr/share/doc,/usr/local/share/man,/usr/local/share/doc
CentOS 7目录变化
/bin和/usr/bin
/sbin和/usr/sbin
/lib和/usr/lib
/lib64和/usr/lib64
显示当前工作目录
每个shell和系统进程都有一个当前的工作目录
CWD:current work directory
显示当前shell CWD的绝对路径
#pwd:printing working directory
       -p 显示真实物理路径
[root@localhost rc0.d]# pwd
/etc/rc0.d
[root@localhost rc0.d]# pwd -P
/etc/rc.d/rc0.d

       -L  显示连接路径(默认)
更改目录
cd 改变目录
使用绝对路径或相对路径
cd  /home/wang/
cd home/wang
切换至父目录: cd ..
切换至当前用户主目录: cd
切换至当前的工作目录: cd –
选项: -p
相关的环境变量
      PWD;当前目录路径
      OLDPWD:上一次目录路径
列出目录内容
列出当前目录的内容或指目录
用法:ls[options] [files_or_dirs]
示例:
ls -a     包含隐藏文件
ls -l      显示额外的信息
ls R      目录递归通过
ls -ld     目录和符号链接信息
ls -1     文件分行显示
ls -S    按从大到小排列
ls -t   按mtime排列
ls -u  配合-t选项,显示并按atime从新到旧排列
ls -U 按目录存放顺序显示
ls  -X  文件后缀排序
基本上Linux最主要的文件系统为Ext2,该文件系统内的信息主要由:
       superblock:记录此文件系统的整体信息,包括inode/block的总量,使用量,剩余量,以及文件系统的          格式化与相关信息等。
       inode:记录文件的属性,一个文件占用一个inode,同时记录此文件的数据所在的block号码。
       block:实际记录文件的内容,若文件太大时,会占用多个block。
Ext2文件系统的数据访问为索引式文件系统(indexed allocation)
需要碎片整理的原因就是文件写入的bloxk太过离散了,此时文件读取的性格将变得很差所致,这个时候可以通过碎片整理将同一个文件所属的block汇集在一起。
Ext2文件系统主要有boot sector,superblock,inode bitmap,block bitmap,inode table,data block等六大部分。
data block是用来放置文件内容数据地方,在Ext2文件系统中所支持的block大小有1KB,2KB及4KB三种而已。
inode记录文件的属性/权限等数据,每个inode大小均固定为128bytes;每个文件都仅会占用一个inode而已;因此文件系统能够新建的文件数量与inode的数量有关
文件的block记录文件的实际数据,目录的block则记录该目录下面文件名与其inode号码的对照表。
日志(journal)文件系统会多出一块记录区,随时记载文件系统的主要活动,可加快系统恢复时间。
Linux文件系统为增加性能,会让主存储器作为大量的磁盘高速缓存。
实际连接只是多了一个文件名对该inode号码的链接而已。
符号链接就类似Windows的快捷方式功能。
磁盘的使用必需要经过分区,格式化与挂载,分别惯用的命令fdisk,mkfs和mount。
开机自动挂载可参考/etc/fstab的设置,设置完毕务必使用mount -a测试语法正确否。

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

(0)
wangqiangwangqiang
上一篇 2017-05-02
下一篇 2017-05-02

相关推荐

  • PHP5.4的变化关注—What has changed in PHP 5.4.x

    What has changed in PHP 5.4.x Most improvements in PHP 5.4.x have no impact on existing code. There are a few incompatibilities and new features that should be …

    Linux干货 2015-06-17
  • grep的基本用法详解

     grep是linux上常用的一个文本处理工具之一。它有着强大的文本处理能力,学会它,可以让工作更有效率。 一、初识grep   grep: Global search Regular Experssion and Print out line   从名字上也可以直观的了解到它是基于正则表达式进行全局搜索,并把结果打印到屏幕上来…

    系统运维 2015-05-25
  • Linux的文件查找之find的使用

    文件查找   本章节内容:   使用locate命令   使用find命令   使用Gnome搜索工具    一、文件的查找(find和locate的对比): 文件查找:是在文件系统上查找符合条件的文件。 locate find 查找时效性 非实时查找 实时查找 文件索引数据库 需要依赖查询系统上预…

    Linux干货 2016-08-15
  • 基于Keepalived构建高可用集群配置实例(HA Cluster)

    什么是集群 简单的讲集群(cluster)就是一组计算机,它们作为一个整体向用户提供一组网络资源。这些单个的计算机系统就是集群的节点(node)。一个理想的集群是,用户从来不会意识到集群系统底层的节点,在他/她们看来,集群是一个系统,而非多个计算机系统。并且集群系统的管理员可以随意增加和删改集群系统的节点。 关于更详细的高可用集群我们在后面再做详解…

    Linux干货 2016-11-03
  • 8-5作业

    1、取本机ip地址 ifconfig |grep -E -o  '(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])' 2、取各分区利…

    Linux干货 2016-08-08
  • iptables实验3 关于内网外网的地址转换及端口转换

    地址属于内核,而不属于网卡!!!!     网络防火墙的实现(主要是forward链) 172.16.100.68(A)和172.16.100.67(B) 192.168.12.10(B)和192.168.12.77(C)(VNET2) B作为C的网关   配置B主机的网卡一个为192.168.1.72,另一个为172.16.2…

    Linux干货 2016-10-30