专栏首页CU技术社区Linux学习笔记:文件的权限了解一下

Linux学习笔记:文件的权限了解一下

Linux 是一个多用户、多任务的系统,常常有多人同时使用一台机工作,为了保护每个人的隐私权,“文件所有者”的角色就显得相当重要了。当Linux用户登录系统之后,就会携带一个用户身份(User ID,UID)和一个用户组身份(Group ID,GID),相当于自己的名片。当需要访问文件或程序时,刷一下名片就能知道是否能读、写、执行了。。

在根目录下输入 ls -l 可看到如下信息:

每条记录由7部分组成,以 lrwxrwxrwx. 1 root root 7 Aug 18 21:27 bin -> usr/bin 为例,按照顺序,具体代表的含义是:

  • lrwxrwxrwx.代表的是文件类型和权限
  • 1 代表文件连接数
  • root 代表拥有者
  • root 代表所属用户组
  • 7 代表文件大小(以K为单位)
  • Aug 18 21:27 代表文件最后修改时间
  • bin -> usr/bin 文件名

先来拆分下lrwxrwxrwx.这串字符,其中第一个字符用来描述文件的类型,可选值为:

  • – 代表普通文件
  • d 代表目录
  • l 代表这个是软连接或硬连接
  • b 代表块设备,如磁盘等保存大块数据的设备
  • c 代表字符设备,如鼠标、键盘等需要连续串行读写的设备
  • s 代表套嵌字(socket)文件
  • p 代表命名管道文件

这个文件l,则代表是一个软连接或硬连接。紧接的9个字符,需要三个三个的看,分别代表着:

  • 拥有者的权限
  • 所属组的权限
  • 其他用户的权限

顺序为rwx,对应的是Read(读)、Write(写)、eXcute(执行)的权限,如果不具有某项权限,则使用-表示。

最后一个.可能让人很疑惑,是用来做什么的,查询了下,资料显示这个点表示的是存在“SELinux的安全标签”!,如果关闭了selinux,则不过出现该点。

另外注意到最后的这次演示的最后的文件名,存在着一个 -> 代表则软连接或硬连接,接下来就来学习下软连接和硬连接的区别。

  • 软连接(也称作符号链接——symbolic link, symlink or soft link),是一类特殊的文件, 其包含有一条以绝对路径或者相对路径的形式指向其它文件或者目录的引用。有点类似于windows的快捷方式。创建方式是: ln -s source dist
  • 硬连接,指通过索引节点来进行连接。在Linux的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(Inode Index)。在Linux中,多个文件名指向同一索引节点是存在的。一般这种连接就是硬连接。硬连接的作用是允许一个文件拥有多个有效路径名,这样用户就可以建立硬连接到重要文件,以防止“误删”的功能。其原因如上所述,因为对应该目录的索引节点有一个以上的连接。只删除一个连接并不影响索引节点本身和其它的连接,只有当最后一个连接被删除后,文件的数据块及目录的连接才会被释放。也就是说,文件真正删除的条件是与之相关的所有硬连接文件均被删除。创建方式是: ln source dist
  • 通过一些梳理,可以知道软连接与硬连接的一些异同:
  • 使用时差别不大,都相当于一个文件具有不同的路径或文件名
  • 输入删除文件连接的目标文件,软连接会失效,硬连接仅是“连接数-1”
  • 软链接可以创建在任何位置,包括网络,而硬连接必须在同一磁盘上

关于软连接和硬连接的详细介绍到整理inode相关知识点的时候再做介绍。

接下来学习的是修改文件的属性和权限,首先学习的是修改所属用户或用户组。命令格式: chown [-R] username:group filename (其中-R 在修改文件夹的时候使用,代表的是递归修改。)

修改读写权限共有两种方法:

1、数字法

权限rwx对应的是4,2,1,可以理解为3位的二进制,如果只要读 权限就是4,如果用户有读写权限,那么就是4+2=6,以此类推。

chmod 700 filename 执行的是设定用户有读写执行的权限,用户组、其他用户都没有权限。

2、文字法

文字法首先要引入四个字母:u、g、o、a,其中u代表user,g代表group,o代表other,a代表all。另外需要学习三个符号:+、-、=,分别代表增加、减去和设定,如: chmod ug+w filename ,意味着给filename 的用户及用户组添加写权限。

补充内容:

1、掩藏文件

刚开始的 ls -l 其实并没有把目录下的所有文件都显示出来,可以使用 ls -al 将所有的信息显示出来:

可以看到root的home目录下有很多前面带.的文件,这些文件就是Linux中的掩藏文件,在Linux中将文件在文件名前面加一.即可将文件掩藏。

2、特殊目录

Linux 下有几个特殊的目录:“.”、“..”、“-”、“~”

  • “.” 当前目录
  • “..” 上层目录
  • “-” 上一个工作目录
  • “~” 当前用户的home目录

3、特殊文件权限

Linux的文件除了rwx以外,还有s、t这两个特殊的权限。平时用的不多,不做深入学习。

来自:标点符 链接:http://www.biaodianfu.com/file-permission.html

本文分享自微信公众号 - CU技术社区(ChinaUnix2013),作者:标点符

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2018-07-06

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 时至 2018 年,还有必要学 Vim 吗?

    从上世纪九十年代起到现在 Vim 一直是最流行、应用最广泛的文本编辑器之一。程序员、作家、系统管理员、运维人员以及其他需要与文本文件打交道的人都在积极地使用它。...

    用户6543014
  • 基准测试|Windows 10 vs Ubuntu 19.10 vs Clear Linux vs Debian 10.1

    本周初,我为Firefox和Chrome提供了一些新的Windows vs. Linux Web浏览器基准测试。对于那些对当前Windows 10 vs.Lin...

    用户6543014
  • Windows,Mac 与 Linux 哪个更适合开发者?

    以前写的,怕引来口水战,干脆不发。这段时间面试了十来人,用Mac的开发水平明显高于Windows的,挺多感想的,于是改改发了吧。

    用户6543014
  • Linux学习笔记:文件的权限

    Linux 是一个多用户、多任务的系统,常常有多人同时使用一台机工作,为了保护每个人的隐私权,“文件所有者”的角色就显得相当重要了。当Linux用户登录系统之后...

    小小科
  • Linux学习笔记:文件的权限

    Linux 是一个多用户、多任务的系统,常常有多人同时使用一台机工作,为了保护每个人的隐私权,“文件所有者”的角色就显得相当重要了。当Linux用户登录系统之...

    小小科
  • 如何给U盘自定义图标

    FHYC
  • Spring Boot & Redis

    多线程环境下,使用池化技术,提高性能。对Jedis来说更是必须,否则还会出现数据错误。

    十毛
  • 走向面试之数据库基础:一、你必知必会的SQL语句练习-Part 2

    本文是在Cat Qi的参考原帖的基础之上经本人一题一题练习后编辑而成,非原创,仅润色而已。另外,本文所列题目的解法并非只有一种,本文只是给出比较普通的一种而已,...

    Edison Zhou
  • Hadoop之HDFS01【介绍】

    &esmp; HDFS(Hadoop Distributed File System)分布式文件系统。HDFS是一个高度容错性的系统,适合部署在廉价的机器上。H...

    用户4919348
  • SED入门

    使用Linux多年,SED和AWK两大神器却始终无法得心应手的来提高自己的工作效率,每每需要查找替换,都要依赖于ST2等一众图形工具,深感愧疚,乃专门抽时间学习...

    大江小浪

扫码关注云+社区

领取腾讯云代金券