Linux文件權限詳解:從入門到精通

前言

權限是什么?

本質:無非就是能做和不能做什么。

為什么要有權限呢?

目的:為了控制用戶行為,防止發生錯誤。

1.權限的理解

在學習下面知識之前要先知道的一點是:linux下一切皆文件,對linux操作就是對文件進行操作

權限=角色+目標權限屬性

角色:誰在操作(用戶身份)

目標權限屬性:操作對象(文件/目錄)本身被設置了什么樣的訪問規則。

在linux中角色分為三種:

擁有者創建的這個文件,也就是這個文件/目錄的所有者。

所屬組:類似于除擁有者之外還有一個小組的人共享這個文件。

other:除擁有者與所屬組之外的用戶。

當用戶嘗試訪問一個文件/目錄時,系統會首先判斷該用戶屬于哪個“角色”

  1. 是文件的擁有者嗎? → 適用 u 權限

  2. 不是擁有者,但在文件的所屬組里?→ 適用 g?權限

  3. 既不是所有者,也不在所屬組里?→ 適用?o?權限

注意:在centos下,系統只會進行一次角色判定,順序是:擁有者,所屬組,other。

目標權限屬性:

在對文件進行操作時最常用無非就是讀寫操作,但是有些是可執行程序,還有個運行操作對應下面三種操作

r(read):讀內容(對于普通文件)/列目錄(對應目錄文件使用ls等列出該目錄下的內容(文件))

w(write):修改內容(普通文件)/在目錄增刪文件。

x(execute):運行程序(普通文件)/進入目錄(目錄文件)。

?- 代表沒有該權限
對應下面code.c文件的權限信息為:
擁有者:有讀文件和寫文件的權限,沒有運行該文件的權限
所屬組:只有讀文件的權限
other:只有讀文件的權限

2.如何使用命令修改權限

2.1 chmod

作用:修改角色對文件的訪問權限。

-:關閉權限

+:打開權限

chmod u-r code.c       # 對擁有者讀該文件的權限關閉

格式:chmod + 【角色】+ 【+/-】+ 【訪問權限】+ 對應文件名

了解了上面知識之后來理解下面幾個知識點。

1.我們能改任何人的權限嗎?

用戶只能修改自己的文件權限。

?

2.如果我們要對沒有對應文件的權限的文件進行操作會怎么樣?

系統會拒絕讓我們訪問。

?

3.root用戶可以無視權限對任何文件進行操作。

?

4.所有普通文件都有x權限,是不是所以文件都可以運行?

不是的,可執行權限!=文件可以執行

只有可運行的文件才能執行,比如被gcc/g++編譯過的.c/.cpp文件。

2.2 chown

作用:修改文件的擁有者。

在默認情況下我們是不能將文件交給別人,想給別人,除非是root(超級用戶)/高權限,上圖展示是在是root用戶下的操作。

格式: chown + 目標角色(用戶)+ 文件名?

3.理解linux多用戶下如何進行“隔離”

因為用戶之間除自身可以進入自己的目錄,其他角色都不能進入(除root)。

問題:

如果root在cqy目錄內創建了一個文件,并將文件的other的權限全部關閉,對應cqy用戶能對該文件進行刪除嗎?

?

可以的,一個文件能否被刪除與文件本身沒有關系,與文件所處目錄的 w 權限有關。因為是在cqy目錄下創建的文件,而我們對該文件擁有的權限全都有。

4.粘滯位

問題:

如果需要兩個用戶之間要進行文件級別的協作該怎么辦?

1)不能將文件放入個人賬戶,因為不同用戶之間是不能進入對方的工作目錄的。

2)放入共享類文件,并且在該目錄下創建的文件其他用戶沒有權限進行刪除。

在根目錄下有一個?tem?目錄,可以看到該目錄的下對 other 的權限是 rwt 這個 t 就是粘滯位,添加了粘滯位的目錄,任何人都可以在共享目錄下創建文件,在該目錄下創建的文件除本人外其他用戶不能進行刪除。

注意:

1)共享文件只能創建在根目錄下,根目錄下的文件只有root可以進行訪問,其他用戶無法訪問。

2)只能給需要共享的文件添加粘滯位。

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/84717.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/84717.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/84717.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

在多云環境透析連接ngx_stream_proxy_protocol_vendor_module

1、模塊定位與價值 多云接入:在同一 Nginx 實例前端接入來自多云平臺的私有鏈路時,能區分 AWS、GCP、Azure 特有的連接 ID。安全審計:自動記錄云平臺側的 Endpoint/VPC ID,有助于聯調和安全事件追蹤。路由分流:基于不…

力扣:基本計算器

基本計算器: 224. 基本計算器 - 力扣(LeetCode) 本體思路為,將中綴表達式轉為后綴表達式,通過后綴表達式進行運算。 中綴表達式: 我們日常生活中熟知的表達式如12-30 就是一個中綴表達式。 后綴表達式: 150. 逆波蘭表達式求值 - …

《AI日報 · 0613|ChatGPT支持導出、Manus免費開放、GCP全球宕機》

AI 資訊 1?? OpenAI ChatGPT Canvas新增多格式導出功能 OpenAI終于為ChatGPT Canvas推出了用戶期待已久的導出功能。現在,用戶可以將創作內容導出為多種格式:文檔類支持PDF、docx和markdown格式,代碼文件則可直接保存為對應擴展名的源文件(如.py、.js、.sql等)。這一功…

C++中的零拷貝技術

一、C中零拷貝技術的核心概念 零拷貝(Zero-copy)是一種重要的優化技術,旨在減少數據在內存中的不必要復制,從而提高程序性能、降低內存使用并減少CPU消耗。在C中,零拷貝技術通過多種方式實現,包括引用語義…

RT_Thread內核源碼分析(五)——內存管理@小堆內存管理算法

目錄 1、內存堆控制 1.1 內存堆控制器 1.2 內存塊節點 1.3 內存堆管理 2、內存堆初始化 2.1 初始化接口 2.2 初始化示例 2.3 源碼分析 3、內存堆操作 3.1 內存塊申請 3.1.1 相關接口 3.1.2 原理分析 3.1.3 示例分析 3.1.4 代碼分析 3.2 內存塊伸縮 3.2.1 相關…

MyBatis-Plus 混合使用 XML 和注解

mybatisplus代碼生成器&#xff1a; 版本匹配是個比較麻煩的問題&#xff0c;這是我的配置&#xff1a; <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.2</version>…

基于ssm的教學質量評估系統

博主介紹&#xff1a;java高級開發&#xff0c;從事互聯網行業六年&#xff0c;熟悉各種主流語言&#xff0c;精通java、python、php、爬蟲、web開發&#xff0c;已經做了六年的畢業設計程序開發&#xff0c;開發過上千套畢業設計程序&#xff0c;沒有什么華麗的語言&#xff0…

【STM32】G030單片機開啟超過8個ADC通道的方法

如圖所示通道數量已經超過8個&#xff0c;按照之前博客的辦法已經行不通了 CubeMX配置STM32F103C8T6多路ADC配合DMA采集_stm32f103c8t6的adc采樣率-CSDN博客 這里筆者開了10個channel&#xff0c;注意切換為不完全配置&#xff0c;否則的話最多只有8個rank 開DMA&#xff0c;…

不同網絡I/O模型的原理

目錄 1、I/O的介紹 1.1、I/O 操作分類 1.2、I/O操作流程階段 1.3、I/O分類 2、同步I/O 2.1、阻塞I/O 2.2、非阻塞I/O 2.3、I/O復用 2.4、信號驅動式I/O 3、異步I/O 前言 在網絡I/O之中&#xff0c;I/O操作往往會涉及到兩個系統對象&#xff0c;一個是用戶空間調用I/O…

在正則表達式中語法 (?P<名字>內容)

&#x1f3af; 重點解釋&#xff1a;?P<xxx> 是什么語法&#xff1f; 這一整段&#xff1a; (?P<xxx>...)是 Python 正則表達式中 “命名捕獲組” 的語法。 咱們現在一個字一個字來解釋&#xff1a; ? (?...) 是干啥的&#xff1f; 這是一個捕獲組&#xff…

中興B860AV1.1_MSO9280_降級后開ADB-免刷機破解教程(非刷機)

中興B860AV1.1江蘇移動-自動降級包 關于中興b860av1.1頑固盒子降級教程終極版 將附件解壓好以后&#xff0c;準備一個8G以下的U盤重新格式化為FAT32格式后&#xff0c;并插入電腦 將以下文件及文件夾一同復制到優盤主目錄下&#xff08;見下圖&#xff09; 全選并復制到U盤主目…

2025-06-13【視頻處理】基于視頻內容轉場進行分割

問題&#xff1a;從網上下載的視頻文件&#xff0c;是由很多個各種不同的場景視頻片段合并而成。現在要求精確的把各個視頻片段從大視頻里分割出來。 效果如圖&#xff1a;已分割出來的小片段 思考過程 難點在于檢測場景變化。為什么呢&#xff1f;因為不同的視頻情況各異&am…

ReentrantLock和RLock

文章目錄 前言一、 ReentrantLock&#xff08;單機鎖&#xff0c;Java 內置&#xff09;示例&#xff1a;方法詳解 二、RLock&#xff08;分布式鎖&#xff0c;Redisson 提供&#xff09;示例:方法詳解 三、 對比總結:四、 如何選擇&#xff1f; 前言 ReentrantLock 和 RLock 都…

thinkphp ThinkPHP3.2.3完全開發手冊

慣例配置 應用設定 APP_USE_NAMESPACE > true, // 應用類庫是否使用命名空間 3.2.1新增 APP_SUB_DOMAIN_DEPLOY > false, // 是否開啟子域名部署 APP_SUB_DOMAIN_RULES > array(), // 子域名部署規則 APP_DOMAIN_SUFFIX > , // 域名后綴 如果是…

Python Day50 學習(仍為日志Day19的內容復習)

補充&#xff1a;梳理超參數調整流程&#xff08;邏輯&#xff09; 超參數調節的流程邏輯可以總結為以下幾個步驟&#xff1a; 1. 明確目標 確定你要優化的模型和評估指標&#xff08;如準確率、F1值、AUC等&#xff09;。 2. 選擇要調節的超參數 列出模型中影響較大的超參數…

公司網絡變差的解決方法(固定IP地址沖突)

問題描述 最近公司網絡變差&#xff0c;不知道為什么。&#xff08;別的同事反饋的&#xff0c;本人沒有感覺變差&#xff0c;也是比較奇怪的現象&#xff09; 現象有視頻會議變卡等。 調查過程 1.領導給網絡公司打電話溝通&#xff0c;對面遠程看了下&#xff0c;不是設備問…

使用Prometheus+Grafana+Alertmanager+Webhook-dingtalk搭建監控平臺

一、監控平臺介紹 1.監控平臺簡述普羅米修斯四件套,分別為Prometheus、Grafana、Alertmanager、Webhook-DingTalk。Prometheus一套開源的監控&報警&時間序列數據庫的組合,由SoundCloud公司開發,廣泛用于云原生環境和容器化應用的監控和性能分析。其提供了通用的數據…

UR機器人解鎖關節扭矩控制:利用英偉達Isaac Lab框架,推動裝配自動化的Sim2Real遷移

在工業制造領域&#xff0c;機器人裝配長期依賴固定自動化模式&#xff0c;面臨部署成本高、適配性差等挑戰。多部件裝配是制造業、汽車及航空航天等行業中的核心環節。傳統裝配系統通常針對特定任務設計&#xff0c;依賴大量人工工程部署&#xff0c;靈活性不足&#xff0c;難…

ABB 605系列

系列概述 ABB Relion605系列是專為配電網設計的保護繼電器產品系列&#xff0c;代表了中低壓電力系統保護領域的技術基準。基于ABB在電力保護領域數十年的經驗&#xff0c;該系列集成了最新的數字信號處理技術和網絡通信能力&#xff0c;為變電站自動化提供了完整的解決方案。…

Python|GIF 解析與構建(6):手搓 tk 錄制工具

目錄 Python&#xff5c;GIF 解析與構建&#xff08;6&#xff09;&#xff1a;手搓 tk 錄制工具 一、工具功能概覽 二、核心架構設計 1. 幀率控制模塊 2. 屏幕捕獲模塊 3. 主應用模塊 三、關鍵技術解析 1. 屏幕捕獲技術 2. 幀率控制原理 3. 透明窗口實現 四、使用指…