[Linux 基础] 一篇带你了解linux权限问题
文章目录
- 1、Linux下的两种用户
- 2、文件类型和访问权限(事物属性)
- 2.1 Linux下的文件类型
- 2.2 基本权限
- 2.3 文件权限值的表示方法
- (1)字符表示方法
- (2)8进制数值表示方法
- 2.4 文件访问权限的相关设置方法
- (1) chmod
- (2) 三位8进制数字
- (3) chown
- (4) chgrp
- 3、目录权限
- 3.1 umask
- 4、粘滞位
1、Linux下的两种用户
Linux下有两种用户:超级用户(root)、普通用户。
超级用户:可以再linux系统下做任何事情,不受限制 普通用户:在linux下做有限的事情。
超级用户的命令提示符是“#”,普通用户的命令提示符是“ $ ”
命令: su [用户名]
功能: 切换用户。 例如,要从root用户切换到普通用户user,则使用 su user。 要从普通用户user切换到root用户则使用 su root(root可以省略),此时系统会提示输入root用户的口令。
从普通用户切换到超级用户:
[lcx@alicloud test_code]$ su

从超级用户切换到普通用户:
```bash
[root@alicloud test_code]# su lcx

从普通用户到超级用户还可以使用 su - 指令:
[root@alicloud test_code]# su -

su与su - 的区别:su是切换,而su - 是重新登录。
2、文件类型和访问权限(事物属性)
Linux下一切皆文件,而文件 = 文件内容+文件属性。
内容很好理解,下图就是这个 .c 文件的内容。

那什么是属性,对应Windows下,文件名称、文件大小,类型等就是一个文件的属性,那么怎么查看,ll指令就可以查看。下图中括起来的都是属性:

权限对应下图来看:

2.1 Linux下的文件类型
Linux下文件不以文件后缀区分文件类型,ll展示出来的所有第一列的第一个字符就是文件类型。 Linux下文件类型分为以下几种:
d:目录文件
-:普通文件,源代码,可执行程序,库等
l:软链接(类似Windows的快捷方式)创建:ln -s 可执行程序 filename.exe
b:块设备文件(例如硬盘、光驱等)
p:管道文件 创建:mkfifo filename
c:字符设备文件(例如屏幕,键盘等串口设备)
s:套接口文件

这些文件中最常用的只是目录文件和普通文件,其他了解就好了。
2.2 基本权限
i.读(r/4): Read对文件而言,具有读取文件内容的权限;对目录来说,具有浏览该目录信息的权限
ii.写(w/2): Write对文件而言,具有修改文件内容的权限;对目录来说具有删除移动目录内文件的权限
iii.执行(x/1): execute对文件而言,具有执行文件的权限;对目录来说,具有进入目录的权限
iv、“-”表示不具有该项权限

我们对这九列来讲解一下,这九列就代表着访问的权限,三个为一组,每一组代表着什么人可以访问,三个字符分别代表不同含义,r读,w写,x执行。
Linux中将人分为三类:
文件和文件目录的所有者: u—User(中国平民 法律问题)
文件和文件目录的所有者所在的组的用户: g—Group(不多说)
其它用户: o—Others (外国人)
上面的九列,三三一组,每一组就代表了不同的人:

2.3 文件权限值的表示方法
(1)字符表示方法
| Linux表示 | 说明 | Linux表示 | 说明 |
|---|---|---|---|
| r– | 只读 | -w- | 仅可写 |
| –x | 仅可执行 | rw- | 可读可写 |
| -wx | 可写可执行 | r-x | 可读可执行 |
| rwx | 可读可写可执行 | — | 无权限 |
(2)8进制数值表示方法
| 权限符号(读写执行) | 八进制 | 二进制 |
|---|---|---|
| r | 4 | 100 |
| w | 2 | 010 |
| x | 1 | 001 |
| rw | 6 | 110 |
| rx | 5 | 101 |
| wx | 3 | 011 |
| rwx | 7 | 111 |
| — | 0 | 000 |
2.4 文件访问权限的相关设置方法
(1) chmod
功能: 设置文件的访问权限
格式: chmod [参数] 权限 文件名
常用选项:R -> 递归修改目录文件的权限
说明:只有文件的拥有者和root才可以改变文件的权限
① 用户表示符+/-=权限字符+:向权限范围增加权限代号所表示的权限
-:向权限范围取消权限代号所表示的权限
=:向权限范围赋予权限代号所表示的权限
用户符号:u:拥有者
g:拥有者同组用
o:其它用户
a:所有用户
1、假设我要给file.txt文件拥有者、所属组、其他用户都+上可执行权限

还可以直接使用a+x,a代表着all(所有)。

2、假设给拥有者-x权限,给所属组-x权限,给其他人+w权限
我们不用分开去操作,可以一次操作,用逗号将不同身份±操作隔开就可以。

3、假设我们将其他人的写与执行权限去掉,chmod o-wx file.txt

(2) 三位8进制数字

1.给file.txt文件的拥有者、所属组、其他人都设置为可读可写可执行权限,chmod 777 file.txt
(3) chown
功能: 修改文件的拥有者
格式: chown [参数] 用户名 文件名
当我们想要把file.txt文件的拥有者修改为root用户时,怎么做?
我们这里就可以使用chown来修改。

我们这里命令是对的,但是为什么显示说操作不被允许?
这是因为我们当前的身份是普通用户,普通用户是无权改变文件拥有者的,虽然这个文件是该普通用户的,就像我们在Windows下下载安装某个软件的时候,会提示我们是否以管理员身份打开/安装,此时我们就要暂时以管理员身份去同意,在Linux中也存在这样的行为,该行为叫做提权。如果身份为root超级管理员,对任何文件的任何操作都可以,不受限制。
指令本身是没有错的,我们在前面加上sudo,并输入用户密码即可,提权的时候系统要确认身份。

此时文件的拥有者就修改为root用户了。
(4) chgrp
功能: 修改文件或目录的所属组
格式: chgrp [参数] 用户组名 文件名
常用选项: -R 递归修改文件或目录的所属组
这里与chown使用方法类似,并且也是需要提权的,没什么可讲的,看懂了chown这个就是一样的。
3、目录权限
可执行权限: 如果目录没有可执行权限, 则无法cd到目录中.
可读权限: 如果目录没有可读权限, 则无法用ls等命令查看目录中的文件内容.
可写权限: 如果目录没有可写权限, 则无法在目录中创建文件, 也无法在目录中删除文件.
我们来对这三个权限分别验证一下:
可执行权限:



可读权限:

可写权限:

3.1 umask
功能:
查看或修改文件掩码
新建文件夹默认权限=0666
新建目录默认权限=0777
但实际上你所创建的文件和目录,看到的权限往往不是上面这个值。原因就是创建文件或目录的时候还要受到umask的影响。假设默认权限是mask,则实际创建的出来的文件权限是: mask & ~umask
格式: umask 权限值
说明: 将现有的存取权限减去权限掩码后,即可产生建立文件时预设权限。超级用户默认掩码值为0022,普通用户默认为0002。
在linux中,目录权限为775(不同系统会存在差异)。我们下面就来了解一下为什么是这样的初始权限。

这其实是权限掩码导致的,umask查看一下:

那么什么是权限掩码呢?
在权限掩码中出现的权限,最终在目录权限中不会出现!
因此,我们创建的目录初始应该是777,但是最后创建出来确实775,因为umask是002(查出来的是0002,第一个0不用管,是权限掩码的起始位)。777通过&~002得到的数值最终就是775,所以创建出来就是775。计算公式:mask & ~umask。

我们可以修改权限掩码,创建的目录的权限值也会随之改变:

当权限掩码被改为000的时候,创建出来的目录权限值就是777了,可以使用公式验证一下,是正确的。
4、粘滞位
什么是粘滞位呢?
在linux下,存在一种特殊情况,如果我们多个账号想要相互协同,共享一些数据呢,我们来看看这种情况。

我们lcx与ljy两个用户都在alltmp目录下进行创作,这里是一个公共区域,lcx用户自己的文件只让别人读,但是不让别人写入,这时ljy用户就想写入自己的东西,操作失败了,你让我读,不让我写,那好都别玩了,我删掉你的文件。
这里我们看到,lcx.txt文件对其他用户是没有w权限的,但是别人是可以删掉的,这里其实是因为在alltmp目录下,创建文件和删除文件不由文件本身决定,是由目录是否对其他用户开放w权限来决定的(删掉你与你无关)。但是这里如果去掉了w权限,大家都创建不了文件,因此是比较矛盾的一件事。
但是,今天我们就是需要一个共享目录,并且除我之外别人不可以删除我的文件!我们就可以给目录加上粘滞位!!!
当一个目录被设置为“粘滞位”(用chmod +t),则该目录下的文件只能由
一、超级管理员删除
二、该目录的所有者删除
三、该文件的所有者删除

此时为alltmp目录加上了粘滞位,文件拥有者想让谁读写执行不想让谁读写执行是自己决定的,别人再也删不掉了。

关于权限的总结 1、目录的可执行权限是表示你可否在目录下执行命令。 2、如果目录没有-x权限,则无法对目录执行任何命令,甚至无法cd 进入目, 即使目录仍然有-r 读权限(这个地方很容易犯错,认为有读权限就可以进入目录读取目录下的文件)。
3、而如果目录具有-x权限,但没有-r权限,则用户可以执行命令,可以cd进入目录。但由于没有目录的读权限,所以在目录下,即使可以执行ls命令,但仍然没有权限读出目录下的文档。
相关文章:
[Linux 基础] 一篇带你了解linux权限问题
文章目录 1、Linux下的两种用户2、文件类型和访问权限(事物属性)2.1 Linux下的文件类型2.2 基本权限2.3 文件权限值的表示方法(1)字符表示方法(2)8进制数值表示方法 2.4 文件访问权限的相关设置方法(1) chm…...
FPGA project :HDMI
实验目标:驱动HdMI显示十色等宽彩条。 本实验的重点是: 1掌握TMDS通信协议。 2rgb565转rgb888。 3编写HDMI驱动程序。 4学会看流程图编写代码。 值得注意的事情 1注意数据与解析数据的信号(比如传入的数据中0或者1的个数)&…...
基于微信小程序的物流快递信息查询平台同城急送小程序(亮点:寄件、发票申请、在线聊天)
文章目录 前言系统主要功能:具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序(小蔡coding)有保障的售后福利 代码参考源码获取 前言 💗博主介绍:✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计…...
idea插件推荐
目录 一、插件安装方式 file->settings->plugins->macketplace 各个版本IDE插件界面略有不同,不一一赘述 二、常用插件 1、Background Image Plus 推荐指数:★★★★☆ 这款插件并不能直接提高你的开发效率,但是可以让你面对的ID…...
Arcgis快速计算NDVI
Arcgis快速计算NDVI 一、问题描述 如何使用Arcgis像ENVI一样波段计算NDVI的值,事实上,Arcgis更快速一些。 二、操作步骤 首先准备好影像 打开窗口-影像分析 点击左上角 点击确定 (发现自己使用的遥感影像不对劲,是计算好了…...
SpringCloud Alibaba - 基于 FeignClient 整合 Sentinel,实现“线程隔离”和“熔断降级”
目录 一、FeignClient 整合 Sentinel 1.1、整合原因 1.2、实现步骤 1.2.1、修改 OrderService 中的 application.yml 文件 1.2.2、给 FeignClient 编写失败后的降级逻辑 二、线程隔离 2.1、线程隔离的两种方式 2.1.1、线程池隔离 2.1.2、信号量隔离(Sentin…...
Acwing 906. 区间分组
Acwing 906. 区间分组 知识点题目描述思路讲解代码展示 知识点 贪心 题目描述 思路讲解 这段代码是用来维护一个最小堆,以确保右边界不相交的区间被正确地保留在堆中。让我详细解释这段代码: heap.empty():这个条件检查最小堆 heap 是否为…...
阿里云 Oss 权限控制
前言 最近公司的私有 Oss 服务满了,且 Oss 地址需要设置权限,只有当前系统的登录用户才能访问 Oss 下载地址。一开始想着用 Nginx 做个转发来着,Nginx 每当检测当前请求包含特定的 Oss 地址就转发到我们的统一鉴权接口上去,但是紧…...
CSS详细基础(六)边框样式
本期是CSS基础的最后一篇~ 目录 一.border属性 二.边框属性复合写法 三.CSS修改表格标签 四.内边距属性 五.外边距属性 六.其他杂例 1.盒子元素水平居中 2.清除网页内外元素边距 3.外边距的合并与塌陷 4.padding不会撑大盒子的情况 七.综合案例——新浪导航栏仿真 …...
支持向量机SVM:从数学原理到实际应用
目录 一、引言背景SVM算法的重要性 二、SVM基础线性分类器简介什么是支持向量?超平面和决策边界SVM的目标函数 三、数学背景和优化拉格朗日乘子法(Lagrange Multipliers)KKT条件核技巧(Kernel Trick)双重问题和主问题&…...
【办公自动化】在Excel中按条件筛选数据并存入新的表(文末送书)
🤵♂️ 个人主页:艾派森的个人主页 ✍🏻作者简介:Python学习者 🐋 希望大家多多支持,我们一起进步!😄 如果文章对你有帮助的话, 欢迎评论 💬点赞Ǵ…...
第三章:最新版零基础学习 PYTHON 教程(第十一节 - Python 运算符—Python 中的any与all)
Any 和 All 是 python 中提供的两个内置函数,用于连续的与/或。Any如果任何一项为 True,则返回 true。如果为空或全部为 false,则返回 False。Any 可以被认为是对所提供的可迭代对象进行 OR 操作的序列。它会短路执行,即一旦知道结果就停止执行。 句法: any(iterable) 函…...
Pytorch单机多卡分布式训练
Pytorch单机多卡分布式训练 数据并行: DP和DDP 这两个都是pytorch下实现多GPU训练的库,DP是pytorch以前实现的库,现在官方更推荐使用DDP,即使是单机训练也比DP快。 DataParallel(DP) 只支持单进程多线程…...
asp.net coremvc+efcore增删改查
下面是一个使用 EF Core 在 ASP.NET Core MVC 中完成增删改查的示例: 创建一个新的 ASP.NET Core MVC 项目。 安装 EF Core 相关的 NuGet 包。在项目文件 (.csproj) 中添加以下依赖项: <ItemGroup><PackageReference Include"Microsoft…...
Java基础面试,什么是面向对象,谈谈你对面向对象的理解
前言 马上就要找工作了,从今天开始一天准备1~2道面试题,来打基础,就从Java基础开始吧。 什么是面向对象,谈谈你对面向对象的理解? 谈到面向对象,那就不得不谈到面向过程。面向过程更加注重的是完成一个任…...
Ubuntu系统初始设置
更换国内源 安装截图工具 安装中文输入法 安装QQ 参考: 安装双系统win10Ubuntu20.04LTS(详细到我自己都害怕) 引导方式磁盘分区方法UEFIGPTLegancyMBR 安装网络助手 sudo apt install net-tools 安装VS Code 使用从官网下载.deb安装包…...
焕新古文化传承之路,AI为古彝文识别赋能
目录 1 古彝文与古典保护 2 古文识别的挑战 2.1 西文与汉文OCR 2.2 古彝文识别难点 3 合合信息:古彝文保护新思路 3.1 图像矫正 3.2 图像增强 3.3 语义理解 3.4 工程技巧 4 总结 1 古彝文与古典保护 彝文指的是云南、贵州、四川等地的彝族人使用的文字&am…...
毛玻璃动画交互效果
效果展示 页面结构组成 从上述的效果展示页面结构来看,页面布局都是比较简单的,只是元素的动画交互比较麻烦。 第一个动画交互是两个圆相互交错来回运动。第二个动画交互是三角绕着圆进行 360 度旋转。 CSS 知识点 animationanimation-delay绝对定位…...
Audio2Face的工作原理
预加载一个3D数字人物模型(Digital Mark),该模型可以通过音频驱动进行面部动画。 用户上传音频文件作为输入。 将音频输入馈送到预训练的深度神经网络中。 Audio2Face加载预制的3d人头mesh 3D数字人物面部模型由大量顶点组成,每个顶点都有xyz坐标。 深度神经网络输入音频特征,…...
【面试题】2023前端面试真题之JS篇
前端面试题库 (面试必备) 推荐:★★★★★ 地址:前端面试题库 表妹一键制作自己的五星红旗国庆头像,超好看 世界上只有一种真正的英雄主义,那就是看清生活的真相之后,依然热爱生活。…...
保姆级教程:用ESP-IDF Monitor和Heap Tracing给LVGL任务栈“拍个X光”
ESP32-S3深度调试:用Heap Tracing与Monitor透视LVGL内存瓶颈 当LVGL动画在ESP32-S3上随机崩溃时,大多数开发者会本能地调整栈大小参数——这就像给发烧病人直接开退烧药,却不去检查感染源。本文将带您使用ESP-IDF的专业诊断工具,…...
python vue医院健康体检系统
目录技术选型与架构设计核心模块划分关键功能实现安全与合规措施部署方案开发里程碑计划项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作技术选型与架构设计 后端采用Python的Django框架,提供RESTful API接口。Djan…...
零成本实现外网访问内网WebDAV:cpolar内网穿透实战教程
零成本实现外网访问内网WebDAV:cpolar内网穿透实战教程 对于需要远程访问家中或办公室文件的用户来说,WebDAV协议提供了一种便捷的文件共享方式。然而,缺乏公网IP往往成为阻碍。本文将详细介绍如何利用cpolar工具,无需复杂网络配…...
无刷电机S型与梯形加减速曲线实战:从算法到代码的平滑运动实现
1. 无刷电机加减速控制的核心价值 第一次调试无刷电机时,我盯着那个疯狂抖动的机械臂陷入了沉思——原来不加控制的电机就像脱缰的野马,根本没法用在精密设备上。后来才明白,加减速曲线就是驯服这匹野马的缰绳。无论是工厂里的机械臂&#x…...
Zynq AXI DMA实战:从零配置S_AXIS_S2MM到M_AXIS_MM2S的完整数据流(Vivado 2023版)
Zynq AXI DMA实战:从零配置S_AXIS_S2MM到M_AXIS_MM2S的完整数据流(Vivado 2023版) 在嵌入式系统开发中,高效的数据传输往往是性能瓶颈所在。Zynq系列SoC凭借其独特的ARM处理器与FPGA可编程逻辑的紧密结合,为高性能数据…...
淘宝淘金币自动化脚本:每天节省20分钟的终极解决方案
淘宝淘金币自动化脚本:每天节省20分钟的终极解决方案 【免费下载链接】taojinbi 淘宝淘金币自动执行脚本,包含蚂蚁森林收取能量,芭芭农场全任务,解放你的双手 项目地址: https://gitcode.com/gh_mirrors/ta/taojinbi 淘宝淘…...
深度解析PAC文件解析器:构建智能代理路由系统的终极方案
深度解析PAC文件解析器:构建智能代理路由系统的终极方案 【免费下载链接】pacparser A library to parse proxy auto-config (PAC) files 项目地址: https://gitcode.com/gh_mirrors/pa/pacparser 在现代企业网络架构中,代理自动配置(…...
Swagger2配置避坑指南:为什么你的Docket分组设置会导致api-docs 404?
Swagger2配置避坑指南:为什么你的Docket分组设置会导致api-docs 404? 在RESTful API开发中,Swagger2作为API文档生成工具被广泛使用。但许多开发者在配置过程中都遇到过这样的问题:明明能正常访问swagger-ui.html页面,…...
OpenClaw对话日志分析:GLM-4.7-Flash任务执行成功率提升
OpenClaw对话日志分析:GLM-4.7-Flash任务执行成功率提升 1. 为什么需要分析对话日志 上个月我把本地部署的OpenClaw智能体从Qwen切换到了GLM-4.7-Flash模型,本以为会获得更好的任务执行效果,结果却遇到了意想不到的问题。每天早上打开电脑&…...
达梦数据库-归档日志文件-记录总结
达梦数据库-归档日志文件-记录总结DM数据库可以运行在归档模式或非归档模式下。如果是归档模式,联机日志文件中的内容保存到硬盘中,形成归档日志文件;如果是非归档模式,则不会形成归档日志。归档日志文件以归档时间命名࿰…...

