【Linux】基本知识和权限(上)

简介: 【Linux】基本知识和权限(上)

1. Linux下的文件


1.1文件本身

问题:我们在Linux下创建一个空文件,那么这个文件占不占磁盘空间?

答:占用磁盘空间。因为文件 = 文件内容 + 文件属性(元数据),空文件是指文件内容为空,但是文件的创建时间,拥有者,权限等数据是需要被保存的,这些东西在磁盘中占用空间。


因为文件包含了内容和属性两个东西,所以我们学习操作文件的方法就要通过两个点:操作文件内容的操作文件属性的


1.2文件之间(普通文件 vs 目录)

这里介绍一个概念:Linux下一切皆文件

在Linux下的文件可以分为普通文件和目录,目录可以类比Windows下的文件夹,是用来保存其他文件的场所


1.3以 . 开头的文件

在【Linux】基本指令中我们讲到了ls指令有个选项是 -a 选项,看下面的实例,我们使用-a选项之后发现多了三个以 . 开头的文件,这三个文件是什么呢?

答:在Linux下,以 . 开头的文件是隐藏文件,并且,每个目录都会有两个文件 . 和 ..,分别表示当前目录和上级目录

e82a153b1d6d5c51beb7445ac6140e5b.png

问题:Linux下目录里面还可以再放目录吗?

答:可以,目录里面可以再放目录也可以放普通文件。

通过上面这个问题的回答,一个目录中可以放入目录,那么就可以这样套娃(递归)下去,这样我们就得到了一个类似与树的结构,这就是目录结构,几乎任何操作系统的目录结构都是一颗多叉树。既然是树形结构,那么就会有叶子节点和路上节点,通过一点点推理,我们可以得到一个结论:路上节点只能是目录,叶子节点可以是空目录,也可以是普通文件。

b09a98d204fe34c32510effa3c998cc6.png

Linux下的目录树

1.4文件路径

在【Linux】基本指令中我们讲到了pwd指令和cd指令,pwd指令的作用是查看当前所在工作目录的绝对路径,cd指令是进入到指定的目录,这里都提到了一个叫做路径的概念,那么为什么会有路径的概念存在?

答:因为路径+文件名 ==> 具有唯一性


我们说任何操作系统的目录结构都是一颗多叉树,在Linux下,这颗多叉树的根节点用/表示,上文中我们说到..表示上级目录,那么我们就可以使用cd ..指令去到上级目录。

29babd937ef5e3959d4c8676f04791c4.png

注意到,当退到/的时候就不能再继续往后退了,/就是根目录


路径分为绝对路径和相对路径,绝对路径是指从根目录开始,使用/分隔不同层级目录,按照层次指向目标文件。相对路径是指目标文件相对于当前位置的路径。相对路径一般较短,方便键入,所以在日常生活中我们使用相对路径的频率更高,那么绝对路径在什么情况下使用的呢?绝对路径的使用比较官方,一般是出现在配置文件中。


2.Linux下的一些”常识“与小技巧


1.工作目录

Linux是一个多用户的操作系统,可以允许多个用户同时登陆一个操作系统,那么就可能会出现多个用户的文件混乱的情况,所以Linux会给每个用户分配一个家目录,一般这个家目录的路径/home/usernam,所以我们也可以通过查看/home下的目录个数来判断当前这台机器有几个用户。但是root是特殊的,root的家目录是单独出来的,它的路径是/root


2.Linux下的”回收站“


我们知道,Linux下删除文件的指令是rm,但是这里的删除就是真正意义上的删除了,不会像Windows下删除之后还能在回收站中找回来。这样我们的操作就是不可挽回的,操作失误造成的后果严重,那么,我们能不能在Linux下自己实现一个回收站呢?答案当然是可以的,方法如下:

原理:创建一个目录,将rm指令改造一下,改造成mv指令,将需要删除的文件move到这个用于存放删除文件的目录。

操作:第一步:在当前用户家目录下创建一个回收站(.trash)

mkdir .trash

af3fadec98e31d6a2f206f1dd1eeea48.png

第二步:使vim打开当前用户家目录下的.brashrc文件

vim ~/.bashrc

a2642f0e49a63b450fad3c6640579b77.png

第三步:在.bashrc文件后追加并保存下面一段代码:

 25 # 替换rm
 26 alias rm=trash
 27 # 显示回收站文件
 28 alias rl='ls ~/.trash'
 29 # 文件移动
 30 trash()                                                                                                                                       
 31 {
 32     # 使用-f 隐藏覆盖文件的选项
 33     # 使用--backup=numbered将覆盖的文件备份起来,以数字追加到结尾的形式备份
 34     mv -f --backup=numbered $@ ~/.trash/
 35 }
 36 # 清空回收站
 37 cleartrash()
 38 {
 39     read -p "clear sure?[y/n]" confirm
 40     [ $confirm == 'y' ] || [ $confirm == 'Y' ] && /bin/rm -rf ~/.trash/*
 41 }

a87bb986e2625aa15a64f287d2e11516.png

第四步:更新环境

source ~/.bashrc

ce1adc5f0ecb52af98a33cd13148cb53.png

注意

  1. 这样更改之后,只有使用rm指令删除的东西才能在回收站.trash中找到,使用rmdir删除的不行。
  2. 使用cleartrash指令可以清空回收站
相关文章
|
20小时前
|
关系型数据库 MySQL Linux
Linux下mysql添加用户并授权数据库权限
Linux下mysql添加用户并授权数据库权限
|
1天前
|
Linux Shell 数据安全/隐私保护
【Linux2】Linux的权限
【Linux2】Linux的权限
|
5天前
|
缓存 关系型数据库 MySQL
linux 基本知识与命令
linux 基本知识与命令
|
13天前
|
安全 Linux Go
【Linux】Linux权限的概念 -- 详解
【Linux】Linux权限的概念 -- 详解
|
15天前
|
运维 Ubuntu 安全
运维最全linux 命令行操作串口_linux串口命令(2),2024年最新Linux运维源码的Binder权限是如何控制
运维最全linux 命令行操作串口_linux串口命令(2),2024年最新Linux运维源码的Binder权限是如何控制
运维最全linux 命令行操作串口_linux串口命令(2),2024年最新Linux运维源码的Binder权限是如何控制
|
20天前
|
Linux 调度 C语言
|
20天前
|
Linux
如何在 Linux 中递归更改文件的权限?
【5月更文挑战第10天】
30 3
|
20天前
|
算法 Linux 数据安全/隐私保护
Linux:权限
Linux:权限
24 0
|
20天前
|
Linux 数据安全/隐私保护 Windows
【Linux】权限 !
关于Linux的权限问题,可以理解为不同级别的工作者,分别拥有不同的能力来管理文件。
30 5
|
20天前
|
Linux 开发工具 数据安全/隐私保护
深入探索Linux:ACL权限、特殊位与隐藏属性的奥秘
深入探索Linux:ACL权限、特殊位与隐藏属性的奥秘