linux桌面版文件管理器介绍(LINUX文件管理)
linux桌面版文件管理器介绍(LINUX文件管理)最后,根据inode信息,找到文件数据所在的block,读出数据。其次,通过inode号码,获取 inode信息2)Unix/Linux如何识别文件?系统内部不使用文件名,而使用inode号码来识别文件。在Linux中创建一个文件,系统就为该文件分配一个惟一的inode,文件的inode用于访问文件的属性。表面上,用户通过文件名打开文件,实际上,系统内部这个过程分成三步:首先,系统找到这个文件名对应的inode号码
【七】文件管理
7.1文件(目录)是如何访问的?
1)inode是什么?
文件数据都储存在"块"中,那么很显然,我们还必须找到一个地方储存文件的元信息,比如文件的创建者、文件的创建日期、文件的大小等等,这种储存文件元信息的区域就叫做Inode,中文译名为"索引节点"。
2)Unix/Linux如何识别文件?
系统内部不使用文件名,而使用inode号码来识别文件。在Linux中创建一个文件,系统就为该文件分配一个惟一的inode,文件的inode用于访问文件的属性。表面上,用户通过文件名打开文件,实际上,系统内部这个过程分成三步:
首先,系统找到这个文件名对应的inode号码
其次,通过inode号码,获取 inode信息
最后,根据inode信息,找到文件数据所在的block,读出数据。
3)Unix/Linux如何识别目录?
目录(directory)也是一种文件。打开目录,实际上就是打开目录文件。
目录文件的结构非常简单,就是一系列目录项的列表,每个目录项,由两部分组成:所包含文件的文件名,以及该文件名对应的inode号码。
4)查看某个文件的inode信息:
[root@cuug ~]# stat /etc/hosts
File: `/etc/hosts'
Size: 167 Blocks: 16 IO Block: 4096 regular file
Device: 802h/2050d Inode: 1012846 Links: 2
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2017-04-21 10:37:02.000000000 0800
Modify: 2015-05-24 21:44:21.000000000 0800
Change: 2015-05-24 21:44:21.000000000 0800
[root@cuug ~]# ll -i /etc/hosts
1012846 -rw-r--r-- 2 root root 167 May 24 2015 /etc/hosts 第一列就是Inode
5)查看一个磁盘分区的inode使用情况
[root@cuug ~]# df -i
文件系统 Inode (I)已用 (I)可用 (I)已用% 挂载点
/dev/sda2 7318528 127440 7191088 2% /
/dev/sda1 26104 34 26070 1% /boot
tmpfs 223858 1 223857 1% /dev/shm
7.2目录的功能介绍
根据1994年发布的文件系统标准(FSSTND),所有的Linux文件系统都有标准的文件和目录结构,那些标准目录又包含一些特定的文件,下面来简要介绍一下每个目录的作用:
1)根目录(/)
根目录位于分层文件系统的最顶层,用斜线(/)表示。它包含一些标准文件和目录,因此可以说它包含了所有的目录和文件。
2)/bin
/bin目录,也称为二进制目录,包含了那些供系统管理员和普通用户使用的重要的Linux命令的二进制(可执行)映像。这个目录下的文件要么是可执行文件,要么是其他目录下的可执行文件的符号连接,目录/usr/bin存放了大部分的用户命令。
3)/boot
/boot目录下存放的是Linux系统启动时要用到的所有文件,包括Linux内核的二进制映像。当用lilo引导Linux时,会用到这里的一些信息,grub的配置文件也放在这里。
4)/dev
/dev目录,也称为设备目录,存放连接到计算机上的设备的对应文件,包含了Linux 系统中使用的所有外部设备,它实际上是访问这些外部设备的端口,你可以访问这些外部设备,与访问一个文件或一个目录没有区别。
5)/etc
/etc目录存放了系统管理时要用到的各种配置文件和子目录,示例网络配置文件、文件系统、X窗口系统配置文件、设备配置信息、设置用户信息等;/etc目录不包含任何二进制文件。这个目录下的文件主要由管理员使用;普通用户对大部分文件有读权限。
6)/home
用户的基本目录,/home 如果建立一个名为“xx”的用户,那么在/home目录下就有一个对应的“/home/xx”路径,用来存放该用户的主目录。
7)/lib
/lib目录下存放了各种编程语言库,包括库文件和kernel模块。典型的Linux系统包含了C、C++、FORTRAN语言的库文件。/lib目录下的库映像文件可以用来启动系统并执行一些命令。实际上它包含了标准C库/lib/libc.so.*,数学库libm.so.*,共享的动态链接库/lib/ld/so以及目录/lib和/sbin下命令用到的其他共享库。
8)/lost found
/lost found 该目录在大多数情况下都是空的。但当突然停电、或者非正常关机后,有些文件就临时存放在这里。
9)/mnt
/mnt目录在一般情况下也是空的,主要用来临时装载文件系统,系统管理员执行mount命令完成装载。工作在系统中,这个目录包含了光驱、磁盘和软驱的装载点。这样,当装载了一个设备时,如光驱,就可以通过访问目录/mnt/cdrom的文件来访问相应光盘上的文件。
10)/proc
/proc目录存放了进程信息和系统信息,这些信息是在内存中由系统自己产生的。
11)/root
许多Linux系统都将目录/root作为根用户(超级用户)的主目录,该目录受到完全保护,不受普通用户的影响,普通用户没有权限访问/root目录。
12)/sbin
/sbin 该目录用来存放系统管理员的系统管理程序。目录/sbin、/usr/sbin、/usr/local/sbin包含系统管理工具、实用程序和通用的根用户专用命令。
13)/usr
/usr目录是Linux文件系统中最大的一个部分,要用到的应用程序和文件几乎都存放在这个目录下面。它包含了主机之间可以共享的只读数据。在多数Linux系统中,/usr至少包含了下面的子目录:X11R6、bin、doc、games、include、lib、local、man、sbin、share、src和tmp。
14)/tmp
/tmp目录用来存放不同程序执行时产生的临时文件。一些命令和应用程序要用到该目录。您也可以用该目录存放自己的一些临时文件。该目录中的所有文件会被定期删除,以保证磁盘(或磁盘分区)不会被临时文件所塞满。/tmp目录下某个文件的生命期是由系统管理员设定的,而且因系统而异,但通常只有若干分钟。多数系统都为/tmp目录设置了粘滞位(sticky bit),这样只有文件的所有者才能从该目录中删除文件。
15)/opt
/opt目录用来安装附加软件包。用户调用的软件包程序放在目录/opt/package_name/bin下,package_name是安装的软件包名称。软件包的参考手册放在/opt/package_name/man下。
16)/var
/var目录是系统在工作时预先设置的工作目录,如各种服务的日志文件和收发的邮件等。/var目录用于放置变量数据(当系统运行时这些数据不断变化)。
7.3文件和目录属性
7.4文件和目录的访问权限
7.5更改属性及权限的方法
1)更改目录或文件所有者及组
由root用户去执行,常用命令是:
chown [R] 用户:组 [目录|文件]
R表示递归,即该目录下所有目录和文件都一同更改。如:
#chown -R oracle:oinstall /u01
2)更改目录或文件的权限
由root用户和所有者都可以去执行,有三种方法
第一种:权重法
r(权重)=4,w(权重)=2,x(权重)=1。如:
#chmod 755 abc 赋予abc权限为rwxr-xr-x
[R]是递归,有效性截止到命令发出之前,对命令之后创建目录或文件无效
第二种:赋值法
#chmod u=rwx,g=rx,o=rx abc 同上例
这里:u=用户权限,g=组权限,o=不同组其他用户权限
第三种:加减法
#chmod u-x,g w abc 给abc去除用户执行的权限,增加组写的权限
#chmod a r abc 给所有用户添加读的权限
权限的理解需要注意两点:
1)凡是对某个文件有写动作的操作,不是看你是否对这个文件是否有W权限,而是看你对这个文件的上级目录的是否有W和X权限,因为你的写操作是对目录的内容的写操作。
2)root用户一般不受权限的限制,谁的目录或文件root都可以做写操作,但执行一个shell脚本所有用户必须有X权限,root也不例外。
[root@cuug abc]# cat a1.sh 这个shell文本里只包括一句执行命令
date
[root@cuug abc]# ls -al
总计 16
drwxr-xrwx 2 root root 4096 12-03 18:01 .
drwxr-xr-x 26 root root 4096 12-03 17:03 ..
-rw-r--r-- 1 root root 5 12-03 18:01 a1.sh
[root@cuug abc]# ./a1.sh 显而易见root缺省X权限,受限
-bash: ./a1.sh: 权限不够
[root@cuug abc]# sh a1.sh或bash a1.sh,此办法是可以的,因root调用了shell解释器
2015年 12月 03日 星期四 18:03:35 CST
[root@cuug abc]# chmod u x a1.sh
[root@cuug abc]# ls -al
总计 16
drwxr-xrwx 2 root root 4096 12-03 18:01 .
drwxr-xr-x 26 root root 4096 12-03 17:03 ..
-rwxr--r-- 1 root root 5 12-03 18:01 a1.sh
[root@cuug abc]# ./a1.sh
2015年 12月 03日 星期四 18:04:12 CST
[root@cuug abc]#
7.6使用附加权限
1)SET位权限
主要用途:
为可执行(有 x 权限的)文件设置,权限字符为“s”,其他用户执行该文件时,将拥有属主或属组用户的权限。SET位权限类型:
chmod u=rws,o=rx
-rws---r-x:表示对属主用户增加SET位权限
应用示例/usr/bin/passwd
2)粘滞位权限(Sticky)
主要用途:
为公共目录(示例,权限为777的)设置,权限字符为“t”,用户不能删除该目录中其他用户的文件。
应用示例:/tmp、/var/tmp
3)设置SET位、粘滞位权限
设置权限字符chmod o±t 目录名...
示例:
【第一步】 建立公共目录,不同用户建立的各自的文件
[root@cuug /]#mkdir /abc root用户建立一个公共目录
[root@cuug /]#chmod 777 /abc 授予所有用户rwx权限
[root@cuug /]#ls -ald /abc
drwxrwxrwx 2 root root 4096 12-09 21:32 /abc
[tim@cuug ~]$touch /abc/timfile 以tim身份建立一个timfile
[ran@cuug ~]$touch /abc/ranfile 以ran身份建立一个ranfile
[ran@cuug ~]$ls -al /abc 查看一下文件的属性和权限
-rw-r--r-- 1 ran g1 0 12-09 21:41 ranfile
-rw-r--r-- 1 tim g1 0 12-09 21:40 timfile
【第二步】 测试ran用户可以删除timfile
删除后,tim重建/abc/timfile
【第三步】 为/abc目录设置粘贴位
测试ran用户删除timfile时报错
[root@cuug ~]#ls -ald /abc
drwxrwxrwx 2 root root 4096 12-09 22:02 /abc
[root@cuug ~]#chmod o t /abc 为/abc设粘贴位
[root@cuug ~]#ls -ald /abc
drwxrwxrwt 2 root root 4096 12-09 22:02 /abc
[ran@cuug ~]$rm /abc/timfile 用户ran删别人的文件会报错
rm:是否删除有写保护的 一般空文件 “/abc/timfile”? y
rm: 无法删除 “/abc/timfile”: 不允许的操作
4)附加权限的特点
1、系统中要尽量避免使用set位,可以适当使用粘滞位;
2、Set位只能设置在文件上,而且只当文件有执行权限时才有意义;
3、粘滞位只能设置在目录上,而且不需要指定设置在针对谁的权限上。
the end !!!
@jackman 共筑美好!