ansible:如何在centos 7上重新启动auditd服务得到关于依赖的错误

在我的剧本中,我有一个更新 audit.rules 的任务,然后通知应该重新启动 auditd 服务的处理程序。

复制代码
`task:
  `-` name:  `6.6.7` `-` `audit` `rules` `configuration`
    template: `src=X/ansible/templates/auditd_rules.j2`
              `dest=/etc/audit/rules.d/audit.rules`
              `backup=yes`
              `owner=root` `group=root` `mode=0640`
     notify:
   `-` `restart` `auditd`


  handlers:
    `-` name: `restart` `auditd`
      service: `name=auditd` `state=restarted`
`

当 playbook 运行时,会更新审计规则并请求重新启动 auditd,但这会失败,如下所示。

复制代码
`RUNNING HANDLER [restart auditd] `************************************************ fatal: [ipX-southeast-2.compute.internal]: FAILED! => {"changed": false, "failed": true, "msg": "Unable to restart service auditd: Failed to restart auditd.service: Operation refused, unit auditd.service may be requested by dependency only.\n"}*

当我查看auditd 的单元定义时,我可以看到rejectManualStop=yes。这就是我无法重新启动服务的原因吗?一个人如何来接受新的审计规则?

复制代码
` systemctl `cat auditd.service`
`# /usr/lib/systemd/system/auditd.service`
[Unit]
Description=`Security Auditing Service`
DefaultDependencies=`no`
After=`local-fs.target systemd-tmpfiles-setup.service`
Conflicts=`shutdown.target`
Before=`sysinit.target shutdown.target`
RefuseManualStop=`yes`
ConditionKernelCommandLine=`!audit=0`
Documentation=`man:auditd(8) https://people.redhat.com/sgrubb/audit/`

[Service]
ExecStart=`/sbin/auditd -n`
`## To not use augenrules, copy this file to /etc/systemd/system/auditd.service`
`## and comment/delete the next line and uncomment the auditctl line.`
`## NOTE: augenrules expect any rules to be added to /etc/audit/rules.d/`
ExecStartPost=`-/sbin/augenrules --load`
`#ExecStartPost=-/sbin/auditctl -R /etc/audit/audit.rules`
ExecReload=`/bin/kill -HUP $MAINPID`
`# By default we don't clear the rules on exit. To enable this, uncomment`
`# the next line after copying the file to /etc/systemd/system/auditd.service`
`#ExecStopPost=/sbin/auditctl -R /etc/audit/audit-stop.rules`

[Install]
WantedBy=`multi-user.target`
`

最佳答案
这已在 Red Hat Bugzilla #1026648 中进行了探索、讨论和解决(大部分)。和 Anisble Issue # 22171 (github)报告。

分辨率

  • 使用 ansible service模块参数use=service强制执行 /sbin/service实用程序而不是 systemd 的聚集事实值(调用 /sbin/systemctl )像这样:
  • - service: name=auditd state=restarted use=service
  • Example playbook (pastebin.com)
  • 解决方法:
  • 使用 ansible command模块来显式运行服务可执行文件,如下所示:
  • - command: /sbin/service auditd restart
  • 分析------根本原因:
    • This is an issue created by upstream packaging of auditd.service unit. It will not start/stop/restart when acted upon by systemctl, apparently by design.
    • It is further compounded by the Ansible service control function, which uses the preferred method identified when system facts are gathered and "ansible_service_mgr" returns "systemd". This is regardless of the actual module used to manage the service.unit.
    • RHEL dev team may fix if considered a problem in upcoming updates (ERRATA)
    • Ansible dev team has offered a workaround and (as of 2.2) updated the service module with the use parameter.

关于ansible:如何在centos 7上重新启动auditd服务得到关于依赖的错误,我们在Stack Overflow上找到一个类似的问题: centos7 - ansible: how to restart auditd service on centos 7 get error about dependency - Stack Overflow
在我的剧本中,我有一个更新 audit.rules 的任务,然后通知应该重新启动 auditd 服务的处理程序。

复制代码
`task:
  `-` name:  `6.6.7` `-` `audit` `rules` `configuration`
    template: `src=X/ansible/templates/auditd_rules.j2`
              `dest=/etc/audit/rules.d/audit.rules`
              `backup=yes`
              `owner=root` `group=root` `mode=0640`
     notify:
   `-` `restart` `auditd`


  handlers:
    `-` name: `restart` `auditd`
      service: `name=auditd` `state=restarted`
`

当 playbook 运行时,会更新审计规则并请求重新启动 auditd,但这会失败,如下所示。

复制代码
`RUNNING HANDLER [restart auditd] `************************************************ fatal: [ipX-southeast-2.compute.internal]: FAILED! => {"changed": false, "failed": true, "msg": "Unable to restart service auditd: Failed to restart auditd.service: Operation refused, unit auditd.service may be requested by dependency only.\n"}*

当我查看auditd 的单元定义时,我可以看到rejectManualStop=yes。这就是我无法重新启动服务的原因吗?一个人如何来接受新的审计规则?

复制代码
` systemctl `cat auditd.service`
`# /usr/lib/systemd/system/auditd.service`
[Unit]
Description=`Security Auditing Service`
DefaultDependencies=`no`
After=`local-fs.target systemd-tmpfiles-setup.service`
Conflicts=`shutdown.target`
Before=`sysinit.target shutdown.target`
RefuseManualStop=`yes`
ConditionKernelCommandLine=`!audit=0`
Documentation=`man:auditd(8) https://people.redhat.com/sgrubb/audit/`

[Service]
ExecStart=`/sbin/auditd -n`
`## To not use augenrules, copy this file to /etc/systemd/system/auditd.service`
`## and comment/delete the next line and uncomment the auditctl line.`
`## NOTE: augenrules expect any rules to be added to /etc/audit/rules.d/`
ExecStartPost=`-/sbin/augenrules --load`
`#ExecStartPost=-/sbin/auditctl -R /etc/audit/audit.rules`
ExecReload=`/bin/kill -HUP $MAINPID`
`# By default we don't clear the rules on exit. To enable this, uncomment`
`# the next line after copying the file to /etc/systemd/system/auditd.service`
`#ExecStopPost=/sbin/auditctl -R /etc/audit/audit-stop.rules`

[Install]
WantedBy=`multi-user.target`
`

最佳答案
这已在 Red Hat Bugzilla #1026648 中进行了探索、讨论和解决(大部分)。和 Anisble Issue # 22171 (github)报告。

分辨率

  • 使用 ansible service模块参数use=service强制执行 /sbin/service实用程序而不是 systemd 的聚集事实值(调用 /sbin/systemctl )像这样:
  • - service: name=auditd state=restarted use=service
  • Example playbook (pastebin.com)
  • 解决方法:
  • 使用 ansible command模块来显式运行服务可执行文件,如下所示:
  • - command: /sbin/service auditd restart
  • 分析------根本原因:
    • This is an issue created by upstream packaging of auditd.service unit. It will not start/stop/restart when acted upon by systemctl, apparently by design.
    • It is further compounded by the Ansible service control function, which uses the preferred method identified when system facts are gathered and "ansible_service_mgr" returns "systemd". This is regardless of the actual module used to manage the service.unit.
    • RHEL dev team may fix if considered a problem in upcoming updates (ERRATA)
    • Ansible dev team has offered a workaround and (as of 2.2) updated the service module with the use parameter.

关于ansible:如何在centos 7上重新启动auditd服务得到关于依赖的错误,我们在Stack Overflow上找到一个类似的问题: centos7 - ansible: how to restart auditd service on centos 7 get error about dependency - Stack Overflow
在我的剧本中,我有一个更新 audit.rules 的任务,然后通知应该重新启动 auditd 服务的处理程序。

复制代码
`task:
  `-` name:  `6.6.7` `-` `audit` `rules` `configuration`
    template: `src=X/ansible/templates/auditd_rules.j2`
              `dest=/etc/audit/rules.d/audit.rules`
              `backup=yes`
              `owner=root` `group=root` `mode=0640`
     notify:
   `-` `restart` `auditd`


  handlers:
    `-` name: `restart` `auditd`
      service: `name=auditd` `state=restarted`
`

当 playbook 运行时,会更新审计规则并请求重新启动 auditd,但这会失败,如下所示。

复制代码
`RUNNING HANDLER [restart auditd] `************************************************ fatal: [ipX-southeast-2.compute.internal]: FAILED! => {"changed": false, "failed": true, "msg": "Unable to restart service auditd: Failed to restart auditd.service: Operation refused, unit auditd.service may be requested by dependency only.\n"}*

当我查看auditd 的单元定义时,我可以看到RejectManualStop=yes。这就是我无法重新启动服务的原因吗?一个人如何来接受新的审计规则?

复制代码
` systemctl `cat auditd.service`
`# /usr/lib/systemd/system/auditd.service`
[Unit]
Description=`Security Auditing Service`
DefaultDependencies=`no`
After=`local-fs.target systemd-tmpfiles-setup.service`
Conflicts=`shutdown.target`
Before=`sysinit.target shutdown.target
RefuseManualStop=yes
`ConditionKernelCommandLine=`!audit=0
`Documentation=`man:auditd(8) https://people.redhat.com/sgrubb/audit/`[Service]
ExecStart=`/sbin/auditd -n`
`## To not use augenrules, copy this file to /etc/systemd/system/auditd.service`
`## and comment/delete the next line and uncomment the auditctl line.`
`## NOTE: augenrules expect any rules to be added to /etc/audit/rules.d/`
ExecStartPost=`-/sbin/augenrules --load`
`#ExecStartPost=-/sbin/auditctl -R /etc/audit/audit.rules`
ExecReload=`/bin/kill -HUP $MAINPID`
`# By default we don't clear the rules on exit. To enable this, uncomment`
`# the next line after copying the file to /etc/systemd/system/auditd.service`
`#ExecStopPost=/sbin/auditctl -R /etc/audit/audit-stop.rules`

[Install]
WantedBy=`multi-user.target`
`

最佳答案
这已在 Red Hat Bugzilla #1026648 中进行了探索、讨论和解决(大部分)。和 Anisble Issue # 22171 (github)报告。

分析:

  • 使用 ansible service模块参数use=service强制执行 /sbin/service实用程序而不是 systemd 的聚集事实值(调用 /sbin/systemctl )像这样:
python 复制代码
- service: name=auditd state=restarted use=service
python 复制代码
- command: /sbin/service auditd restart

分析------根本原因:

  • This is an issue created by upstream packaging of auditd.service unit. It will not start/stop/restart when acted upon by systemctl, apparently by design.
  • It is further compounded by the Ansible service control function, which uses the preferred method identified when system facts are gathered and "ansible_service_mgr" returns "systemd". This is regardless of the actual module used to manage the service.unit.
  • RHEL dev team may fix if considered a problem in upcoming updates (ERRATA)
  • Ansible dev team has offered a workaround and (as of 2.2) updated the service module with the use parameter.

关于ansible:如何在centos 7上重新启动auditd服务得到关于依赖的错误,我们在Stack Overflow上找到一个类似的问题: centos7 - ansible: how to restart auditd service on centos 7 get error about dependency - Stack Overflow

https://stackoverflow.com/questions/41053331/

简单来说就是auditd开发者觉着auditd是系统底层记录日志的服务,不应由管理员重启或停止其服务。

解决方法:

1、使用service auditd restart可以绕过systemctl重启auditd服务。

2、修改systemd服务配置文件/usr/lib/systemd/system/auditd.service配置``RefuseManualStop=No``,执行systemctl deamon-reload。后可以使用systemctl restart auditd

在ansible-play里,1、可以使用command模块代替service模块,重启auditd服务。

  • command: /sbin/service auditd restart

或者2、修改auditd.service配置文件,使systemctl可以管理auditd

相关推荐
ddacrp6 小时前
RHEL_NFS服务器
linux·服务器·网络
码界奇点6 小时前
Linux进程间通信三System V 共享内存完全指南原理系统调用与 C 封装实现
linux·c语言·网络·c++·ux·risc-v
ZHANG13HAO7 小时前
RV1106 通过 4G 网络基于 libdatachannel 实现 WebRTC 实时视频传输”
linux
..过云雨7 小时前
13.【Linux系统编程】从ELF格式深入理解动静态库
linux·c语言·c++·后端
一名机电研究生7 小时前
华为、阿里巴巴、字节跳动 100+ Linux面试问题总结(一)
linux·华为·面试
讨厌下雨的天空7 小时前
环境变量与地址
linux
阿巴~阿巴~8 小时前
深入解析UDP服务器核心开发机制
linux·服务器·网络协议·网络编程·udp服务器·recvfrom函数
wa的一声哭了8 小时前
Linux服务器配置ssh免密登陆多台服务器、服务器别名配置
linux·运维·服务器·网络·arm开发·python·ssh
beijingliushao8 小时前
93-MongoDB-Linux
linux·数据库·mongodb
YongCheng_Liang9 小时前
openEuler 22.03 LTS 部署 ELK(Elasticsearch+Logstash+Kibana)完整教程
linux·运维·elk·elasticsearch