首頁 運維 linux運維 SELinux有什麼用

SELinux有什麼用

Feb 10, 2023 am 11:30 AM
linux selinux

SELinux主要功能是最大限度地減少系統中服務進程可存取的資源(最小權限原則),最大程式上限制了Linux系統中的惡意程式碼活動。 SELinux是部署在Linux系統中的安全增強功能模組,它透過對進程和檔案資源採用MAC(強制存取控制方式)為Linux系統提供了改進的安全性。

SELinux有什麼用

本教學操作環境:linux7.3系統、Dell G3電腦。

SELinux是什麼

安全增強Linux(Security-Enhanced Linux)簡稱SELinux,它是一個Linux 核心模組,也是Linux 的一個安全子系統。

SELinux 主要由美國國家安全局開發。 2.6 以上版本的 Linux 核心都已經整合了 SELinux 模組。

SELinux 的結構及配置非常複雜,而且有大量概念性的東西,要學精難度較大。很多 Linux 系統管理員嫌麻煩都把 SELinux 關閉了。

SELinux有什麼用

SELinux 主要作用是最大限度地減少系統中服務進程可存取的資源(最小權限原則) 。

我們知道,傳統的Linux 系統安全,採用的是DAC(自主存取控制方式),而SELinux 是部署在Linux 系統中的安全增強功能模組,它透過對進程和檔案資源採用MAC(強制存取控制方式)為Linux 系統提供了改進的安全性。

要注意的是,SELinux 的MAC 並不會完全取代DAC,恰恰相反,對於Linux 系統安全性來說,它是一個額外的安全層,換句話說,當使用SELinux 時,DAC 仍然被使用,且會先被使用,如果允許訪問,再使用SELinux 策略;反之,如果DAC 規則拒絕訪問,則根本無需使用SELinux 策略。

例如,若使用者嘗試對沒有執行權限(rw-)的檔案進行執行操作,那麼傳統的 DAC 規則就會拒絕使用者訪問,因此,也就無需再使用 SELinux 策略。

相比傳統的Linux DAC 安全控制方式,SELinux 具有諸多好處,比如說:

  • 它使用的是MAC 控制方式,這被認為是最強的存取控制方式;

  • 它賦予了主體(使用者或流程)最小的存取特權,這也意味著,每個主體僅被賦予了完成相關任務所必須的一組有限的權限。透過賦予最小存取特權,可以防止主體對其他使用者或進程產生不利的影響;

  • SELinux 管理過程中,每個進程都有自己的運行區域(稱為域) ,各進程僅運行在自己的網域內,無法存取其他進程和文件,除非被授予了特殊權限。

  • SELinux 可以調整到 Permissive 模式,此模式允許查看在系統上執行 SELinux 後所產生的印象。在 Permissive 模式中,SELinux 仍然會記錄它所認為的安全漏洞,但不會阻止它們。

其實,想要了解 SELinux 的優點,最直接的辦法就是查看當 Linux 系統上沒有執行 SELinux 時會發生什麼事。

例如,Web 伺服器守護程式(httd)正在監聽某一連接埠上所發生的事情,而後進來了一個要求查看主頁的來自 Web 瀏覽器的簡單請求。由於不會受到SELinux 的約束,httpd 守護程式聽到請求後,可以完成以下事情:

  • 根據相關的擁有者和所屬群組的rwx權限,可以存取任何檔案或目錄;

  • 完成存在安全隱患的活動,例如允許上傳檔案或更改系統顯示;

  • 可以監聽任何連接埠的傳入請求。

但在一個受 SELinux 約束的系統上,httpd 守護程式受到了更嚴格的控制。仍然使用上面的範例,httped僅能監聽 SELinux 允許其監聽的連接埠。 SELinux 還可以防止 httpd 存取任何沒有正確設定安全上下文的文件,並拒絕沒有再 SELinux 中明確啟用的不安全活動。

因此,從本質上講,S​​ELinux 最大程式上限制了 Linux 系統中的惡意程式碼活動。

相關推薦:《Linux影片教學

以上是SELinux有什麼用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

vscode需要什麼電腦配置 vscode需要什麼電腦配置 Apr 15, 2025 pm 09:48 PM

VS Code 系統要求:操作系統:Windows 10 及以上、macOS 10.12 及以上、Linux 發行版處理器:最低 1.6 GHz,推薦 2.0 GHz 及以上內存:最低 512 MB,推薦 4 GB 及以上存儲空間:最低 250 MB,推薦 1 GB 及以上其他要求:穩定網絡連接,Xorg/Wayland(Linux)

Linux體系結構:揭示5個基本組件 Linux體系結構:揭示5個基本組件 Apr 20, 2025 am 12:04 AM

Linux系統的五個基本組件是:1.內核,2.系統庫,3.系統實用程序,4.圖形用戶界面,5.應用程序。內核管理硬件資源,系統庫提供預編譯函數,系統實用程序用於系統管理,GUI提供可視化交互,應用程序利用這些組件實現功能。

vscode終端使用教程 vscode終端使用教程 Apr 15, 2025 pm 10:09 PM

vscode 內置終端是一個開發工具,允許在編輯器內運行命令和腳本,以簡化開發流程。如何使用 vscode 終端:通過快捷鍵 (Ctrl/Cmd ) 打開終端。輸入命令或運行腳本。使用熱鍵 (如 Ctrl L 清除終端)。更改工作目錄 (如 cd 命令)。高級功能包括調試模式、代碼片段自動補全和交互式命令歷史。

git怎麼查看倉庫地址 git怎麼查看倉庫地址 Apr 17, 2025 pm 01:54 PM

要查看 Git 倉庫地址,請執行以下步驟:1. 打開命令行並導航到倉庫目錄;2. 運行 "git remote -v" 命令;3. 查看輸出中的倉庫名稱及其相應的地址。

notepad怎麼運行java代碼 notepad怎麼運行java代碼 Apr 16, 2025 pm 07:39 PM

雖然 Notepad 無法直接運行 Java 代碼,但可以通過借助其他工具實現:使用命令行編譯器 (javac) 編譯代碼,生成字節碼文件 (filename.class)。使用 Java 解釋器 (java) 解釋字節碼,執行代碼並輸出結果。

vscode在哪寫代碼 vscode在哪寫代碼 Apr 15, 2025 pm 09:54 PM

在 Visual Studio Code(VSCode)中編寫代碼簡單易行,只需安裝 VSCode、創建項目、選擇語言、創建文件、編寫代碼、保存並運行即可。 VSCode 的優點包括跨平台、免費開源、強大功能、擴展豐富,以及輕量快速。

Linux的主要目的是什麼? Linux的主要目的是什麼? Apr 16, 2025 am 12:19 AM

Linux的主要用途包括:1.服務器操作系統,2.嵌入式系統,3.桌面操作系統,4.開發和測試環境。 Linux在這些領域表現出色,提供了穩定性、安全性和高效的開發工具。

vscode終端命令不能用 vscode終端命令不能用 Apr 15, 2025 pm 10:03 PM

VS Code 終端命令無法使用的原因及解決辦法:未安裝必要的工具(Windows:WSL;macOS:Xcode 命令行工具)路徑配置錯誤(添加可執行文件到 PATH 環境變量中)權限問題(以管理員身份運行 VS Code)防火牆或代理限制(檢查設置,解除限制)終端設置不正確(啟用使用外部終端)VS Code 安裝損壞(重新安裝或更新)終端配置不兼容(嘗試不同的終端類型或命令)特定環境變量缺失(設置必要的環境變量)

See all articles