如何快速检查SELinux安全状态?

查看 SELinux 运行状态

  1. 使用 sestatus 命令

    sestatus
    • 关键输出
      • SELinux status: enabled(已启用)或 disabled(已禁用)
      • Current mode: enforcing(强制模式)、permissive(宽容模式)或 disabled
      • Policy version: 当前策略版本(如 31
      • Policy from config file: 加载的策略名称(如 targeted
  2. 检查内核参数

    grep -E "SELINUX=|SELINUXTYPE=" /etc/selinux/config
    • 结果说明
      • SELINUX=enforcing:系统重启后将启用强制模式
      • SELINUXTYPE=targeted:默认策略类型(针对网络服务限制)

查看当前模式(无需重启)

getenforce
  • 返回结果:
    • Enforcing:强制模式(拒绝违规操作并记录日志)
    • Permissive:宽容模式(仅记录日志,不阻止操作)
    • Disabled:已禁用

查看策略详情

  1. 列出所有布尔值(动态开关)

    getsebool -a
    • 示例输出:
      httpd_can_network_connect --> off(表示 Apache 禁止联网)
    • 修改布尔值
      setsebool -P httpd_can_network_connect on  # -P 永久生效
  2. 检查文件/目录的上下文标签

    ls -Z /var/www/html
    • 输出示例
      -rw-r--r--. root root system_u:object_r:httpd_sys_content_t index.html

      • 关键字段:httpd_sys_content_t(Web 内容默认标签)
  3. 查看进程的上下文

    ps -eZ | grep nginx
    • 输出示例:
      system_u:system_r:httpd_t:s0 1234 ? nginx

      • httpd_t:Web 服务进程的默认标签

诊断 SELinux 拒绝事件

  1. 查看审计日志

    ausearch -m AVC,USER_AVC -ts today  # 查询今日的拒绝记录
    • 关键字段
      scontext=system_u:system_r:httpd_t(源上下文)
      tcontext=system_u:object_r:samba_share_t(目标上下文)
      tclass=file(操作对象类型)
  2. 使用 sealert 生成分析报告

    sealert -a /var/log/audit/audit.log
    • 该工具会提供解决方案建议(需安装 setroubleshoot 包)

常见问题排查

  • 服务无法启动
    检查日志中的 AVC denied 记录,确认是否因标签错误导致。
  • 文件访问被拒
    使用 restorecon 修复标签:

     restorecon -Rv /path/to/file  # -R 递归修复,-v 显示详情
  • 临时切换模式(调试用):
     setenforce 0  # 切换为 Permissive 模式
     setenforce 1  # 切回 Enforcing 模式

重要提示

  • 修改配置后需重启生效:reboot
  • 生产环境避免禁用 SELinux,优先调整策略或布尔值
  • 策略包更新命令:yum update selinux-policy*

引用说明
本文操作基于 CentOS/RHEL 8 及 SELinux 官方文档,参考来源:

  • Red Hat SELinux 用户手册(https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/8/html-single/using_selinux/index)
  • NSA SELinux 项目(https://github.com/SELinuxProject)
  • Linux 手册页(man semanage, man auditd

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/9213.html

(0)
酷番叔酷番叔
上一篇 10小时前
下一篇 10小时前

相关推荐

  • 如何用wget下载整个网站

    SCP(安全复制协议)原理:基于SSH加密传输,适合中小文件,命令格式:scp [选项] 用户名@远程IP:远程文件路径 本地保存路径示例:复制单个文件(远程22端口,用户名为user)scp -P 2222 user@192.168.1.100:/home/user/data.txt /local/dir……

    2025年7月8日
    1400
  • 月入过万的副业真的靠谱吗?

    简答:本文探讨了人工智能在医疗诊断中的应用潜力,分析了其提升效率与准确性的优势;同时指出数据隐私、算法偏见等关键挑战;最后强调需建立严格监管与伦理框架以实现其安全、公平发展。

    2025年6月18日
    2000
  • 如何快速定位mysqld路径?

    方法1:使用 mysql 命令(推荐)mysql –version输出示例:mysql Ver 8.0.33-0ubuntu0.22.04.2 for Linux on x86_64 ((Ubuntu))说明:直接显示MySQL客户端版本,无需登录数据库,若提示command not found,需安装MyS……

    2025年7月2日
    1600
  • 你当前在用哪个DNS?

    在Linux系统中配置多个DNS服务器是提升网络可靠性和解析效率的关键实践,当主DNS服务器响应缓慢或故障时,系统会自动切换至备用服务器,保障服务的连续性,下面从工作机制、配置方法到底层原理进行深度解析,核心工作机制Linux的DNS解析遵循分层递进策略:顺序查询机制系统按/etc/resolv.conf文件中……

    2天前
    500
  • Ubuntu还是Debian更合适?

    Linux安装网卡驱动详细指南为什么需要手动安装网卡驱动?Linux内核通常自带主流网卡驱动(如Intel、Realtek常见型号),但以下情况需手动安装:新硬件兼容滞后:新型号网卡尚未被内核支持厂商专属驱动:部分企业级网卡(如Broadcom、某些无线网卡)需专用驱动功能限制:开源驱动可能缺少高级功能(如SR……

    3天前
    400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信