【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指令可以清空回收站
相关文章
|
4月前
|
Linux Shell
Linux系统文件默认权限
Linux系统文件默认权限
85 2
|
3月前
|
Linux 数据安全/隐私保护
linux特殊权限!!
本文介绍了Linux系统中的特殊权限,包括suid、sgid和sbit。suid使普通用户在执行特定命令时获得root权限;sgid使用户在创建文件时继承目录的用户组权限;sbit确保用户只能删除自己在共享目录中创建的文件。此外,文章还讲解了chattr和lsattr命令,用于更改和查看文件的扩展属性,以及umask的概念和计算方法,帮助理解文件和目录的默认权限。
86 1
linux特殊权限!!
|
4月前
|
运维 监控 安全
Linux_权限理解(详细PLUS)
【10月更文挑战第3天】本文介绍了Linux系统中的权限管理基础,包括文件系统对象与权限关联、权限的继承性、字符与数字表示法的解读,以及用户、组与权限的动态交互。详细解析了`chmod`命令的高级用法和权限修改的风险,探讨了SUID、SGID和Sticky Bit等特殊权限的作用机制,并提出了基于角色的权限分配和定期权限审计的最佳实践。
113 11
|
4月前
|
Linux 应用服务中间件 nginx
Linux下权限设置之suid、sgid、sticky
Linux下权限设置之suid、sgid、sticky
|
4月前
|
Linux 数据安全/隐私保护 Windows
Linux_权限理解(详细PLUS
Linux_权限理解(详细PLUS
|
4月前
|
网络协议 Linux 网络安全
【Linux】用户和权限及实用操作------迅速了解用户和权限及其实用操作
【Linux】用户和权限及实用操作------迅速了解用户和权限及其实用操作
|
4月前
|
Linux Go 数据安全/隐私保护
Linux入门2——初识Linux权限
Linux入门2——初识Linux权限
44 0
|
6月前
|
Unix Linux Go
Linux中的chmod权限问题
Linux中的chmod权限问题
87 0
|
6月前
|
安全 Linux 数据安全/隐私保护
在Linux中,使用rsync服务模式时,如果指定了⼀个密码文件,那么这个密码文件的权限应该设置成多少才可以?
在Linux中,使用rsync服务模式时,如果指定了⼀个密码文件,那么这个密码文件的权限应该设置成多少才可以?
|
6月前
|
Linux
在Linux中,如何使用xargs和exec实现把当前目录下所有后缀名为.txt的⽂件的权限修改为777。
在Linux中,如何使用xargs和exec实现把当前目录下所有后缀名为.txt的⽂件的权限修改为777。