Linux一切皆文件:
Llinux系统的文件或目录的属性主要包括:索引节点、文件类型、文件权限、链接数、所属的用户和用户组、最近修改时间等。
Llinux文件属性及权限图形说明:
Linux文件属性及权限补充说明:
第一列:inode索引结点
inode (index node)概述
一个硬盘需要存放数据,首先分区,再格式化(格式化会创建文件系统类型),最后就可以存储数据。Linux的文件系统类型一般有ext2/ext3/ext4等类型。在每个linux存储设备或存储分区被格式化创建成ext4(CentOS 6.7)文件系统后,创建文件系统一般生成两部分:第一部分inode,第二部分是block。inode用来存储文件属性及信息索引(指向文件实体,但文件名称不包含在inode),block用来存放实际的数据使用(例如文字、照片、视频等普通文件数据)。inode是一块存储空间,CentOS 6非启动分区inode默认大小为256字节,CentOS 5 默认大小为128字节。正常情况下,一个文件只能占用一个inode,如果两个文件的inode相同则说明是这两个文件是互为硬链接,也可以是多个文件。inode节点的总数一般在格式化时就给定。
查看系统分区及文件类型
[root@oldboy test]# df -Th
Filesystem Type Size Used Avail Use% Mounted on
/dev/sda3 ext4 8.8G 1.4G 7.0G 17% /
tmpfs tmpfs 491M 0 491M 0% /dev/shm
/dev/sda1 ext4 190M 36M 145M 20% /boot
查看指定文件inode
[root@oldboy test]# stat file.txt
File: `file.txt'
Size: 0 Blocks: 0 IO Block: 4096 regular empty file
Device: 803h/2051d Inode: 139792 Links:1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2018-11-13 16:58:45.989909373 +0800
Modify: 2018-11-13 16:58:45.989909373 +0800
Change: 2018-11-13 16:58:45.989909373 +0800
[root@oldboy test]# ls -lih file.txt
139792 -rw-r--r-- 1 root root 0 Nov 1316:58 file.txt
查看系统分区inode使用情况
[root@oldboy test]# df -i
Filesystem Inodes IUsed IFree IUse% Mounted on
/dev/sda3 593344 55764 537580 10% /
tmpfs 125596 1 125595 1% /dev/shm
/dev/sda1 51200 38 51162 1% /boot
[root@oldboy test]# dumpe2fs /dev/sda3 | grep -i "inode
count"
dumpe2fs 1.41.12 (17-May-2010)
Inode count: 593344
不同CentOS版本inode大小不同(boot分区默认是128字节)
[root@localhost test]# cat /etc/redhat-release
CentOS release 5.5 (Final)
[root@localhost test]# dumpe2fs /dev/sda1 | grep -i "inode
size"
dumpe2fs 1.39 (29-May-2006)
Inode size: 128
[root@localhost test]# dumpe2fs /dev/sda3 | grep -i "inode
size"
dumpe2fs 1.39 (29-May-2006)
Inode size: 128
[root@oldboy test]# cat /etc/redhat-release
CentOS release 6.7 (Final)
[root@oldboy test]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/sda3 8.8G 1.4G 7.0G 17% /
tmpfs 491M 0 491M 0% /dev/shm
/dev/sda1 190M 36M 145M 20% /boot
[root@oldboy test]# dumpe2fs /dev/sda1 | grep -i "inode size"
dumpe2fs 1.41.12 (17-May-2010)
Inode size: 128
[root@oldboy test]# dumpe2fs /dev/sda3 | grep -i "inode size"
dumpe2fs 1.41.12 (17-May-2010)
Inode size: 256
block概述
linux存储设备或存储分区被格式化创建成ext4(CentOS 6.7)文件系统后,创建文件系统一般生成两部分:第一部分inode,第二部分是block。inode前面已讲述,。了解block先了解sector(扇区)。硬盘的最小存储单位:sector(扇区),每个扇区储存512字节,操作系统会一次性连续读取多个扇区,即一次性读取多个扇区称为一个block(块),文件存取的最小单位:block(块),由多个扇区组成;block的大小常见的有1KB、2KB、4KB,在linux中常见设置为4KB,即连续8个扇区组成一个block,/boot分区的block一般为1KB。系统创建一个文件或者文件占大小一次固定分配4K(8个扇区,每个扇区512B)
查看每个分区的sector大小
[root@oldboy test]# df -l
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/sda3 9213440 1440588 7298180 17% /
tmpfs 502384 0 502384 0% /dev/shm
/dev/sda1 194241 35992 148009 20% /boot
[root@oldboy test]#
查看分区指定的block大小
[root@oldboy test]# dumpe2fs /dev/sda3 | grep -i "block size"
dumpe2fs 1.41.12 (17-May-2010)
Block size: 4096
[root@oldboy test]# dumpe2fs /dev/sda1 | grep -i "block size"
dumpe2fs 1.41.12 (17-May-2010)
Block size: 1024
查看指定分区的扇区、磁道、柱面、磁头等信息,磁盘的容量=磁头*磁道*扇区(512B)*柱面
[root@oldboy test]# fdisk -l /dev/sda3
Disk /dev/sda3: 9721 MB, 9721348096 bytes
255 heads, 63 sectors/track, 1181 cylinders
Units = cylinders of 16065 * 512 = 8225280bytes
Sector size (logical/physical): 512 bytes /512 bytes
I/O size (minimum/optimal): 512 bytes / 512bytes
Disk identifier: 0x00000000
第二列:文件类型及权限
文件类型及权限共有10个字符组成(第一个字符代表文件类型、后面9个字符代表文件权限),假如把SElinux开启,文件类型及权限共有11个字符(第一个字符代表文件类型、第2个到第10个字符代表文件权限,第11个字符与selinux有关系,一般用不到)
******第一个字符******
Linux的文件类型
在linux系统中,可以说一切设备(包括目录、普通文件等)皆文件。文件类型包含有普通文件、目录、字符设备文件、块设备文件、符号链接文件、管道文件等等
1、d(directory)表示目录
[root@oldboy test]# ls -l /test/ | grep "^d"
drwxr-xr-x 2 root root 4096 Nov 14 19:24dir1
drwxr-xr-x 2 root root 4096 Nov 14 19:24dir2
drwxr-xr-x 2 root root 4096 Nov 14 19:24dir3
[root@oldboy test]# ls -ld /test/*
drwxr-xr-x 2 root root 4096 Nov 14 19:24/test/dir1
drwxr-xr-x 2 root root 4096 Nov 14 19:24/test/dir2
drwxr-xr-x 2 root root 4096 Nov 14 19:24/test/dir3
2、- (regular file) 普通文件
(1)、纯文本文件(ascll)文件内容可以直接读到的数据,例如:字母、数字、特殊字条串等,可以用cat命令读取的文,比如配置文件几乎都是这种类型。
[root@oldboy test]# file file.txt
file.txt: ASCII text
(2)、二进制文件(binary)linux中的命令程序就属于这个格式。例如cat 命令就是一个二进制文件。
[root@oldboy test]# file /bin/ls
/bin/ls: ELF 64-bit LSB executable, x86-64,version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.18,stripped
(3)、数据格式文件(data)有些程序运行过程中会读取某些特定格式的文件,那些特定格式的文件可以被称为数据文件。例如:linux 在用户登录时都会将登录数据记录在/var/log/wtmp 那个文件内,该文件是一个数据文件,通过last命令读出来。/var/log/lastlog也是一个数据文件,可以使用lastlog命令读出来。cat命令读取会是乱码,因为他属于一种特殊格式的文件。file 命令也可以查看文件类型
[root@oldboy test]# file /var/log/wtmp
/var/log/wtmp: data
3、l (link)链接文件(一般指得是软链接文件或符号链接)
[root@oldboy test]# ls -l /mnt/file_hard_link.txt
lrwxrwxrwx 1 root root 14 Nov 14 19:38/mnt/file_hard_link.txt -> /test/file.txt
[root@oldboy test]# readlink /mnt/file_hard_link.txt
/test/file.txt
4、b(block)块设备和其它外围设备,是特殊类型的文件
[root@oldboy ~]# find /dev/ -type b | xargs ls -l | head -3
brw-rw---- 1 root disk 7, 0Nov 12 23:12 /dev/loop0
brw-rw---- 1 root disk 7, 1Nov 12 23:12 /dev/loop1
brw-rw---- 1 root disk 7, 2Nov 12 23:12 /dev/loop2
5、c (character)字符设备文件(一般是指串设备或终端设备等)
[root@oldboy ~]# find /dev/ -type c | xargs ls -l | head -3
crw-rw---- 1 root video 10, 175 Nov 12 23:12 /dev/agpgart
crw-rw---- 1 root root 251, 0 Nov 12 23:12 /dev/bsg/0:0:0:0
crw-rw---- 1 root root 251, 1 Nov 12 23:12 /dev/bsg/2:0:0:0
6、s(socket)套接字文件
[root@oldboy ~]# find /dev/ -type s | xargs ls -l | head -3
srw-rw-rw- 1 root root 0 Nov 12 23:12/dev/log
7、p(named pipe)管道文件
[root@oldboy ~]# find /var/spool/postfix/public/ -type p | xargs ls -l
prw--w--w- 1 postfix postfix 0 Nov 14 19:52/var/spool/postfix/public/pickup
prw--w--w- 1 postfix postfix 0 Nov 14 19:48/var/spool/postfix/public/qmgr
Linux下扩展名的作用
在linux中,虽然扩展名没什么实际意义,但为了兼容windows,同时方便我们多数习惯了windows用户区分文件的不同,所以还是习惯通过扩展名来表示不同的文件类型,例如:
1、.tar\.tar.gz\.tgz\.zip\.tar.bz表示压缩文件,创建命令一般为tar\gzip\unzip等
2、.sh表示shell脚本文件,通过shell语言开发的程序
3、.pl表示perl语言文件,通过perl语言开发的程序
4、.py表示python语言文件,通过python语言开发的程序
5、.html\.htm\.php\.jsp\.do表示网页语言文件
6、.conf表示系统配置文件
7、.rpm表示rpm安装包文件
******后面9个字符******
第三列:硬链接个数
文件链接分为两种,硬链接和软链接(符号链接)。
硬链接文件与软链接访问图形说明:
软链接(符号链接)可以看作是windows的快捷方式,可以让你快速找到目标文件,只是一个普通的文件,但软链接文件跟实际的原文件inode是不相同,软链接可以针对文件和目录进行创建。
硬链接是通过原文件的索引节点进行链接的文件,也可以理解为通过原文件inode复制出来的一个文件。硬链接和原文件的inode索引节点是相同的,硬链接只可以针对文件进行创建,目录创建不了(系统限制)。每个创建的目录会自动创建两个硬链接.和..可通过ls –a查看
链接创建命令
ln 原文件 目标文件 ##创建硬链接命令
ln -s 原文件 目标文件 ##创建软链接命令
硬链接创建
[root@oldboy test]# touch file
[root@oldboy test]# echo "testfile" > file
[root@oldboy test]# cat file
testfile
[root@oldboy test]# ln file file_hard_link
[root@oldboy test]# ls -lih
total 0
140988 -rw-r--r-- 2 root root 0 Nov 1501:51 file
140988 -rw-r--r-- 2 root root 0 Nov 1501:51 file_hard_link
[root@oldboy test]# cat file_hard_link
testfile
[root@oldboy test]# mkdir dir
[root@oldboy test]# ls -ld dir/
drwxr-xr-x 2 root root 4096 Nov 15 01:52dir/
[root@oldboy test]# ls -lid dir/ dir/.
140989 drwxr-xr-x 2 root root 4096 Nov 1501:52 dir/
140989 drwxr-xr-x 2 root root 4096 Nov 1501:52 dir/.
软链接创建
[root@oldboy test]# touch file
[root@oldboy test]# echo "testfile" > file
[root@oldboy test]# cat file
testfile
[root@oldboy test]# ln -s file file_soft_link
[root@oldboy test]# ls -li
total 4
140988 -rw-r--r-- 1 root root 9 Nov 1501:57 file
140989 lrwxrwxrwx 1 root root 4 Nov 1501:57 file_soft_link -> file
[root@oldboy test]# cat file_soft_link
testfile
第四列:文件或目录所属用户(用户)
第五列:文件或目录所属用户组(用户组)
Linux/Unix是一个多用户、多任务的操作系统同,在linux系统系统用户是分角色的,linux系统中,由于角色不同,权限和所完成的任务也不同,用户的角色是通过UID和GID识别的,特别是UID,在linux系统中,一个UID是唯一标识系统用户的账号(相当于我们的身份证)。用户的系统账号的名称(如oldboy)其实给人(管理员)看的,linu系统能够识别的仅仅是UID和GID这样的数字。用户UID就相当于我们的身份证一样,用户名就相当于我们的名字。
UID(User Identify) 中文用户ID,相当于各位的身份证,在系统中是唯一的
GIP(Group Identify)中文组ID,相当于各位的家庭或者你们的学校ID
Linux系统分为三类用户:
1、超级用户root
root(超级管理员),UID为0,拥有最高的权限,类似windows系统的administrator本地管理员。root可以使用sudo管理提权给普通用户使用,相当于分配特殊权限给普通用户使用。
2、虚拟用户
虚拟用户,UID为1~499,虚拟用户一般与系统和程序服务相关,一般是默认不能登录系统使用。
3、普通用户
一般是由具备系统管理员root权限用户所创建,UID为500~65534,这类用户的权限会受到一定的基本权限限制,一般来自具备管理员用户的限制。
查看用户UID和GID命令
[root@oldboy ~]# id oldboy
uid=500(oldboy) gid=500(oldboy)groups=500(oldboy)
当创建一个用户,以下配置文件会被修改
用户配置文件 /etc/passwd
用户密码配置文件 /etc/shadow
用户组配置文件 /etc/group
用户组密码配置文件 /etc/gshadow
1、用户配置文件/etc/passwd是系统识别用户的一个文件,系统所有用户都记录在这里/etc/passwd 文件中,每一行代表一个用户的信息,分别有7个字段,使用冒号 :分隔,每个字段的含义,如下图所示:
2、用户密码配置文件/etc/shadow是系统用户密码配置文件,与用户配置文件/etc/passwd中x字段的占位符相对应,记录着用户密码等相关记录。/etc/shadow文件中,每一行代表一个用户的密码相关信息,分别9个字段,使用冒号 : 分隔,每个字段含义如下图所示:
3、用户组配置文件/etc/group记录用户组相关信息。/etc/group文件中,每一行代表一个用户组信息,分别4个字段,使用冒号 : 分隔,每个字段含义如下图所示:
4、用户组密码配置文件/etc/gshadow与用户配置文件/etc/group中x占位符相对应,记录用户组密码相关信息。/etc/gshadow分别有4个字段,使用冒号: 分隔,每个字段的含义如下图所示:
第六、七、八列:文件大小及文件的修改时间
文件时间戳分三种:
modify 修改时间 find命令对应选项 -mtime 一般修改文件内容
change 改变时间 find命令对应选项 -ctime 文件的属性改变
access 访问时间 find命令对应选项 -actime 访问文件内容
格式化时间:
[root@oldboy ~]# ls -l
total 44
-rw-------. 1 root root 1139 Sep 7 17:18 anaconda-ks.cfg
-rw-r--r--. 1 root root 22179 Sep 7 17:18 install.log
-rw-r--r--. 1 root root 5890 Sep 7 17:16 install.log.syslog
drwxr-xr-x 2 root root 4096 Nov 14 18:18test
[root@oldboy ~]# ls -l --time-style=long-iso
total 44
-rw-------. 1 root root 1139 2018-09-07 17:18 anaconda-ks.cfg
-rw-r--r--. 1 root root 22179 2018-09-07 17:18install.log
-rw-r--r--. 1 root root 5890 2018-09-07 17:16 install.log.syslog
drwxr-xr-x 2 root root 4096 2018-11-14 18:18test
修改时间戳命令:
[root@oldboy ~]# stat install.log
File: `install.log'
Size: 22179 Blocks: 56 IO Block: 4096 regular file
Device: 803h/2051d Inode: 13 Links:1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2018-09-07 17:12:50.634999903 +0800
Modify: 2018-09-07 17:18:05.290999679 +0800
Change: 2018-09-07 17:18:18.479999676 +0800
[root@oldboy test]# touch file.txt
[root@oldboy test]# echo "testfile" > file.txt
[root@oldboy test]# stat file.txt
File: `file.txt'
Size: 9 Blocks: 8 IO Block: 4096 regular file
Device: 803h/2051d Inode: 140987 Links:1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2018-11-17 13:33:09.362803892 +0800
Modify: 2018-11-17 13:33:57.626808703 +0800
Change: 2018-11-17 13:33:57.626808703 +0800
[root@oldboy test]# cat file.txt
testfile
[root@oldboy test]# stat file.txt
File: `file.txt'
Size: 9 Blocks: 8 IO Block: 4096 regular file
Device: 803h/2051d Inode: 140987 Links:1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2018-11-17 13:34:13.969814896 +0800
Modify: 2018-11-17 13:33:57.626808703 +0800
Change: 2018-11-17 13:33:57.626808703 +0800
[root@oldboy test]# chown oldboy.oldboy file.txt
[root@oldboy test]# stat file.txt
File: `file.txt'
Size: 9 Blocks: 8 IO Block: 4096 regular file
Device: 803h/2051d Inode: 140987 Links:1
Access: (0644/-rw-r--r--) Uid: ( 500/ oldboy) Gid: ( 500/ oldboy)
Access: 2018-11-17 13:34:13.969814896 +0800
Modify: 2018-11-17 13:33:57.626808703 +0800
Change: 2018-11-17 13:34:38.519806714 +0800
第九列:文件名(特殊)
注意:文件名不包含在文件inode里,而是在上级目录的block里
查看文件和目录
[root@oldboy ~]# ls -lF
total 56
-rw-------. 1 root root 1139 Sep 7 17:18 anaconda-ks.cfg
-rw-r--r--. 1 root root 22179 Sep 7 17:18 install.log
-rw-r--r--. 1 root root 5890 Sep 7 17:16 install.log.syslog
-rw-r--r-- 1 root root 10240 Nov 17 18:10 pack.tar
drwxr-xr-x 2 root root 4096 Nov 17 17:47test/