MySQL 8.0 参考手册  / 第 6 章 安全  /  6.7 SELinux

6.7 SELinux

Security-Enhanced Linux (SELinux) 是一种强制访问控制 (MAC) 系统,它通过将称为SELinux 上下文的安全标签应用于每个系统对象来实现访问权限。SELinux 策略模块使用 SELinux 上下文来定义进程、文件、端口和其他系统对象如何相互交互的规则。只有在策略规则允许的情况下,系统对象之间的交互才被允许。

SELinux 上下文(应用于系统对象的标签)具有以下字段:userroletypesecurity level。类型信息而不是整个 SELinux 上下文最常用于定义进程如何与其他系统对象交互的规则。例如,MySQL SELinux 策略模块使用type信息定义策略规则。

您可以使用操作系统命令(例如带 选项的lsps )查看 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 文档。