【Linux权限】Shell命令及运行原理 | Linux权限管理 | 粘滞位 上

简介: 【Linux权限】Shell命令及运行原理 | Linux权限管理 | 粘滞位

文章目录

一、shell命令以及运行原理

Linux 严格意义上说的是一个操作系统,我们称之为核心 (kernel),也就是内核,但是一般用户,不能直接使用 kernel,而是通过 kernel 的外壳程序,也就是所谓的 shell 来与 kernel 沟通。

为什么不能直接使用 kernel ❓

从技术角度,Shell 的最简单定义:命令行解释器 (command Interpreter) 主要包含:

  • 将使用者的命令翻译给核心(kernel)处理。
  • 同时,将核心的处理结果翻译给使用者。

对比 windows GUI,我们操作 windows 不是直接操作 windows 内核,而是通过图形接口,点击,从而完成我们的操作 (比如进入 D 盘的操作,我们通常是双击 D 盘盘符,或者运行起来一个应用程序)。

shell 对于 Linux,有相同的作用,主要是对我们的指令进行解析,解析指令给 Linux 内核。反馈结果在通过内核运行出结果,通过 shell 解析给用户。

【帮助理解】

如果说你是一个闷骚且害羞的程序员,那 shell 就像媒婆,操作系统内核就是你们村头漂亮的且有让你心动的 MM小花。你看上了小花,但是又不好意思直接表白,那就让你家人找媒婆帮你提亲,所有的事情你都直接跟媒婆沟通,由媒婆转达你的意思给小花,而我们找到媒婆姓王,所以我们叫它王婆,它对应我们常使用的 bash。如果小花已经心有所属了,而你又死缠烂打,甚至想做出一些违法操作,媒婆就可以直接拒绝。

张三为什么不去直接找如花 ?&& 媒婆存在的价值 ?

  1. 解决张三不擅长的问题
  2. 保护如花

什么是shell ❓

shell 是包裹在操作系统外的一层软件层,它叫做命令行解释器。

为什么要存在shell ❓

  1. 解决用户不擅长与操作系统打交道
  2. shell 承担保护操作系统的角色

shell VS bash ❓

如果 shell 是媒婆,那么 bash 就是王婆。

也就是说 shell 是对所有外壳程序的统称,而王婆是具体的一个外壳程序 —— centos 7 > bash

也就是说不同的 Linux 环境,它们所使用的外壳程序不一定一样。

简单了解进程 ❓

Linux 在登录时,其实本质是系统创建一个登录进程,其中会为我们提供服务如通信服务、绘图服务等。对于进程我们可以从 windows 下打开任务管理器就可以看到每一个运行中的软件创建的进程。

当用户登录 Linux 系统的时候,系统会给用户创建一个进程,一般叫做 bash (命令行解释器 (服务) )

这里我们可以使用命令 ps axj | grep bash 查看当前系统的 bash 进程

复制 SSH 渠道后再次查看:增加了一个 bash 进程

二、Linux权限的概念

Linux 下有两种用户:

  1. 超级用户 (root):可以在 linux 系统下做任何事情,不受限制
  2. 普通用户:在 linux 下做有限的事情
  3. 超级用户的命令提示符是“#”,普通用户的命令提示符是“$”。

注意为了更好的学习,后面尽量少使用 root 用户。

root 用户是 Linux 中一个管理员的角色,且只有一个 root 帐户,它具有最高权限。

这里一定是得有两组密码的,且一定不要把两组密码设置成一样的。

怎么切换用户 ❓

命令:su [用户名]

功能:切换用户

例如,要从 root 用户切换到普通用户 user,则使用 su user。 要从普通用户 user 切换到 root 用户则使用 su root (root 可以省略),此时系统会提示输入 root 用户的口令。

su 和 su - ?

  1. su 只是切换了 root 身份,但是 shell 环境仍然是普通用户的 shell,且 pwd 仍是普通用户的目录
  2. su - 把用户和 shell 环境一起切换成了 root 身份,且 pwd 是 root 的目录

注意 su 同 su root,以后我们要安全切换成 root 时可直接 su -。

sudo ❓

如果不想切换成 root ,只想用 root 的身份去执行命令,可以在命令前加上 sudo,这样就可以对命令进行短期的权限提升。

注意我们在 sudo 的时候可能会报错,这里先不打算解决,因为涉及到后面学的知识,这里可以先用 su -。

三、Linux权限管理

什么是权限 ❓

权限本质上是决定某件事情,某人能否做。

文件权限 ❓

  1. 文件受人的影响 —— 为什么不能自定义博客域名?因为没有 VIP。
  2. 文件受本身自身特点 (事物属性) 的影响 —— 为什么不能看电影?因为它本身不具备视频属性。

所以文件权限 = 人 + 事物属性

文件权限属性:r(读)、w(写)、x(执行权限)

人 (不是特定具体的人,而是一种角色):拥有者、所属组、other (其它)

💦 文件访问者的分类(人)

  • 文件和文件目录的所有者:u —— User (中国平民 法律问题)
  • 文件和文件目录的所有者所在的组的用户:g —— Group (不多说)
  • 其它用户:o —— Others (外国人)

💦 文件类型和访问权限(事物属性)

a) 文件类型

  • d:文件夹
  • -:普通文件
  • l:软链接 (类似 windows 的快捷方式)
  • b:块设备文件 (例如硬盘、光驱等)
  • p:管道文件
  • c:字符设备文件 (例如屏幕等串口设备)
  • s:套接口文件

使用命令 ls -l (ll) 显示的多列属性的第一列对应的字符来区分它的文件类型。

查看文件类别还可以使用命令 file 查看:

b) 基本权限

  • i.读 (r/4):read 对文件而言,具有读取文件内容的权限;对目录而言,具有浏览目录信息的权限
  • ii.写 (w/2):write 对文件而言,具有修改文件内容的权限;对目录而言,具有删除移动目录内文件的权限
  • iii.执行 (x/1):execute 对文件而言,具有执行文件的权限;对目录而言,具有进入目录的权限

💦 文件权限值的表示方法

a) 字符表示方法

Linux表示 说明 Linux 说明
r - - 只读 - w - 仅可写
- - x 仅可执行 r w - 可读可写
- w x 可写可执行 r - x 可读可执行
r w x 可读可写可执行 - - - 无权限

b) 八进制数值表示方法

权限符号 (读写执行) 八进制 二进制
r 4 1 0 0
w 2 0 1 0
x 1 0 0 1
r w 6 1 1 0
r x 5 1 0 1
w x 3 0 1 1
r w x 7 1 1 1
- - - 0 0 0 0

其中我们可以直接使用八进制来替代 u、g、o 中的 r、w、x ❗

$ chmod 777 file.txt
$ chmod 000 file.txt
$ chmod 640 file.txt


相关文章
|
7月前
|
Linux 应用服务中间件 Shell
二、Linux文本处理与文件操作核心命令
熟悉了Linux的基本“行走”后,就该拿起真正的“工具”干活了。用grep这个“放大镜”在文件里搜索内容,用find这个“探测器”在系统中寻找文件,再用tar把东西打包带走。最关键的是要学会使用管道符|,它像一条流水线,能把这些命令串联起来,让简单工具组合出强大的功能,比如 ps -ef | grep 'nginx' 就能快速找出nginx进程。
791 1
二、Linux文本处理与文件操作核心命令
|
6月前
|
存储 安全 Linux
Linux卡在emergency mode怎么办?xfs_repair 命令轻松解决
Linux虚拟机遇紧急模式?别慌!多因磁盘挂载失败。本文教你通过日志定位问题,用`xfs_repair`等工具修复文件系统,三步快速恢复。掌握查日志、修磁盘、验重启,轻松应对紧急模式,保障系统稳定运行。
1093 2
|
7月前
|
缓存 监控 Linux
Linux内存问题排查命令详解
Linux服务器卡顿?可能是内存问题。掌握free、vmstat、sar三大命令,快速排查内存使用情况。free查看实时内存,vmstat诊断系统整体性能瓶颈,sar实现长期监控,三者结合,高效定位并解决内存问题。
638 0
Linux内存问题排查命令详解
|
7月前
|
存储 安全 Unix
七、Linux Shell 与脚本基础
别再一遍遍地敲重复的命令了,把它们写进Shell脚本,就能一键搞定。脚本本质上就是个存着一堆命令的文本文件,但要让它“活”起来,有几个关键点:文件开头最好用#!/usr/bin/env bash来指定解释器,并用chmod +x给它执行权限。执行时也有讲究:./script.sh是在一个新“房间”(子Shell)里跑,不影响你;而source script.sh是在当前“房间”里跑,适合用来加载环境变量和配置文件。
605 9
|
7月前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
619 2
|
关系型数据库 MySQL Shell
MySQL 备份 Shell 脚本:支持远程同步与阿里云 OSS 备份
一款自动化 MySQL 备份 Shell 脚本,支持本地存储、远程服务器同步(SSH+rsync)、阿里云 OSS 备份,并自动清理过期备份。适用于数据库管理员和开发者,帮助确保数据安全。
|
10月前
|
Shell
Shell脚本循环控制:shift、continue、break、exit指令
使用这些命令可以让你的Shell脚本像有生命一样动起来。正确使用它们,你的脚本就能像一场精心编排的舞蹈剧目,既有旋律的起伏,也有节奏的跳跃,最终以一场惊艳的表演结束。每一个动作、每一个转折点,都准确、优雅地完成所需要表达的逻辑。如此,你的脚本不只是冰冷的代码,它透过终端的界面,跳着有节奏的舞蹈,走进观众——使用者的心中。
348 60
|
7月前
|
数据采集 监控 Shell
无需Python:Shell脚本如何成为你的自动化爬虫引擎?
Shell脚本利用curl/wget发起请求,结合文本处理工具构建轻量级爬虫,支持并行加速、定时任务、增量抓取及分布式部署。通过随机UA、异常重试等优化提升稳定性,适用于日志监控、价格追踪等场景。相比Python,具备启动快、资源占用低的优势,适合嵌入式或老旧服务器环境,复杂任务可结合Python实现混合编程。
|
9月前
|
Web App开发 缓存 安全
Linux一键清理系统垃圾:释放30GB空间的Shell脚本实战​
这篇博客介绍了一个实用的Linux系统盘清理脚本,主要功能包括: 安全权限检查和旧内核清理,保留当前使用内核 7天以上日志文件清理和系统日志压缩 浏览器缓存(Chrome/Firefox)、APT缓存、临时文件清理 智能清理Snap旧版本和Docker无用数据 提供磁盘空间使用前后对比和大文件查找功能 脚本采用交互式设计确保安全性,适合定期维护开发环境、服务器和个人电脑。文章详细解析了脚本的关键功能代码,并给出了使用建议。完整脚本已开源,用户可根据需求自定义调整清理策略。
1043 1