AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 464029
Accepted
Milister
Milister
Asked: 2018-08-22 19:59:43 +0800 CST2018-08-22 19:59:43 +0800 CST 2018-08-22 19:59:43 +0800 CST

如何在 SELinux 中添加异常?

  • 772

当 SELinux 被禁用时,我没有任何问题,但是当它被强制执行时,我就面临这个问题

[systemd] failed to get d-bus session: Failed to connect to socket /run/dbus/system_bus_socket: Permission denied

审计日志

 sealert -a /var/log/audit/audit.log
100% done
found 2 alerts in /var/log/audit/audit.log
--------------------------------------------------------------------------------

SELinux is preventing /usr/sbin/zabbix_agentd from connectto access on the unix_stream_socket /run/dbus/system_bus_socket.

*****  Plugin catchall (100. confidence) suggests   **************************

If you believe that zabbix_agentd should be allowed connectto access on the system_bus_socket unix_stream_socket by default.
Then you should report this as a bug.
You can generate a local policy module to allow this access.
Do
allow this access for now by executing:
# ausearch -c 'zabbix_agentd' --raw | audit2allow -M my-zabbixagentd
# semodule -i my-zabbixagentd.pp

我按照上面的建议创建了一个策略,重新启动了 zabbix-agent,现在从 zabbix 代理日志获取

[systemd] failed to get d-bus session: An SELinux policy prevents this sender from sending this message to this recipient, 0 matched rules; type="method_call", sender="(null)" (inactive) interface="org.freedesktop.DBus" member="Hello" error name="(unset)" requested_reply="0" destination="org.freedesktop.DBus" (bus)



 sealert -a /var/log/audit/audit.log
 39% donetype=AVC msg=audit(1534885076.573:250): avc:  denied  { connectto } for  pid=10654 comm="zabbix_agentd" path="/run/dbus/system_bus_socket" scontext=system_u:system_r:zabbix_agent_t:s0 tcontext=system_u:system_r:system_dbusd_t:s0-s0:c0.c1023 tclass=unix_stream_socket

**** Invalid AVC allowed in current policy ***
permissions selinux
  • 1 1 个回答
  • 2554 Views

1 个回答

  • Voted
  1. Best Answer
    maulinglawns
    2018-08-22T23:24:28+08:002018-08-22T23:24:28+08:00

    嗯,首先你必须确定你从 SELinux 得到的拒绝。最简单的(在我看来)方法是通过sealert实用程序。

    首先安装setroubleshoot-server软件包:

    yum install setroubleshoot-server
    

    然后运行:

    sealert -a /var/log/audit/audit.log
    

    你可能会得到很多输出,寻找你的具体拒绝,并遵循建议。但一定不要允许不应该允许的事情!

    这是拒绝的示例,以及sealert(我的重点)建议的解决方法:

    SELinux 正在阻止 /usr/libexec/postfix/qmgr 对进程使用 rlimitinh 访问。
    
    ***** 插件包罗万象(100。信心)建议 ******************************
    
    您认为默认情况下应该允许 qmgr 对标记为 postfix_qmgr_t 的进程进行 rlimitinh 访问。
    然后你应该将此报告为错误。
    您可以生成本地策略模块以允许此访问。
    做
    通过执行以下命令暂时允许此访问:
    # ausearch -c 'qmgr' --raw | audit2allow -M my-qmgr
    # semodule -i my-qmgr.pp
    
    
    附加信息:
    源上下文 system_u:system_r:postfix_master_t:s0
    目标上下文 system_u:system_r:postfix_qmgr_t:s0
    目标对象未知 [ 进程 ]
    来源 qmgr
    源路径 /usr/libexec/postfix/qmgr
    港口                          
    主持人                          
    源 RPM 包 postfix-2.10.1-6.el7.x86_64
    目标 RPM 包           
    策略 RPM selinux-policy-3.13.1-102.el7_3.16.noarch
    Selinux 启用 True
    目标策略类型
    执行模式执行
    主机名 centos
    平台 Linux centos 3.10.0-514.26.2.el7.x86_64 #1 SMP Tue
                                  2017 年 7 月 4 日 15:04:05 UTC x86_64 x86_64
    警报计数 5
    首次出现时间 2018-04-18 18:02:32 CEST
    最后出现时间 2018-08-22 09:11:22 CEST
    本地 ID 855f168c-1e47-4c6b-8a1e-f8fddce5d426
    

    上面的示例再次涉及 Postfix;查找您的拒绝,并插入本地策略。

    • 4

相关问题

  • 组权限如何工作?

  • Redis日志文件权限错误,但是权限已经是777

  • 以 root 权限启动 zypper 命令

  • 以非特权用户身份运行时,meld 无法访问 /dev/fd/* 的可能原因是什么?

  • 另一个用户的非空子目录是否可以安全地从我的目录中删除?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve