[LINUX]基本权限

news2024/11/26 22:44:20

🥁作者华丞臧.
📕​​​​专栏:【LINUX】
各位读者老爷如果觉得博主写的不错,请诸位多多支持(点赞+收藏+关注)。如果有错误的地方,欢迎在评论区指出。
推荐一款刷题网站 👉 LeetCode刷题网站


文章目录

  • shell命令以及运行原理
  • Linux用户
    • useradd & userdel指令
      • useradd
      • userdel
    • su指令
    • sudo提权
  • Linux权限的概念及管理
    • 什么是权限
    • Linux文件类型
    • 如何操作权限
      • chmod指令
      • chown指令
      • chgrp指令
      • file指令
      • umask指令
      • 目录的权限
      • 粘滞位


shell命令以及运行原理

Linux严格意义上说的是一种操作系统,我们称之为核心(Kernel),一般用户不能直接使用(Kernel)。而是通过Kernel的“外壳”程序,也就是所谓的shell,来与Kernel沟通。那么为什么不直接使用Kernel呢?

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

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

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

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

  • 帮助理解:如果说你是一个闷骚且害羞的程序员,那shell就像媒婆,操作系统内核就是你们村头漂亮的且有让你心动的MM小花。你看上了小花,但是又不好意思直接表白,那就让你你家人找媒婆帮你提亲,所有的事情你都直接跟媒婆沟通,由媒婆转达你的意思给小花,而我们找到媒婆姓王,所以我们叫它王婆,它对应我们常使用的bash;
  • 执行命令:通过派生子进程的方式执行用户的指令,而shell本身并不执行对应的指令(一般而言);
  • shell存在的意义,变相保护操作系统。

在这里插入图片描述

Linux用户

Linux下有两种用户:超级用户(root)、普通用户

  • 超级用户:可以再linux系统下做任何事情,不受限制;
  • 普通用户:受Linux中权限约束的用户;
  • 超级用户的命令提示符是“#”,普通用户的命令提示符是"$"。

在这里插入图片描述

useradd & userdel指令

useradd

语法:useradd -[选项] [用户名]
功能:创建一个新用户(使用时可能需要sudo提权);
常用选项:

  • -m 自动创建用户的登入目录

在这里插入图片描述

userdel

语法:userdel -[选项] [用户名]
功能:删除一个用户(使用时可能需要sudo提权);
在这里插入图片描述

su指令

语法:su [用户名]
功能:切换用户
例如,要从root用户切换到普通用user,则使用su user(user指用户名)。要从普通用户user切换到root用户则使用su root(root可以省略),此时系统会提示输入root用户的命令(即密码)。
+

可以看到root超级用户权限非常大,从root切换到普通用户可以直接切换不需要密码。

还可以使用一下命令切换到超级用户:
su -:该命令会重新登录root用户
在这里插入图片描述
su:该命令不会重新登录root用户,即切换用户前后所在的路径不会改变。
在这里插入图片描述

普通用户退回超级用户的方法:

  1. su root || su -
  2. exit

在这里插入图片描述

sudo提权

语法:sudo [一段命令]
功能:不切换用户,让普通用户短暂的提权,即短暂以root用户的身份执行命令。(sudo是给距离最近的一个指令提权)

注意:sudo提权必须是系统信任的用户。即需要用root用户将当前用户添加到/etc/sudoers中(简单了解)。

  • 白名单:系统无条件相信的用户;
  • 黑名单:系统不信任的用户。

在这里插入图片描述
进行sudo提权需要输入普通用户自己的密码,目的是为了给受信任的用户,提供最少的执行障碍

Linux权限的概念及管理

什么是权限

在现实当中,权限是约束一个或者某些群体的。

例如,腾讯视频app当中,有普通用户和VIP用户(角色),当我们使用app时里面的电影(业务)有些任何人都能看,有些只有vip有权限能看,vip这个角色能赋予我们看vip电影的权限。

权限:某事情是否允许被谁做
在Linux中,权限一般指文件权限:

文件权限 = 角色 + 文件属性。

在Linux中,分为以下三种角色:

1. 拥有者(owner)
2. 所属组(grouper)
3. 其他人(other)

在Linux中,分为四种文件属性:

1. r(read,读)对文件而言,具有读取文件内容的权限;对目录来说,具有浏览该目录信息的权限;
2. w(write,写)对文件而言,具有修改文件内容的权限;对目录来说具有删除移动目录内文件的权限;
3. e(execute,执行)对文件而言,具有执行文件的权限;对目录来说,具有进入目录的权限;
4. - 表示不具有该项权限

Linux文件类型

Linux和Window中文件类型差别很大,Windows中以文件的后缀来区分文件类型,而在Linux中不是以文件的后缀来区分文件类型。
注意Linux中也可以使用后缀区分文件类型,但仅仅是给用户做一个提示符号来使用,后缀本质其实就是文件名的一部分

通过ll指令显示的众多属性列中的第一列的第一个字符区分文件类型。
在这里插入图片描述

常见的Linux中的文件类型
-:普通文件(源代码、库文件、可执行程序、文档压缩包等等)
在这里插入图片描述

d:目录文件
在这里插入图片描述

c:字符设备文件(比如:键盘、显示器)
在这里插入图片描述

b:块设备文件(磁盘)
在这里插入图片描述

l:链接文件(快捷方式本质就是链接文件)
在这里插入图片描述

p:管道文件()
在这里插入图片描述

s:socet文件(基本不会见到)

注意:Linux识别文件类型与后缀无关,并不代表Linux当中的工具对识别文件类型没有这个要求。

通过ll指令显示的众多属性列中的第一列,一共有十个字符除去第一个字符还有九个字符,这九个字符三个三个为一组分别代表拥有者、所属组、其他人对于该文件的权限。
在这里插入图片描述

如何操作权限

chmod指令

功能:设置文件的访问权限
格式:chmod [参数] 权限 文件名
常用选项:

  • R -> 递归修改目录文件的权限
  • 说明:只有文件的拥有者和root才可以改变文件的权限
  1. chmod用户表示符+/-=权限字符
  • +:向权限范围增加权限代号所表示的权限
  • -: 向权限范围取消权限代号所表示的权限
  • =:向权限范围赋予权限代号所表示的权限
  • 用户符号:
  • u:拥有者
  • g:拥有者同组用
  • o:其它用户
  • a:所有用户
Linux说明Linux表示说明
r–只读-w-仅可写
–x仅可执行rw-可读可写
-wx可写可执行r-x可读可执行
rwx可读可写可执行无权限

实例:
在这里插入图片描述

注意:在Linux系统中,匹配使用者会从左边拥有者的身份开始匹配,如果匹配上就不会再匹配之后的身份了。

root用户不受权限约束
在这里插入图片描述

  1. 三位8进制数字
    语法:chmod [xxx] [文件名]
    权限还可以通过以下方式表示和更改,即9位二进制三个一组转成8进制。
    在这里插入图片描述

8进制数值表示方法:

权限符号(执行)八进制二进制
r4100
w2010
x1001
rw6110
rx5101
wx3011
rwx7111
0000

在这里插入图片描述

chown指令

语法:chown [用户名] [文件名]
功能:修改文件的拥有者。

注意:修改文件的拥有者,如果是普通用户需要使用sudo提权(root用户不需要)。

在这里插入图片描述

在这里插入图片描述

chgrp指令

功能:修改文件或目录的所属组
格式:chgrp [参数] 用户组名 文件名
常用选项:-R 递归修改文件或目录的所属组
实例:
在这里插入图片描述

file指令

功能说明:辨识文件类型。
语法:file [选项] 文件或目录…
常用选项

  • -c 详细显示指令执行过程,便于排错或分析程序执行的情形。
  • -z 尝试去解读压缩文件的内容。

在这里插入图片描述

为什么要有权限?

便于系统进行安全管理。

umask指令

首先,为什么我们创建的目录或者普通文件,默认权限是我们所看到的的样子?

Linux规定,目录起始权限是777,而普通文件起始权限是666。而我们所看到的并不是这两个,因为在起始权限之下,系统还有一个umask我们称为权限掩码,系统会默认配置好umask,权限掩码是可以通过umask指令修改的。

权限掩码:凡是在umask中出现的权限,都必须在起始权限中去掉。

在这里插入图片描述
改变权限掩码
在这里插入图片描述

最终权限 = 起始权限 & (~umask)
umask显示出的是4位的8进制

在这里插入图片描述

目录的权限

  • 可执行权限( x ): 如果目录没有可执行权限, 则无法cd到目录中
  • 可读权限( r ): 如果目录没有可读权限, 则无法用ls等命令查看目录中的文件内容.
  • 可写权限( w ): 如果目录没有可写权限, 则无法在目录中创建文件, 也无法在目录中删除文件.所有目录被创建出来,一般都要能被进入,所以系统规定一个目录权限必须是777开始。

换句话来讲, 就是只要用户具有目录的写权限, 用户就可以删除目录中的文件, 而不论这个用户是否有这个文件的写权限。

粘滞位

语法:chmod +t [目录名]
功能:给目录加上粘滞位(权限的一种特殊情况)。
常用选项

  • +t 设置粘滞位
  • -t 取消粘滞位

Linux系统是支持多用户的系统,那么就存在以下场景:

在Linux系统中有很多人,我们需要在一个公共的目录下,进行临时文件的操作(增删查改)。假设张三、李四都在这个公共目录下且都具有目录的写权限,那么张三创建一个文件,李四却可以删除张三创建的文件,这是不是很不合理。

粘滞位能很好解决上述问题,粘滞位的作用如下:

让一个公共目录,大家各自可以进行rwx操作,但是禁止大家互删对方的文件。

在这里插入图片描述

当一个目录被设置为"粘滞位"(用chmod +t),则该目录下的文件只能由:

  1. 超级管理员删除
  2. 该目录的所有者删除
  3. 该文件的所有者删除

关于目录权限的总结:

  • 目录的可执行权限是表示你可否在目录下执行命令;
  • 如果目录没有-x权限,则无法对目录执行任何命令,甚至无法cd 进入目, 即使目录仍然有-r 读权限(这个地方很容易犯错,认为有读权限就可以进入目录读取目录下的文件);
  • 而如果目录具有-x权限,但没有-r权限,则用户可以执行命令,可以cd进入目录。但由于没有目录的读权限;所以在目录下,即使可以执行ls命令,但仍然没有权限读出目录下的文档。

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

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

相关文章

web前端网页设计与制作——华夏第一县HTML+CSS+JavaScript

家乡旅游景点网页作业制作 网页代码运用了DIV盒子的使用方法,如盒子的嵌套、浮动、margin、border、background等属性的使用,外部大盒子设定居中,内部左中右布局,下方横向浮动排列,大学学习的前端知识点和布局方式都有…

【C++】C++入门

屏幕前的你,一起加油啊!!! 文章目录一、命名空间(namespace)1.命名空间的定义(::域作用限定符)2.命名空间的使用(三种使用方式)二、C输入&输出&#xff…

Maven pom.xm javafx-maven-plugin打包javafx 应用及调试

1、添加 javafx-maven-plugin到 plugin内 <plugin><groupId>com.zenjava</groupId><artifactId>javafx-maven-plugin</artifactId><version>8.8.3</version><configuration><!-- 启动类 --><mainClass>com.test.d…

【春招必备】Java面试题,面试加分项,从jvm层面了解线程的启动和停止

前言 Spring 作为一个轻量级的 Java 开发框架&#xff0c;将面向接口的编程思想贯穿整个 Java 系统应用&#xff0c;因此在 Java 面试中常被提。本次介绍的主要是解析面试过程中如果从源码角度分析常见的问题&#xff0c;为了方便大家阅读&#xff0c;小编这里还整理了一份微服…

零拷贝技术面试题

文章目录1 零拷贝的介绍2 传统的IO的执行流程3 零拷贝涉及的技术点3.1 内核空间和用户空间3.2 用户态和内核态3.3 DMA技术4 零拷贝实现的几种方式4.1 mmapwrite4.2 sendfile4.3 sendfileDMA scatter/gather实现的零拷贝5 java提供的零拷贝方式5.1 Java NIO对mmap的支持5.2 Java…

抖音快手如何轻松接入虚拟人直播

在上一篇文章零基础开启元宇宙——创建虚拟形象中&#xff0c;我们实现了创建虚拟形象&#xff0c;接下来我们可以利用虚拟形象“为所欲为”。今天我们利用虚拟形象在短视频平台如快手、抖音中直播&#xff0c;对于不希望露脸的主播们这是可是一大利器呀&#xff01;话不多说&a…

【Unity项目实战】手把手教学:飞翔的小鸟(5)背景滚动

承接上一篇&#xff1a;【Unity项目实战】手把手教学&#xff1a;飞翔的小鸟&#xff08;4&#xff09;文本添加&#xff0c;我们已经使得主角小鸟接触到地面后跳转到Game Over状态&#xff0c;接下来我们将继续往下&#xff0c;讲解得分机制。 一、重新进入游戏 根据上篇最后…

网络流量回溯分析助力企业实现高效率运维(一)

背景 汽车配件电子图册系统是某汽车集团的重要业务系统。业务部门反映&#xff0c;汽车配件电子图册调用图纸时&#xff0c;出现访问慢现象。 某汽车总部已部署NetInside流量分析系统&#xff0c;使用流量分析系统提供实时和历史原始流量。本次分析重点针对汽车配件电子图册系…

[附源码]Node.js计算机毕业设计二手书交易软件设计与实现Express

项目运行 环境配置&#xff1a; Node.js最新版 Vscode Mysql5.7 HBuilderXNavicat11Vue。 项目技术&#xff1a; Express框架 Node.js Vue 等等组成&#xff0c;B/S模式 Vscode管理前后端分离等等。 环境需要 1.运行环境&#xff1a;最好是Nodejs最新版&#xff0c;我…

数据技术之数据挖掘

第7章 数据挖掘 1.什么是数据挖掘 数据挖掘(Data Mining)就是从大量的数据中&#xff0c;提取隐藏在其中的&#xff0c;事先不知道的、但潜在有用的信息的过程。数据挖掘的目标是建立一个决策模型&#xff0c;根据过去的行动数据来预测未来的行为。 2.阿里数据挖掘平台 阿里…

Java-1213

JVM历程 Sun Classic VM 1996年发布&#xff0c;世界上第一款商用Java虚拟机&#xff0c;JDK1.4时被淘汰&#xff0c;现在hotspot内置了此虚拟机 这款虚拟机只提供了解释器&#xff08;现在主流的虚拟机还会提供即时编译器JIT&#xff09;解释器和JIT两者用一个就可以让程序执…

分享一种 ConstraintLayout 让TextView 自适应的同时,还不超出限制范围的方式

分享一种 ConstraintLayout 让TextView 自适应的同时&#xff0c;还不超出限制范围的方式 不知道大家有没有遇到这种布局需求&#xff1a; 上图布局很简单&#xff0c;ImageView 中间的TextView View ImageView&#xff0c;需求是中间的 TextView 宽度需要根据内容来展示&…

OpenMLDB 实时引擎性能测试报告

OpenMLDB 提供了一个线上线下一致性的特征平台。其中&#xff0c;为了支持低延迟高并发的在线实时特征计算&#xff0c;OpenMLDB 设计实现了一个高性能的实时 SQL 引擎。本报告覆盖了 OpenMLDB 实时 SQL 引擎的性能测试&#xff0c;包含了在较为复杂的负载、典型配置下的各种性…

多线程知识笔记(四)-----volatile、wait方法、notify方法

文章目录1、volatile关键字2、volatile和synchronized对比3、wait和notify方法1、volatile关键字 先看例子&#xff1a; class Counter {public int flag 0; }public class Test4{public static void main(String[] args) {Counter counter new Counter();Thread t1 new Th…

如何使用Footrace 钱包监控功能和设置自定义的交易警报

2022-06-12 本文将介绍如何使用 Footrace 监控 CEX 的钱包地址并设置自定义警报。 什么是 Footrace&#xff1f; Footrace (Foot Trace) 是一个多链的钱包追踪监控平台&#xff0c;可以监控CEX、DEX、鲸鱼、聪明钱、或任何你想关注的地址的钱包。 Footrace 帮助投资者保护他…

有了这几个软件安全测试工具,编写安全测试报告再也不愁

软件的安全是开发人员、测试人员、企业以及用户共同关心的话题&#xff0c;尤其是软件产品的使用者&#xff0c;因为系统中承载着用户的个人信息、人际互动、管理权限等各类隐私海量关键数据。软件安全测试工作不仅是为了用户&#xff0c;更牵扯到许多的利益共同体。因此软件安…

2854-40-2,环二肽cyclo(Pro-Val)

Component of coffee flavor 咖啡香精成分 在烘焙咖啡中检测到Cyclo(Pro-Val)和其他含pro的二酮哌嗪类化合物。这些化合物的含量随着烘焙强度的增加而增加&#xff0c;它们增加了苦味。这种味道苦涩的环二肽也在可可、巧克力、牛肉和奶酪等其他食品中被检测到。Cyclo(Pro-Val)显…

Linux物理内存管理——会议室管理员如何分配会议室

之前学习了站在内存的角度去看内存&#xff0c;看到的都是虚拟内存&#xff0c;这些虚拟内存总是要映射到物理页面的&#xff0c;这一篇文章来学习物理内存是如何管理的。 物理内存的组织方式 之前学习虚拟内存的时候&#xff0c;当涉及物理内存的映射的时候&#xff0c;总是…

不会还有人不知道如何搭建【关键字驱动自动化测试框架】吧 ?

前言 这篇文章我们将了解关键字驱动测试又是如何驱动自动化测试完成整个测试过程的。关键字驱动框架是一种功能自动化测试框架&#xff0c;它也被称为表格驱动测试或者基于动作字的测试。关键字驱动的框架的基本工作是将测试用例分成四个不同的部分。首先是测试步骤&#xff0…

MobileNet网络模型(V1,V2,V3)

MobileNet网络中的亮点&#xff1a;DW卷积&#xff0c;增加了两个超参数&#xff0c;控制卷积层卷积核个数的α&#xff0c;控制输入图像大小的β&#xff0c;这两个超参数是我们人为设定的&#xff0c;并不是学习到的。BN batch normal批规范化&#xff0c;为了加快训练收敛速…