一、 文件的权限
1、 文件一经创建就对应三种访问方式
- 读(r),可以查看文件的内容
- 写(w),可以编辑和删除文件
- 执行(x),文件是一个(shell脚本等)程序,可以执行
2、 按照针对的用户,文件的权限可分为三类:
- 文件属主,创建该文件的用户
- 同组用户,拥有该文件的用户组中的任何用户
- 其他用户,即不属于拥有该文件用户组的某一用户
每种用户下都对应三种访问类型。
下面是使用ls –l 命令显示的文件列表
依次来看:
1. total 683560
汇总了该目录下所有文件的大小以及一级目录的大小,不包含下级目录。
将下面6中的数值相加转化为K字节的数据总和。(由于total实现的计算方法不会是简单的相加,结果会稍有偏差)
注:解释不是很确定,查了很多资料,觉得这个比较准确
2. drwxr-xr-x一共十位
[1]d 是文件类型
[2-4]rwx 这三位是设定文件属主对文件的访问方式
[5-7]r-x 这三位是设定同组用户对文件的访问方式
[8-10]r-x 这三位是设定其他用户对文件的访问方式
3. 3 这是该文件硬链接的数目
- 如果是一个文件不是目录,此时这一字段表示这个文件所具有的硬链接数
- 如果是一个目录,则第2字段表示该目录所含子目录的个数,不包括文件(对于一个空目录,则第2字段的数字是2。因为每个目录都有一个默认的指向它上级目录的子目录和指向他本身的一个子目录)
4. root 文件的属主用户
拥有该文件的用户
5. system 文件属主用户所在的缺省组
一个用户可能有多个组,但都会有一个主组,这里就显示的是这个默认的主组
6. 256 文件的长度(单位是字节)
- 如果是一个文件不是目录,则指这个文件的大小
- 如果是一个目录,则指这个目录的大小(不包括其下面的子目录,子文件的大小,目录是一个特殊的文件也有自己的大小)
7. Jul 13 15:01 文件的最近更新时间
文件(或目录)的最近访问(或修改)时间
8. ese 文件名
如果是一个符号链接,那么会有一个 “->"箭头符号,后面根一个它指向的文件名
3、 文件类型
字母 | 源 | 含义 |
d | directory | 目录或者是特殊文件(保存其他文件或目录的相关信息) |
- |
| 普通文件 |
l | link | 链接文件,相当于windows中的快捷方式 |
b | block | 块设备文件,一般置于/dev目录下,设备文件是普通文件和程序访问硬件设备的入口,是很特殊的文件。没有文件大小,只有一个主设备号和一个辅设备号。一次传输数据为一整块的被称为块设备,如硬盘、光盘等。最小数据传输单位为一个数据块(通常一个数据块的大小为512字节) |
c | character | 字符设备文件,一般置于/dev目录下,一次传输一个字节的设备被称为字符设备,如键盘、字符终端等,传输数据的最小单位为一个字节。 |
p | pipe | 命令管道文件,与shell编程有关的文件 |
s | sock | sock文件,与shell编程有关的文件。 |
4、 硬链接,软链接
链接文件的概念类似于windows里的快捷方式。多个连接文件同时指向一个“源文件”。链接文件分为硬链接或符号链接两种。
- 硬链接:操作系统不区分链接创建的先后顺序,同一个文件所有的链接文件都是等价的,若一个文件存在两个链接,那么除去一个链接还可以通过另外一个链接来访问该文件,也可以除去创建链接时用到的文件,但只要还有一个链接存在,就可通过该连接访问文件。
- 符号链接(软链接):即建立一个独立的文件,这个文件会让数据的读取指向它链接的文件内容。
5、 文件访问方式
5.1 基本了解
2. drwxr-xr-x这里除了第一个字符d,指目录后面就是对不同用户访问权限的设置
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
r|- | w|- | x|- | r|- | w|- | x|- | r|- | w|- | x|- |
1—3位:设置所属用户的权限,如上例子,具有读、写、执行的权限
4—6位:设置同组用户的权限,如上例子,具有读、执行的权限
7—9位:设置其他用户的权限,如上例子,具有读、执行的权限
注:“-”说明该位的权限禁用了
5.2 修改权限
修改文件的权限使用chmod命令,有两种模式:
- 符号模式
命令的格式:chmod 用户 操作 权限 文件名
例如:chmod o + r myfile 给其他用户增加对myfile读的权限
“用户”有四种情况:
1》 u 所属用户
2》 g 同组用户
3》 o 其他用户
4》 a 所有用户(相当于ugo)
“操作”三种情况:
1》 + 增加权限
2》 - 取消权限
3》 = 设定权限
“权限”三种情况:(其他特殊的情况,暂时用不到,以后再学习)
1》r 读权限
2》w 写权限
3》x 执行权限
注:可以将这些符号组合使用,下面举几个例子
chmod go+r myfile 对myfile给其他用户和同组用户增加读的权限
chmod g+w o-r myfile 对myfile取消其他用户的读权限,增加对同组用户的写权限
- 绝对模式
命令的格式:chmod 模式 文件名
例如: chmod 640 myfile
注:对于每一个权限位都是一个八进制的数
八进制数 | 含义 | 八进制数 | 含义 |
0400 | 属主用户读权限 | 0010 | 同组用户执行权限 |
0200 | 属主用户写权限 | 0004 | 其他用户读权限 |
0100 | 属主用户执行权限 | 0002 | 其他用户写权限 |
0040 | 同组用户读权限 | 0001 | 其他用户执行权限 |
0020 | 同组用户写权限 |
|
|
计算模式方法
属主用户 | 同组用户 | 其他用户 |
r、w、x | r、w、x | r、w、x |
4+2+1 | 4+2+1 | 4+2+1 |
举几个例子:
chmod 760 myflie对myfile的属主用户赋予读、写、执行权限,同组用户读、写权限,其他用户不赋予任何权限
chmod 644 * 对目录下所有的文件进行设置权限,如果要将目录下的包括各个子目录下的所有文件都设置,则可以使用-R参数
注:相比绝对模式,符号模式可以对单个权限位进行设置。命令虽然比较长,但使用起来还是比较方便的。
6、 目录的权限
r | w | x |
可以列举其中的内容 | 可以在其中创建删除文件 | 可以进入和搜索该目录 |