Linux系统下安全控制策略SELinux解析

2023-10-28 06:28

本文主要是介绍Linux系统下安全控制策略SELinux解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SELinux(Security-Enhanced linux)是增强版Linux,简称SELinux,它是一个Linux内核模块,也是Linux的一个安全子系统,主要以内核模块为支持,用户态程序进行权限策略管理。

背景

Linux系统下的root权限相当于系统的最高权限,例如,当一个Linux木马程序通过漏洞或钓鱼等方式在用户电脑中执行时,几乎可以完成任何操作,这给Linux系统安全造成了严峻的威胁。

为了降低这一安全风险,Linux系统引入了SELinux安全控制策略。SELinux控制策略的核心思想,相当于给系统设置了2把锁,除了root权限用户之外,还引入了管理员adm用户,而且这两个用户的权限各不相同,甚至存在相互制约,攻击者必须同时获取两把钥匙才能取得权限,这极大降低了暴露的攻击面和被攻击的可能。

SELinux安全策略把权限细化到访问的目录或具体的文件,这意味着每个Linux系统运行的程序只能访问事先被允许的文件,访问其他的文件就会出现访问受限或者报错。如果权限控制策略写的非常仔细,或在产品的二进制中执行RCE shellcode,最终也只能访问一些无关的不重要信息。

SELinux的引入降低了系统被攻击和控制的风险,但同时导致Linux系统在使用上更复杂,因此,这些策略更适用于布置在已经调试好的机器。但SELinux也是历史上最杰出的安全子系统,其中的模块实现细节和安全思想也被多数安全产品借鉴,二次开发出安全产品和引入到其他的类linux系统中。

本文将详细介绍其中的实现思想,并对控制策略细节进行分析。

策略细节分析

1. 策略3种状态

在Linux安全操作系统上,SELinux的安全策略状态有三种:

Enforcing(强制模式):表示SELinux正在运行,所设置的所有安全策略都被启用,所有与SELinux安全策略相关的服务和程序被策略限制。

Permissive(宽容模式):表示SELinux运行,所设置的所有安全策略都被启用,所有涉及到的安全策略相关的服务和程序不会被策略限制,程序不会受到限制,但是会有日志记录。

Disabled(关闭):SELinux安全策略被关闭。

2. 实现细节
在这里插入图片描述

SELinux的框架实现的思想是通Linux内核模块的LSM框架进行实现的,LSM框架的思想允许安全模块.ko类型的文件以插件的方式进入内核,以便更严格地控制基于身份的任意访问安全性。LSM框架开发了一套系统的钩子函数接口,可以对Linux系统的文件进行复制、移动及修改,网络行为监控、IP、端口都对应了其中的配置规则,SELinux作为一个LSM的内核模块加载到内核中,在允许之前进行额外的访问确认,安全服务器就是对访问的规则进行策略判断,这些策略通过用户空间的策略管理接口配置到系统中,SELinux策略通过内核的LSM框架为基础去实现,LSM提供内核消息钩子函数去捕获操作系统的各种操作消息,在此基础上,SELinux自己在内核中实现了策略管理器,通过不同的策略与传递过来的消息进行对比,以此判断放行或阻断。

3. 配置文件说明
上述了策略的配置,管理员账户可通过用户态提供策略的接口去配置策略,策略文件是为策略源文件作说明的,policy.conf策略的具体组成包括:类别和许可、类型强制声明(类型、TE规则、角色和用户)、约束、资源标记说明。

其应用于管理编写特定规则下的文件,例如policy.conf,通过策略编译器checkpolicy去编译、生成policy.xx的二进制文件,同时策略编译器在编译规则时会检测语法是否正确,错误的规则语法会判断编译不通过,之后编译文件的策略二进制通过checkmodule命令去载入到内核中,规则开始生效。

在这里插入图片描述

具体的规则配置官方手册:https://opensource.com/business/13/11/selinux-policy-guide

适用场景及优缺点

SELinux安全控制策略作为Linux子系统中的安全防护环节,具有安全可靠、权限细化等特点。由于开启SELinux策略的Linux系统,会对所有操作进行审计和规则检测,如果规则中没有给浏览器对应的端口访问权限和特定的文件执行,访问就会失败,因此,SELinux策略更适用于安全产品配置到Linux系统中的一体化硬件设备中去开启,也能更大程度发挥出安全策略的优势。

总结

SELinux安全控制策略是安全体系中端点安全防护中的一环,其主要采用权限分类和认证的策略,使未经过认证的程序无法被执行,防止操作系统被入侵后陌生程序执行恶意程序和木马,Android的权限访问控制策略也借鉴了其中的安全思想。总的来说,SELinux的安全控制策略拥有优秀的安全控制框架,允许自定义适合自身系统的安全策略,增强Linux的系统安全,防御未知攻击。

这篇关于Linux系统下安全控制策略SELinux解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/291319

相关文章

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

Linux镜像文件制作方式

《Linux镜像文件制作方式》本文介绍了Linux镜像文件制作的过程,包括确定磁盘空间布局、制作空白镜像文件、分区与格式化、复制引导分区和其他分区... 目录1.确定磁盘空间布局2.制作空白镜像文件3.分区与格式化1) 分区2) 格式化4.复制引导分区5.复制其它分区1) 挂载2) 复制bootfs分区3)

SQL 注入攻击(SQL Injection)原理、利用方式与防御策略深度解析

《SQL注入攻击(SQLInjection)原理、利用方式与防御策略深度解析》本文将从SQL注入的基本原理、攻击方式、常见利用手法,到企业级防御方案进行全面讲解,以帮助开发者和安全人员更系统地理解... 目录一、前言二、SQL 注入攻击的基本概念三、SQL 注入常见类型分析1. 基于错误回显的注入(Erro

Linux服务器数据盘移除并重新挂载的全过程

《Linux服务器数据盘移除并重新挂载的全过程》:本文主要介绍在Linux服务器上移除并重新挂载数据盘的整个过程,分为三大步:卸载文件系统、分离磁盘和重新挂载,每一步都有详细的步骤和注意事项,确保... 目录引言第一步:卸载文件系统第二步:分离磁盘第三步:重新挂载引言在 linux 服务器上移除并重新挂p

C++ 多态性实战之何时使用 virtual 和 override的问题解析

《C++多态性实战之何时使用virtual和override的问题解析》在面向对象编程中,多态是一个核心概念,很多开发者在遇到override编译错误时,不清楚是否需要将基类函数声明为virt... 目录C++ 多态性实战:何时使用 virtual 和 override?引言问题场景判断是否需要多态的三个关

Linux下屏幕亮度的调节方式

《Linux下屏幕亮度的调节方式》文章介绍了Linux下屏幕亮度调节的几种方法,包括图形界面、手动调节(使用ACPI内核模块)和外接显示屏调节,以及自动调节软件(CaliseRedshift和Reds... 目录1 概述2 手动调节http://www.chinasem.cn2.1 手动屏幕调节2.2 外接显

Linux(centos7)虚拟机没有IP问题及解决方案

《Linux(centos7)虚拟机没有IP问题及解决方案》文章介绍了在CentOS7中配置虚拟机网络并使用Xshell连接虚拟机的步骤,首先,检查并配置网卡ens33的ONBOOT属性为yes,然后... 目录输入查看ZFhrxIP命令:ip addr查看,没有虚拟机IP修改ens33配置文件重启网络Xh

C++简单日志系统实现代码示例

《C++简单日志系统实现代码示例》日志系统是成熟软件中的一个重要组成部分,其记录软件的使用和运行行为,方便事后进行故障分析、数据统计等,:本文主要介绍C++简单日志系统实现的相关资料,文中通过代码... 目录前言Util.hppLevel.hppLogMsg.hppFormat.hppSink.hppBuf

linux实现对.jar文件的配置文件进行修改

《linux实现对.jar文件的配置文件进行修改》文章讲述了如何使用Linux系统修改.jar文件的配置文件,包括进入文件夹、编辑文件、保存并退出编辑器,以及重新启动项目... 目录linux对.jar文件的配置文件进行修改第一步第二步 第三步第四步总结linux对.jar文件的配置文件进行修改第一步进

Redis的安全机制详细介绍及配置方法

《Redis的安全机制详细介绍及配置方法》本文介绍Redis安全机制的配置方法,包括绑定IP地址、设置密码、保护模式、禁用危险命令、防火墙限制、TLS加密、客户端连接限制、最大内存使用和日志审计等,通... 目录1. 绑定 IP 地址2. 设置密码3. 保护模式4. 禁用危险命令5. 通过防火墙限制访问6.