Security-Enhanced Linux (SELinux) 是一种强制访问控制 (MAC) 系统,它通过将称为SELinux 上下文的安全标签应用于每个系统对象来实现访问权限。SELinux 策略模块使用 SELinux 上下文来定义进程、文件、端口和其他系统对象如何相互交互的规则。只有在策略规则允许的情况下,系统对象之间的交互才被允许。
SELinux 上下文(应用于系统对象的标签)具有以下字段:user
、role
、
type
和security level
。类型信息而不是整个 SELinux 上下文最常用于定义进程如何与其他系统对象交互的规则。例如,MySQL SELinux 策略模块使用type
信息定义策略规则。
您可以使用操作系统命令(例如带
选项的ls和ps )查看 SELinux 上下文。-Z
假设 SELinux 已启用并且 MySQL 服务器正在运行,以下命令显示mysqld进程和 MySQL 数据目录的 SELinux 上下文:
mysqld进程:
$> ps -eZ | grep mysqld
system_u:system_r:mysqld_t:s0 5924 ? 00:00:03 mysqld
MySQL数据目录:
$> cd /var/lib
$> ls -Z | grep mysql
system_u:object_r:mysqld_db_t:s0 mysql
在哪里:
system_u
是系统进程和对象的 SELinux 用户标识。system_r
是用于系统进程的 SELinux 角色。objects_r
是用于系统对象的 SELinux 角色。mysqld_t
是与 mysqld 进程关联的类型。mysqld_db_t
是与 MySQL 数据目录及其文件关联的类型。s0
是安全级别。
有关解释 SELinux 上下文的更多信息,请参阅您的发行版的 SELinux 文档。