Linux 中 uid、gid、euid、egid、groups 之間的關係

来源:https://www.cnblogs.com/kqdssheng/p/18278645
-Advertisement-
Play Games

導航 1 許可權匹配流程 2 五種身份變化 3 有效用戶/組 4 特權對 Shell 腳本無效 5 Sudo 與 SUID/SGID 的優先順序 6 SUID、SGID、Sticky 各自的功能 Linux最優秀的地方之一,就在於他的多人多工環境。而為了讓各個使用者具有較保密的檔案資料,因此檔案的許可權管 ...


導航


Linux最優秀的地方之一,就在於他的多人多工環境。而為了讓各個使用者具有較保密的檔案資料,因此檔案的許可權管理就變的很重要了。
Linux一般將檔案可存取的身份分為三個類別,分別是 owner/group/others,且三種身份各有 read/write/execute 等許可權。
image

故對於"靜態"的檔案來說,其中的許可權屬性即確定了“哪些身份的人擁有什麼樣的許可權可以去操作檔案”,如上圖所示。

而對於"動態"的進程來說,操作系統又為進程分配了它們的用戶身份,即有效用戶身份euid、有效群組身份egid、群組身份groups、還有繼承uid、繼承gid。【註:不管進程是否有SUID/SGID加持,進程都將擁有這5個身份,只不過無差異時 id 命令預設不顯示euid/egid而已,預設euid=uid、egid=gid】

(1)許可權匹配流程
於是,當一個進程想要操作某個檔案文件時,操作系統便會根據進程擁有的身份檔案擁有的許可權標記去做判斷。判斷流程如下(示例以讀許可權 r 舉例):

  1. 如果進程的 euid 等於檔案的 owner-id,則繼續開始判斷檔案擁有者對應的許可權位中是否包含 r 許可權,若包含則文件被進程順利讀取,若不包含則提示進程無許可權,此時不管 r 許可權包含與否判斷流程都將不再繼續;如果進程的 euid 不等於檔案的 owner-id,則開始步驟 2 的判斷。
  2. 如果進程的 groups 包含檔案的 group-id,則繼續開始判斷檔案所屬群組對應的許可權位中是否包含 r 許可權,若包含則文件被進程順利讀取,若不包含則提示進程無許可權,此時不管 r 許可權包含與否判斷流程都將不再繼續;如果進程的 groups 不包含檔案的 group-id,則開始步驟 3 的判斷。
  3. 此時直接開始判斷檔案其它人對應的許可權位中是否包含 r 許可權,若包含則文件被進程順利讀取,若不包含則提示進程無許可權。至此,流程不再遞歸判斷,直接結束。
    image

image

image

(2)五種身份變化
當一個二進位命令被授予 SUID/SGID 特權時,命令進程中 5 種身份的變化。

  • 當無特殊許可權時,uid=繼承shell的uid,gid=繼承shell的gid,euid=uid,egid=gid,groups=uid所加入的群組。
  • 當授予suid特殊許可權時,uid=繼承shell的uid,gid=繼承shell的gid,euid=suid的值,egid=gid,groups=uid所加入的群組。
  • 當授予sgid特殊許可權時,uid=繼承shell的uid,gid=繼承shell的gid,euid=uid,egid=sgid的值,groups=uid所加入的群組+sgid。
  • 當授予suid和sgid特殊許可權時,uid=繼承shell的uid,gid=繼承shell的gid,euid=suid的值,egid=sgid的值,groups=uid所加入的組+sgid。

image

image

image

image

(3)有效用戶/組
不管實驗2中進程的5種身份如何變化,當進程產生新檔案時,檔案的擁有者和所屬群組都是以euid和egid的值去賦予的。
image

(4)特權對 Shell 腳本無效
特殊許可權 SUID/SGID 對於 shell 腳本不起作用,授予和不授予的狀態一樣。
image

(5)Sudo 與 SUID/SGID 的優先順序
當 Sudo 和 SUID/SGID 同時作用二進位命令時,優先以SUID/SGID的許可權為主,這其實就相當於在root shell下執行特殊授權的命令一樣,命令進程的5種身份依舊按照小節(2)描述的過程一樣,root也不例外。
image

(6)SUID、SGID、Sticky 各自的功能。

  • SUID:只作用於二進位文件,當命令被執行時,命令會以命令擁有者的身份走完進程的整個生命周期,而非以當前 shell 的用戶身份運行。
  • SGID:當作用於二進位文件時,效果與 SUID 類似,只是在命令進程的整個整個生命周期中又多了一個群組的援助;當作用於目錄時,使用者進入此目錄下時他的有效群組將會變成該目錄的群組,此時新建的任何文件目錄,他們的 群組id 都將和該目錄的 群組id 一樣。
  • Sticky:只作用於目錄,使用者在該目錄下新建的任何文件目錄,都將只有自己與 root 才有權力刪除。如 /tmp 目錄。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • .Net 中提供了一系列的管理對象集合的類型,數組、可變列表、字典等。從類型安全上集合分為兩類,泛型集合 和 非泛型集合,傳統的非泛型集合存儲為Object,需要類型轉。而泛型集合提供了更好的性能、編譯時類型安全,推薦使用。 ...
  • 今天在技術群里,石頭哥向大家提了個問題:"如何在一個以System身份運行的.NET程式(Windows Services)中,以其它活動的用戶身份啟動可互動式進程(桌面應用程式、控制台程式、等帶有UI和互動式體驗的程式)"? 我以前有過類似的需求,是在GitLab流水線中運行帶有UI的自動化測試程 ...
  • OPC基金會提供了OPC UA .NET標準庫以及示常式序,但官方文檔過於簡單,光看官方文檔和示常式序很難弄懂OPC UA .NET標準庫怎麼用,花了不少時間摸索才略微弄懂如何使用,以下記錄如何從一個控制台程式開發一個OPC UA伺服器。 安裝Nuget包 安裝OPCFoundation.NetSt ...
  • 前言 隨著 DEV24.1.3 的發佈,XAF Blazor 中的屬性編輯器(PropertyEditor)也進行了很大的改動,在使用體驗上也更接近 WinForm 了,由於進行了大量的封裝,理解上沒有 WinForm 直觀,所以本文通過對屬性編輯器的原理進行解析,並對比新舊版本中的變化,使大家能夠 ...
  • 由於.NET Framework 4.0 是比較古老的版本,只有New Relic 7.0以下的版本才會支持.NET Framework 4.0的引用程式。 Technical support for .NET Framework 4.0 or lower 你可以參考這個官方Install New ...
  • 功能說明 使用ListView時,希望可以在單元格顯示圖片或其他控制項,發現原生的ListView不支持,於是通過拓展,實現ListView可以顯示任意控制項的功能,效果如下: 實現方法 本來想著在單元格裡面實現控制項的自繪的,但是沒找到辦法,最後是通過在單元格的錶面顯示對應控制項的,浮於錶面達到目的。 實 ...
  • 一:背景 1. 講故事 前些天有位朋友找到我,說他們的程式會偶發性的卡死一段時間,然後又好了,讓我幫忙看下怎麼回事?窗體類的程式解決起來相對來說比較簡單,讓朋友用procdump自動抓一個卡死時的dump,拿到dump之後,上 windbg 說話。 二:WinDbg 分析 1. 主線程在做什麼 要想 ...
  • 痞子衡嵌入式半月刊: 第 103 期 這裡分享嵌入式領域有用有趣的項目/工具以及一些熱點新聞,農曆年分二十四節氣,希望在每個交節之日準時發佈一期。 本期刊是開源項目(GitHub: JayHeng/pzh-mcu-bi-weekly),歡迎提交 issue,投稿或推薦你知道的嵌入式那些事兒。 上期回 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...