1、前言
上一篇我们讲到了Linux 文件类型7种类型,本篇我们说说Linux文件目录结构。
2、Linux 目录树
所有可操作的计算机资源都存在于目录树这个结构中,对计算资源的访问,可以看做是对这棵目录树的访问。Linux 的目录结构如下:Linux 文件系统的结构层次鲜明,就像一棵倒立的树,最顶层是其根目录:
/bin: 常用命令一般都在这里,主要存放二进制可执行文件(ls、cat、mkdir 等)。
/boot: 这里存放的是启动 Linux 时使用的一些核心文件,包括一些连接文件以及镜像文件。
它主要存放用于系统引导时使用的各种文件;
/dev : 存放设备文件, 该目录下存放的是 Linux 的外部设备,在 Linux 中访问设备的方式和访问文件的方式是相同的。
/etc: 这个目录用来存放所有的系统管理所需要的配置文件和子目录。
/home: 主要存放所有用户文件的根目录,是用户主目录的基点,,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的,如上图中的 alice、bob 和 eve。
/lib: lib 是 Library(库) 的缩写这个目录里存放着系统最基本的动态连接共享库,其作用类似于 Windows 里的 DLL 文件。存放着和系统运行相关的库文件。
/lost+found: 这个目录一般情况下是空的,当系统非正常关机而留下“无家可归”的文件(windows 下叫什么.chk)就存放在这里。
/media: linux 系统会自动识别一些设备,例如U盘、光驱等等,当识别后,Linux 会把识别的设备挂载到这个目录下。
/mnt: 系统管理员安装临时文件系统的安装点,系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在 /mnt/ 上,然后进入该目录就可以查看光驱里的内容了。
/opt: 这是给主机额外安装软件所放置的目录。比如你安装一个tomcat 则就可以放到这个目录下。默认是空的。
/proc: proc 是 Processes(进程) 的缩写,/proc 是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。 这个目录的内容不在硬盘上而是在内存里,我们也可以直接修改里面的某些文件,比如可以通过下面的命令来屏蔽主机的ping命令,使别人无法ping你的机器:
echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all
/root: 该目录为系统管理员,也称作超级权限者的用户主目录。
/sbin: s 就是 Super User 的意思,是 Superuser Binaries (超级用户的二进制文件) 的缩写,存放二进制可执行文件,只有 root 才能访问。这里存放的是系统管理员使用的系统级别的管理命令和程序。如 ifconfig 等;
/selinux: 这个目录是 Redhat/CentOS 所特有的目录,Selinux 是一个安全机制,类似于 windows 的防火墙,但是这套机制比较复杂,这个目录就是存放selinux相关的文件的。
/srv: 该目录存放一些服务启动之后需要提取的数据。
/sys: 该目录下安装了 2.6 内核中新出现的一个文件系统 sysfs 。
sysfs 文件系统集成了下面3种文件系统的信息:针对进程信息的 proc 文件系统、针对设备的 devfs 文件系统以及针对伪终端的 devpts 文件系统。
该文件系统是内核设备树的一个直观反映。
当一个内核对象被创建的时候,对应的文件和目录也在内核对象子系统中被创建。
/tmp:用于存放各种临时文件,是公用的临时文件存储点;。
/usr: usr 是 unix shared resources(共享资源) 的缩写,用于存放系统应用程序,类似于 windows 下的 program files 目录。
/usr/bin: 系统用户使用的命令和应用程序。
/usr/sbin: 超级用户使用的比较高级的管理程序和系统守护程序。
/usr/src: 内核源代码默认的放置目录。
/var: var 是 variable(变量) 的缩写,这个目录中存放着在不断扩充着的东西,我们习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件。
/run: 是一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删掉或清除。如果你的系统上有 /var/run 目录,应该让它指向 run。
3、重点关注目录
在 Linux 系统中,有几个目录是非常重要的,注意不要误删除或者随意更改内部文件。
/etc: 这个是系统中的配置文件,如果你更改了该目录下的某个文件可能会导致系统不能启动。
/bin, /sbin, /usr/bin, /usr/sbin: 这是系统预设的执行文件的放置目录,比如 ls 就是在 /bin/ls 目录下的。
值得提出的是,/bin, /usr/bin 是给系统用户使用的指令(除root外的通用户),
而/sbin, /usr/sbin 则是给 root 使用的指令。
/var: 系统上跑了很多程序,那么每个程序相应的日志就被记录到这个目录下,
具体在 /var/log 目录下,另外 mail 的预设放置也是在这里。
4、linux文件基本属性
Linux的多用户系统系统,不同用户处于不同的地位,拥有不同的权限。
4.1、 查看用户属性:ls -l
drwxr-xr-x 2 csdn csdn 4.0K 1月 27 22:14 Code
你可能除了知道最后面那一项是文件名之外,其它项就不太清楚了,那么到底是什么意思:
比如第一项文件类型和权限那一堆东西具体指什么,链接又是什么,何为最后修改时间,下面一一道来:
rwx:表示read、write和execute权限
4.2、 如何更改文件属性?
chgmod -R xyz 文件或目录
xyz : 就是刚刚提到的数字类型的权限属性,为 rwx 属性数值的相加
4.3、通过例子加深印象
不用着急现在我们来通过下面的讲解让你加深印象。
如果我们修改文件权限,我们可以学习下如何通过数字来计算权限:
读 权限用数字4表示
写权限用数字2表示
执行权限数字1表示
对应的字母与数字等价关系如下:
** r=4 w=2 x=1 **
4.3.1、如果我要给读写执行权限那怎么算呢?
如: rwx=4+2+1=7
我们以修改CodeTest目录的权限修改为 drwxr-xrwx 为例子举例。
思路如下:
- 所有者权限不变。数值相加为7
- 组权限不变。数值相加为5
- 其它所有者权限要变更,数值相加为7
结果:757
1、通过ll查看CodeTest目录权限,正常如下:
drwxr-xr-x 2 csn csn 4096 2月 22 18:12 CodeTest
2、计算权限数字:
思路如下:
#1.所有者权限不变。数值相加为7
#2.组权限不变。数值相加为5
#3.其它所有者权限要变更,数值相加为7
结果:757
3、 使用chmod 命令修改权限
chmod 757 CodeTest
使用ll验证,正常结果如下:
drwxr-xrwx 1 csn csn 4.0K 2月 22 18:12 CodeTest
数值记算看起来很麻烦,其实我们多练习,熟练之后根本就不需要思考。一定要多练习。