【从零开始学习Linux】一文带你了解Shell外壳及用户权限(一)

news2025/2/27 17:27:27

🚩纸上得来终觉浅, 绝知此事要躬行。
🌟主页:June-Frost
🚀专栏:Linux入门

🔭【从零开始学习Linux】系列均属于Linux入门,主要包含Linux操作系统下的指令、操作、权限以及开发工具,使得拥有基本编写代码的能力。

🔥该文章主要了解Shell外壳(理论)及用户权限,其中用户权限将分为两部分进行总结叙述。

目录:

  • 🔭 操作系统的基本结构和运行原理
  • 🔭 用户权限
    • ✉️ 用户的分类
    • ✉️ 身份切换(su指令)
    • ✉️ 短暂提权
  • 🔭 权限管理
    • ✉️ 更改权限
  • ❤️ 结语

🔭 操作系统的基本结构和运行原理

 内核和外壳是操作系统的两个主要组成部分。

 内核是操作系统的核心,负责管理系统的硬件和软件资源。它直接与硬件设备进行交互,控制硬件设备、管理内存、提供硬件接口、处理基本I/0、管理文件系统等。此外,内核还为程序分配内存和CPU时间,以及提供系统调用接口,以便应用程序能够使用操作系统的功能。

 外壳是用户与内核交互的界面,它提供了用户与操作系统的交互方式。它实际上是一个命令解释器,解释用户输入的命令并送到内核执行。它还提供了一些基本的命令和工具,例如文件管理、进程管理、设备管理等。此外,外壳还提供了图形界面(例如windows系统),使得用户可以通过图形界面与操作系统进行交互。

 内核与外壳协同工作,使得计算机能够正常运转,并为应用程序提供稳定、高效的运行环境。

重点来了❗️

 对于Linux系统来说,其内核本身只是一个基础组件。由于考虑到操作系统的易用性(用户不能直接访问操作系统)和安全性(防止用户非法操作导致操作系统受到损害),于是shell外壳就有了存在的意义,它是用户与内核之间的桥梁,为用户提供操作系统的接口。Shell外壳可以理解为用户与操作系统之间的交互界面,它接收用户输入的指令并提交给内核处理,同时将处理结果反馈给用户

 Shell外壳是一个用C语言编写的程序,在系统启动期间,它都会存在。当用户输入有风险,自定义的指令时,Shell会创建子进程去执行该操作。

 在CentOS 7 中 ,Shell通过Bash具体实现。


🔭 用户权限

✉️ 用户的分类

  Linux下一般有两种用户:

  • 超级管理员:具有一切操作权力,其用户名为root
  • 普通用户:为了使用Linux系统资源而建立的,通常由管理员创建,权限受限。

✉️ 身份切换(su指令)

  • 语法su [用户名]
    功能:变更用户身份。

 如果使用su命令时没有指定用户,那么默认会切换到root用户的身份。并且,su - 也可以切换到root用户。

susu - 是不一样的,主要区别在于它们切换用户身份时所携带的Shell环境su命令只切换用户身份,而不改变Shell环境。这意味着,使用su命令切换到root用户后,你的工作目录和环境变量仍然保持原用户的设置,而不是root用户的设置。相比之下,su-命令在切换用户身份的同时,也会将Shell环境切换到目标用户的环境。具体来说,使用su-命令切换到root用户后,你的工作目录会变成root用户的工作目录,环境变量也会变成root用户的环境变量。

📙注意:

  1. 当普通用户切换成root用户是需要输入root密码的。
  2. 当普通用户切换到另一个普通用户则需要对方的密码。
  3. root用户切换为普通用户是不需要密码的。


✉️ 短暂提权

  在Linux或Unix系统中,当你需要执行需要管理员权限的命令,但又不想以root用户身份登录时,可以使用sudo。例如,你可能需要使用sudo来安装软件包、修改系统配置、执行系统管理等操作。

📙sudo:

  • 语法sudo [选项] 命令
  • 功能:用于暂时获得超级用户权限来执行特定的命令。

 使用sudo时,需要输入当前用户的密码以验证其权限。这里无法执行是因为cy用户不在白名单中,需要使用vim去改变配置文件。


🔭 权限管理

 可以从两个方面去看待权限,首先权限一定存在身份限制,定义了用户对特定资源的访问能力,其次权限一定得保证对应的资源有人们所需的属性,例如:影视软件的属性就是让人们观看电影,而身份(vip)的不同决定了能免费观看什么电影。

 在之前的文章中,提到了Linux系统的一个设计理念——Linux系统下一切皆文件,所以谈及Linux的权限问题,主要是在文件权限上。

📗在Linux中,访问者的身份分为3类:

  • 拥有者(owner)指的是创建文件或目录的用户,每个文件或目录都有一个唯一的拥有者。拥有者可以对该文件或目录进行修改、删除等操作。
  • 所属组(group)是拥有者所在的组,可以是系统中的任何一个组。所属组决定了拥有者所在的组对文件或目录的访问权限。
  • other是指不属于拥有者和所属组的用户,也就是除了拥有者和所属组的成员之外的所有用户。other用户对文件或目录的访问权限取决于系统管理员设置的权限。

💫 所属组存在的意义:

 所属组(group)的存在主要是出于管理方面的考虑,尤其是要控制对文件和其他系统资源的访问。在Linux中,每个用户都可能隶属于一个或多个组,而每个组也都有唯的一个名称和一个组标识符(GID)。用户和组ID的主要用途有二:一是确定各种系统资源的所有权;二是控制赋予进程访问上述资源的权限。例如,每个文件都属于某个特定的用户和组,而每个进程也拥有相应的用户ID和组ID属性,这就决定了进程的所有者,以及进程访问文件时所拥有的权限。

 在团队工作的场景下,所属组的概念就很容易理解。比如在老师的计算机里,可以设置文件权限,就能限制非自己班级(即非本组)的其他用户的可读权限,也可以让自己的班级(即本组)成员可以修改文件。

📗Linux中操作的对象是文件,而文件对应的属性也有3种:

  • 读(r):表示具有读取文件内容的权限。
  • 写(w):表示具有修改文件内容的权限。
  • 执行(x):表示具有执行文件的权限。

 在文件属性列表上,对应有9个字符,每3个为一组,分别对应拥有者,所属组和other的权限。例如:这个文件拥有者的权限为rw- ,说明拥有者有读权限,写权限,但是没有执行权限。

 如果一个用户同时是拥有者和所属组,系统在匹配时只会匹配一次,会将该用户匹配到拥有者,然后看对应是否有权限,所以如果同一个用户如果作为拥有者没有读权限,作为所属组有读权限,在这种匹配下是不可以读文件的。

⏳ 对于一个文件是否可执行,需要满足两个条件:① 有执行权限。② 该文件是个可执行文件。

✉️ 更改权限

 一般来说,只有文件的拥有者和root才可以改变文件的权限。

📙chmod:

  • 语法chmod [参数] 权限 文件名
  • 功能:更改文件或目录的权限。它允许用户控制谁可以读取、写入和执行文件。
  • 常用选项R 递归修改目录文件的权限

  权限的表示格式:[{ugoa}{+-=}{rwx}]

u:表示拥有者(owner)权限。
g:表示所属组(group)权限。
o:表示其他用户(others)权限。
a:表示所有用户(all)权限。
+:表示添加(增加)权限。
-:表示移除(删除)权限。
=:表示设置(明确)权限。
r:表示读取(read)权限。
w:表示写入(write)权限。
x:表示执行(execute)权限。

 这些参数可以组合在一起使用,以精确地控制需要修改的权限。

在这里插入图片描述

 除了这种方式,还有一种三位8进制数字的方式来改变权限。由于一个身份所对应的文件权限,就只有rwx,那么每一位如果有对应的权限就为1,如果没有就为0,所以就形成了 000 ~ 111 的一个二进制组合,转化8进制就为0~7。例如:chmod 755 filename 就会将文件的拥有者设置为读、写和执行权限,而所属组和其他用户只有读和执行权限。


❤️ 结语

 文章到这里就结束了,如果对你有帮助,你的点赞将会是我的最大动力,如果大家有什么问题或者不同的见解,欢迎大家的留言~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1158362.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

k8s之集群调度

目录 调度 工作机制 调度过程 调度算法 优先级 指定调度节点 调度 Kubernetes 是通过 List-Watch 的机制进行每个组件的协作,保持数据同步的,每个组件之间的设计实现了解耦。 用户是通过 kubectl 根据配置文件,向 APIServer 发送命令…

SandboxAQ推出量子安全“守卫军”!开源框架和加密算法元库Sandwich

Sandwich示意图(图片来源:网络) 未来几年,IT领域需要对当今计算机通信网络中使用的密码学协议进行一些重大更改,以确保它们仍然安全,且对未来的量子计算机具有应对能力。 其中一个关键特征称为加密敏捷性…

黑芝麻智能助力亿咖通·天穹Pro行泊一体智能驾驶计算平台正式量产

11月1日,亿咖通科技旗下首款智能驾驶计算平台——亿咖通天穹Pro行泊一体智能驾驶平台已向客户开始正式量产交付。亿咖通天穹行泊一体智能驾驶计算平台是亿咖通科技基于黑芝麻智能华山二号A1000,由双方合作研发并推出的具备行泊一体能力的智能驾驶解决方案…

【Linux进程】先谈硬件—冯诺依曼体系结构

目录 冯诺依曼体系 冯诺依曼体系结构 冯诺依曼体系的工作流程 为什么一个程序要运行,必须的先加载到内存中运行? 从软件数据流角度理解冯诺依曼 冯诺依曼体系结构 我们常见的计算机,如笔记本。我们不常见的计算机,如服务器&#xff0c…

信息收集-web架构-源码

一、web架构资产-平台指纹识别-源码 代码审计,从代码中挖掘漏洞,有代码才能做的,没有代码(黑盒),有代码(白盒) 没有源码只能做黑盒,有源码黑白盒都可做 有源码成功率高…

学习笔记二十七:K8S控制器Statefulset入门到企业实战应用

这里写目录标题 Statefulset控制器:概念、原理解读Statefulset资源清单文件编写技巧查看定义Statefulset资源需要的字段查看statefulset.spec字段如何定义?查看statefulset的spec.template字段如何定义 Statefulset使用案例:部署web站点State…

Java 实现灰度图转真彩图

目录 1 问题2 实现1 问题 Java 实现灰度图转真彩图 将以上的图片,jpg png 都可以,转为有颜色的 2 实现 import javax.imageio.ImageIO; import java.awt.*; import java.awt.image.BufferedImage; import java.awt.image.Raster; import java.io.File;public class DatUtil…

k8s之pod进阶---资源限制与探针

目录 一、资源限制 二、探针(健康检查) 2.1 含义 2.2 探针的三种规则 2.3 probe支持三种检查方法 2.4 探针的示例 1、存活探针:livenessProbe (1)exec方式 (2)httpGet方式 (…

百度 | 文心一言也开始收费了

好久没用文心一言了 之前一直用ChatGPT的 今天打开文心一言一看,好家伙 出了文心大模型4.0,想体验一下来着 可惜是收费的 看下价格,没买 50块钱一个月,对比ChatGPT4来说,确实不算贵 毕竟gpt4一个月20美刀 ,…

CEYEE希亦新品洗地机Pro系列发布, 领跑行业的「水汽混动」技术的旗舰新杰作

CEYEE希亦全新一代洗地机T800 PRO正式上市,采用双滚刷,双倍活水洗拖洗方式,达到拖一遍抵两遍,相对于10倍洁净效果! 这款希亦Pro系列产品不仅刷新了洗地机行业技术水准,满足了用户愈发极致的清洁效能追求&a…

小白学习必看,NAS网络存储详细学习

NAS(Network Attached Storage:网络附属存储)按字面简单说就是连接在网络上,具备资料存储功能的装置,因此也称为“网络存储器”。它是一种专用数据存储服务器。它以数据为中心,将存储设备与服务器彻底分离&…

急诊医学科常用评估量表汇总,建议收藏!

根据急诊医学科医生的量表使用情况,笔者整理了10个急诊医学科常用量表,可在线评测直接出结果,可转发使用,可生成二维码使用,可创建项目进行数据管理,有需要的小伙伴赶紧收藏! 1.急性生理学与慢性…

11月的『备考学习计划』+高效的作息时间表 超好用~

每日作息时间表 每天有三个时间段学习效率高 上午10点左右 下午4点左右 晚上8点-10点左右 坚持住了,学习效果事半功倍 有同感的同学 可以举举手🤚,点点赞💓 每日作息时间表 6:30-7:00起床 6:30---7:00是起床的最佳时刻&am…

报错-TypeError: Cannot read properties of undefined (reading ‘url‘)

背景:使用pinia进行状态管理,优化接口调用请求时,报错 TypeError: Cannot read properties of undefined (reading url) TypeError:无法读取未定义的属性(读取“url”) 解决:花括号的属性未定义&#xf…

人工智能基础_机器学习013_三种梯度下降对比_线性回归梯度下降更新公式_对梯度下降函数求偏导数_得到---人工智能工作笔记0053

这里批量梯度下降,就是用准备的所有样本数据进行梯度下降计算. 然后小批量梯度下降就是使用比如我一共有500个样本,那么我从中拿出50个样本进行梯度下降计算. 然后随机梯度下降,更厉害, 从一共有500个样本中,随机的取一个样本进行梯度下降计算, 首先我们看批量梯度下降,使用…

如何在 Photoshop 中使用位图模式制作自定义音乐海报

如何在 Photoshop 中使用位图创建炫酷的音乐海报设计。 1.如何设置新的 Photoshop 文件 步骤1 在 Photoshop中,转到 “文件”>“新建”。将文档命名为 “音乐海报”。 将宽度设置 为 1270 px , 高度 设置为 1600 px。将分辨率 设置 为 72 像素/英寸…

【案例】3D地球(vue+three.js)

需要下载插件 <template><div class"demo"><div id"container" ref"content"></div></div> </template> <script> import * as THREE from three; // import mapJSON from ../map.json; import { Or…

【笔记】Arrays.binarySearch()实践,以及需要注意的一些问题点

背景&#xff1a;我想校验一个指定的String字符串&#xff0c;是否存在于另一个String数组中&#xff0c;选择Arrays.binarySearch()方法实现&#xff0c;代码如下&#xff1a; String[] item {"0","1","16","1591","1594"…

Java程序员面试核心知识--Java基础知识(一)

目录 一、Java程序初始化顺序 二、Java的Clone方法作用 三、 OverLoad&#xff08;重载&#xff09;与Override&#xff08;重写&#xff09;区别 四、abstract class&#xff08;抽象类&#xff09;与interface&#xff08;接口&#xff09;的异同 五、String、StringBuf…

行业追踪,2023-11-01

自动复盘 2023-11-01 凡所有相&#xff0c;皆是虚妄。若见诸相非相&#xff0c;即见如来。 k 线图是最好的老师&#xff0c;每天持续发布板块的rps排名&#xff0c;追踪板块&#xff0c;板块来开仓&#xff0c;板块去清仓&#xff0c;丢弃自以为是的想法&#xff0c;板块去留让…