四個(gè)導(dǎo)致SELinux警告產(chǎn)生的原因詳細(xì)介紹
發(fā)布時(shí)間:2012-11-15 10:56:11 作者:佚名
我要評(píng)論

上次的 SELinux 的入門評(píng)論中,有童鞋表示 SELinux 警告看不懂;這次就來(lái)介紹下四個(gè)導(dǎo)致警告產(chǎn)生的原因以及解決方案,需要的朋友可以參考下
上次的 SELinux 的入門評(píng)論中,有童鞋表示 SELinux 警告看不懂。這次就來(lái)介紹下四個(gè)導(dǎo)致警告產(chǎn)生的原因以及解決方案。
原因一:出現(xiàn)標(biāo)注錯(cuò)誤
SELinux 的核心概念就是標(biāo)注,無(wú)論是文件系統(tǒng)、目錄、文件、文件啟動(dòng)描述符、端口、消息接口還是網(wǎng)絡(luò)接口,所有的一切都需要標(biāo)簽,并且僅且僅能按照標(biāo)簽所賦予的權(quán)限執(zhí)行。即使運(yùn)行的 Apache 進(jìn)程被黑客入侵且取得了 uid=0 root 權(quán)限,它依然無(wú)法訪問(wèn)某個(gè)用戶主目錄下的文件。因?yàn)闃?biāo)注為 httpdt 的 Apache 進(jìn)程所持有的無(wú)法訪問(wèn)標(biāo)注為 userhome_t 的內(nèi)容。
因此,如果標(biāo)注有問(wèn)題的話,SELinux 就會(huì)彈出警告。如何處理此類,可以參看本站前文中關(guān)于 semanage fcontext 和 restorecon 命令的使用。當(dāng)然也可以按照?qǐng)D形化的 SELinux 除錯(cuò)工具中的提示解決。
原因二:自定義了程序運(yùn)行設(shè)置
經(jīng)過(guò)多年的發(fā)展,SELinux 已經(jīng)積累了大量的策略文件時(shí),對(duì)于絕大多數(shù)應(yīng)用程序的默認(rèn)運(yùn)行請(qǐng)求都有記錄,可以賦予合適的最小權(quán)限予以執(zhí)行。不過(guò)若是您自定義了一些運(yùn)行配置或者有特殊的應(yīng)用需求,則需要調(diào)整部分 SELinux 設(shè)置。
對(duì)于大多數(shù)常見(jiàn)的自定義需求,SELinux 采取布爾值的方式進(jìn)行控制,可以參看本站前文中關(guān)于 setsebool 命令的使用。若想了解全部可調(diào)整的 SELinux 布爾值,使用 semanage boolean -l 命令。這可以通過(guò)圖形化的 SELinux 除錯(cuò)工具解決,也可以通過(guò)圖形化的 system-config-selinux 解決。
原因三:SELinux 策略或應(yīng)用程序配置有問(wèn)題
若是您并未特別修改配置卻依然收到 SELinux 警告,原因可能就在 SELinux 策略或者應(yīng)用程序本身了。此時(shí)建議首先在 SELinux 除錯(cuò)工具的幫助下提交錯(cuò)誤報(bào)告,然后再依據(jù)情況進(jìn)行處理。若是已經(jīng)被報(bào)告過(guò),通常在錯(cuò)誤報(bào)告的評(píng)論中會(huì)詳細(xì)解決方案。
此時(shí)若是想忽略 SELinux 警告依然運(yùn)行應(yīng)用程序,則有如下幾種方式:
將 SELinux 設(shè)為允許模式,僅記錄警告但不阻止運(yùn)行:setenforce 0。
將某單一標(biāo)注進(jìn)程設(shè)置為允許模式,而非整個(gè)系統(tǒng),例如僅想以允許模式運(yùn)行 Apache: semange permissive -a httpd_t
參照 SELinux 除錯(cuò)工具的建議創(chuàng)建并加載自定義策略。具體過(guò)程依情況而異,SELinux 除錯(cuò)工具內(nèi)會(huì)有詳細(xì)的說(shuō)明。
原因四:程序已被入侵
SELinux 并非入侵檢測(cè)系統(tǒng),所以目前 SELinux 除錯(cuò)工具無(wú)法主動(dòng)的甄別出入侵企圖,不過(guò)當(dāng)您發(fā)現(xiàn)警告內(nèi)容包含有如下特征時(shí),很有可能對(duì)應(yīng)進(jìn)程已被黑客攻破了:
嘗試關(guān)閉 SELinux (/etc/selinux) 或者設(shè)定某個(gè) SELinux 布爾值。
嘗試載入內(nèi)核模塊、寫入內(nèi)核目錄或者引導(dǎo)器鏡像。
嘗試讀取 shadow_t 標(biāo)識(shí)的文件,那里通常包含了加密的賬戶信息。
嘗試覆蓋寫入日志文件。
嘗試連接不需要的隨機(jī)端口或者郵件端口。
至此四種常見(jiàn)警告原因介紹完畢,希望您下次遇到 SELinux 警告時(shí)可以安全有效的處理。順便說(shuō)下,絕大部分 SELinux 除錯(cuò)工具的本地化問(wèn)題已經(jīng)解決,使用簡(jiǎn)中的童鞋們將可以在 Fedora 18 看到簡(jiǎn)中的警告內(nèi)容了。
原因一:出現(xiàn)標(biāo)注錯(cuò)誤
SELinux 的核心概念就是標(biāo)注,無(wú)論是文件系統(tǒng)、目錄、文件、文件啟動(dòng)描述符、端口、消息接口還是網(wǎng)絡(luò)接口,所有的一切都需要標(biāo)簽,并且僅且僅能按照標(biāo)簽所賦予的權(quán)限執(zhí)行。即使運(yùn)行的 Apache 進(jìn)程被黑客入侵且取得了 uid=0 root 權(quán)限,它依然無(wú)法訪問(wèn)某個(gè)用戶主目錄下的文件。因?yàn)闃?biāo)注為 httpdt 的 Apache 進(jìn)程所持有的無(wú)法訪問(wèn)標(biāo)注為 userhome_t 的內(nèi)容。
因此,如果標(biāo)注有問(wèn)題的話,SELinux 就會(huì)彈出警告。如何處理此類,可以參看本站前文中關(guān)于 semanage fcontext 和 restorecon 命令的使用。當(dāng)然也可以按照?qǐng)D形化的 SELinux 除錯(cuò)工具中的提示解決。
原因二:自定義了程序運(yùn)行設(shè)置
經(jīng)過(guò)多年的發(fā)展,SELinux 已經(jīng)積累了大量的策略文件時(shí),對(duì)于絕大多數(shù)應(yīng)用程序的默認(rèn)運(yùn)行請(qǐng)求都有記錄,可以賦予合適的最小權(quán)限予以執(zhí)行。不過(guò)若是您自定義了一些運(yùn)行配置或者有特殊的應(yīng)用需求,則需要調(diào)整部分 SELinux 設(shè)置。
對(duì)于大多數(shù)常見(jiàn)的自定義需求,SELinux 采取布爾值的方式進(jìn)行控制,可以參看本站前文中關(guān)于 setsebool 命令的使用。若想了解全部可調(diào)整的 SELinux 布爾值,使用 semanage boolean -l 命令。這可以通過(guò)圖形化的 SELinux 除錯(cuò)工具解決,也可以通過(guò)圖形化的 system-config-selinux 解決。
原因三:SELinux 策略或應(yīng)用程序配置有問(wèn)題
若是您并未特別修改配置卻依然收到 SELinux 警告,原因可能就在 SELinux 策略或者應(yīng)用程序本身了。此時(shí)建議首先在 SELinux 除錯(cuò)工具的幫助下提交錯(cuò)誤報(bào)告,然后再依據(jù)情況進(jìn)行處理。若是已經(jīng)被報(bào)告過(guò),通常在錯(cuò)誤報(bào)告的評(píng)論中會(huì)詳細(xì)解決方案。
此時(shí)若是想忽略 SELinux 警告依然運(yùn)行應(yīng)用程序,則有如下幾種方式:
將 SELinux 設(shè)為允許模式,僅記錄警告但不阻止運(yùn)行:setenforce 0。
將某單一標(biāo)注進(jìn)程設(shè)置為允許模式,而非整個(gè)系統(tǒng),例如僅想以允許模式運(yùn)行 Apache: semange permissive -a httpd_t
參照 SELinux 除錯(cuò)工具的建議創(chuàng)建并加載自定義策略。具體過(guò)程依情況而異,SELinux 除錯(cuò)工具內(nèi)會(huì)有詳細(xì)的說(shuō)明。
原因四:程序已被入侵
SELinux 并非入侵檢測(cè)系統(tǒng),所以目前 SELinux 除錯(cuò)工具無(wú)法主動(dòng)的甄別出入侵企圖,不過(guò)當(dāng)您發(fā)現(xiàn)警告內(nèi)容包含有如下特征時(shí),很有可能對(duì)應(yīng)進(jìn)程已被黑客攻破了:
嘗試關(guān)閉 SELinux (/etc/selinux) 或者設(shè)定某個(gè) SELinux 布爾值。
嘗試載入內(nèi)核模塊、寫入內(nèi)核目錄或者引導(dǎo)器鏡像。
嘗試讀取 shadow_t 標(biāo)識(shí)的文件,那里通常包含了加密的賬戶信息。
嘗試覆蓋寫入日志文件。
嘗試連接不需要的隨機(jī)端口或者郵件端口。
至此四種常見(jiàn)警告原因介紹完畢,希望您下次遇到 SELinux 警告時(shí)可以安全有效的處理。順便說(shuō)下,絕大部分 SELinux 除錯(cuò)工具的本地化問(wèn)題已經(jīng)解決,使用簡(jiǎn)中的童鞋們將可以在 Fedora 18 看到簡(jiǎn)中的警告內(nèi)容了。
相關(guān)文章
Fedora Linux 42 穩(wěn)定版發(fā)布: 帶來(lái)大量新功能和軟件更新
Fedora 42昨日發(fā)布,這是 Red Hat 贊助開發(fā)的杰出前沿 Linux 發(fā)行版的最新版,包含大量新功能和軟件更新,使其成為 2025 年上半年發(fā)布的一款出色的 Linux 操作系統(tǒng)之一,內(nèi)2025-04-16如何在Linux查看硬盤信息? 查看Linux硬盤大小類型和硬件信息的5種方法
使用Linux系統(tǒng)的過(guò)程中,查看和了解硬盤信息是非常重要的工作,尤其是對(duì)于系統(tǒng)管理員而言,那么在Linux系統(tǒng)中如何查看硬盤信息?以下是具體內(nèi)容介紹2025-03-12如何在 Linux 中查看 CPU 詳細(xì)信息? 3招輕松查看CPU型號(hào)、核心數(shù)和溫度
在日常運(yùn)維工作中,獲取 CPU 信息是系統(tǒng)運(yùn)維管理員常見(jiàn)的工作內(nèi)容,無(wú)論是為了性能調(diào)優(yōu)、硬件升級(jí)還是僅僅滿足好奇心2025-03-11什么是 Arch Linux? 獨(dú)樹一幟的Arch Linux發(fā)行版分析
Arch Linux是為簡(jiǎn)化,優(yōu)化,現(xiàn)代化,實(shí)用主義,用戶中心和多功能性而創(chuàng)建Linux發(fā)行版,究竟是什么讓 Arch 與眾不同?下面我們就來(lái)簡(jiǎn)要解讀2025-02-19如何在Linux環(huán)境下制作 Win11裝機(jī)U盤?
一直用的linux辦公,想要將筆記本電腦從 Linux 系統(tǒng)切換回 Windows 11,我們可以制作一個(gè)win11裝機(jī)u盤,詳細(xì)如下2025-02-17Rsnapshot怎么用? 基于Rsync的強(qiáng)大Linux備份工具使用指南
Rsnapshot 不僅可以備份本地文件,還能通過(guò) SSH 備份遠(yuǎn)程文件,接下來(lái)詳細(xì)介紹如何安裝、配置和使用 Rsnapshot,包括創(chuàng)建每小時(shí)、每天、每周和每月的本地備份,以及如何進(jìn)2025-02-06Linux Kernel 6.13發(fā)布:附更新內(nèi)容及新特性解讀
Linux 內(nèi)核 6.13 正式發(fā)布,新版本引入了惰性搶占支持,簡(jiǎn)化內(nèi)核搶占邏輯,通過(guò)減少與調(diào)度器相關(guān)的調(diào)用次數(shù),讓內(nèi)核在運(yùn)行時(shí)表現(xiàn)更優(yōu),從而提高效率2025-01-23五大特性引領(lǐng)創(chuàng)新! 深度操作系統(tǒng) deepin 25 Preview預(yù)覽版發(fā)布
今日,深度操作系統(tǒng)正式推出deepin 25 Preview版本,該版本集成了五大核心特性:磐石系統(tǒng)、全新DDE、Treeland窗口合成器、AI For OS以及Distrobox子系統(tǒng)2025-01-18Linux Mint Xia 22.1重磅發(fā)布: 重要更新一覽
Beta 版 Linux Mint“Xia” 22.1 發(fā)布,新版本基于 Ubuntu 24.04,內(nèi)核版本為 Linux 6.8,這次更新帶來(lái)了諸多優(yōu)化和改進(jìn),進(jìn)一步鞏固了 Mint 在 Linux 桌面操作系統(tǒng)領(lǐng)域的2025-01-16LinuxMint怎么安裝? Linux Mint22下載安裝圖文教程
Linux Mint22發(fā)布以后,有很多新功能,很多朋友想要下載并安裝,該怎么操作呢?下面我們就來(lái)看看詳細(xì)安裝指南2025-01-16