现在的位置: 首页 > 综合 > 正文

Linux目录结构与文件权限

2012年03月22日 综合 ⁄ 共 2519字 ⁄ 字号 暂无评论

1、 一切皆文件;(我们可以这样理解:所有的东西,程序、设备、内存都模拟成文件。我们可以修改这些文件。这与Windows系统有根本性的区别)

2、 由大量的体积小、目标单一的小程序组成;

3、 组合小程序,通常使用管道进行连接,来完成更复杂繁琐的任务;(通道到后面学过之后提到)

4、 通过配置文件来保存程序的配置信息,而配置文件通常是纯文本文件。(这就意味着我们只要有个文本编辑器,就可以对大多数服务的进行配置了。是不是很方便啊!)

让我们再了解下Linux工作的特性:

1、 严格区分大小写;(例如:File,FIle,FILE等,这些都是不同的文件。是否理解了呢?呵呵)

2、 不以文件名的后缀判断file.html' target='_blank'>文件类型。(一谈到文件类型,大家能想到大概就是Windows操作系统下的文件类型,比如.txt、.doc、.sys、.mp3、.exe等,根据这些后缀就能判断文件的类型。但是在Linux中一个文件是否能被执行,和后缀名没有太大的关系,主要看文件的属性有关。不过为了方便我们分辩、查找和应用,使用一些后缀还是很有必要的。)

在Linux中所有的目录都在根目录下,这与Windows的目录结构不同,Windows中每个分区就代表一个根目录。下面我们来简单的认识下Linux的目录结构。说到目录结构,我们就不得不提下它所依照的标准了,它所依照的标准是FHS标准,正是因为有了这个标准,才使得每一个版本的Linux目录结构都相同,避免了我们换一个版本的Linux就从新学习一下Linux目录结构的这个问题。

FHS标准使得众多的Linux发布包有了可以遵循的标准,使得软件和用户可以预测已经安装了的文件和目录的位置。它定义了如下的内容。

1、定义了文件系统中每个区域的用途;

2、定义了所需要的最小构成的文件和目录;

3、给出了例外处理和矛盾的特殊例子。

FHS实际上仅是规范在根目录(/)下面各个主要目录应该放什么样的文件。FHS定 义了两层规范,第一层是, / 下面的各个目录应该要放什么文件数据,例如 /etc应该要放置设置文件,/bin与 /sbin则应该要放置可执行文件等等。第二层则是针对 /usr及 /var这两个目录的子目录来定义。例如 /var/log放置系统登录文件、/usr/share放置共享数据等等。

由于FHS仅是定义出最上层(/)及子层(/usr, /var)的目录内容应该要放置的文件数据,因此,在其他子目录层级内,就可以随开发人员自行配置了。

下面我们来简单了解下目录内容和用途:

/:根目录;

/bin(binary):放置的是二进制文件。可执行的命令;非管理类的命令。都可以使用。(通常是系统启动就需要的文件);

/sbin:管理类的命令,通常只有管理员才能使用; (

/lib:存放的是库文件(系统级别的);

/etc:大部分可执行文件的配置文件;

/etc/sysconfig:网络相关的文件。服务额外配置文件,及网络设备相关配置文件。

/etc/init.d:服务的管理脚本。

/usr:(类似windows的)平常管理用的文件 ;

/usr/bin

/usr/sbin

/usr/etc

/usr/lib

/usr/include (一般放置头文件)

/usr/local(第三方软件)

/usr/local/bin

/usr/local/sbin

/usr/local/etc

/usr/local/lib

/boot:(鞋子)引导文件的目录。(系统启动需要的文件)。Kernel(内核),bootloader(grub) ;

/dev:设备文件所在目录(特殊文件)c、b(终端设备是字符文件) ;

/home/USERNAME,/root(用户的主目录);

/lost+found:系统意外关闭,内存中存在的内容会写入到这个目录下;

/media,/mnt:挂载点目录,,media通常挂载移动设备,mnt通常挂载固定的设备;

/misc:杂项 ;

/opt:有些第三方软件,把此目录当成默认安装位置。Nessus,Oracle;

/proc:伪目录(这些文件不在磁盘上存在)(内存中的内核相关信息的映射);

/sys:比如像磁盘这样的存储设备或某些总线设备的驱动程序相关属性信息;

/srv:服务运行中中间文件的存放位置;

/tmp:临时文件目录;

/var:可变的

/var/log:系统日志文件。

/var/run:每一个服务运行的Pid文件。(文件标识符);

/var/mai:未被读取的邮件存放位置。

至此,我么已经大致了解了Linux的目录结构。另外,上面我们既然提到了Linux的文件类型,那我们来说说Linux都有那儿些文件类型吧!

-:普通文件

d:目录文件

l:符号连接(软链接)(特殊文件)

c:字符设备文件

b:块设备文件

p:管道式文件(不常见)

s:套接字文件(不常见)

说了这么多,最后来说下权限的问题吧!对于文件和目录,它们的权限含义有些不同,请看下面的介绍

文件权限:

r:读

w:写

x:执行

目录权限:

r:ls 查看文件

w:建立或删除文件

x:cd切换至此目录,或者ls -l文件

-:代表没有权限

我们常常看到用数字来说权限,下面给出一个对应关系,可以从中找到数字所对应的权限

权限 二进制 八进制

--- 000 0

--x 001 1

-w- 010 2

-wx 011 3

r-- 100 4

r-x 101 5

rw- 110 6

rwx 111 7

我们重点说下权限问题,后面的内容一带而过。从图中我们看到了-rw-r--r--的内容。其实这就是文件的权限。

假设这个文件什么权限都没有,它该表示成什么呢?很明显是----------。

第一个-所在的位置代表的是文件类型。从图中我们可以看出这是个普通文件。可以对应上面我们所说的文件类型。后面9个-所代表的就是文件的权限了,并且将其分为三部分,每三个一部分。从前向后分别代表:拥有文件的用户的权限、文件所在组的权限、其他用户的权限,其用数字表示权限便是6 4 4;

数字1:表示文件的应连接的次数数(目录一般为2);

第一个root:文件的所有者(属主);

第二个root:代表文件所在的组(属组 );

数字95:代表文件大小;

日期Feb 6 2012:代表文件最近被修改(改内容)的时间。

给我留言

留言无头像?