我想用 Ansible 播放将结果保存find
到文件中。
- name: Find / -name "postgresql"
find:
paths: /var/log
patterns: 'postgresql'
上述结果将保存到文件中。简单来说,命令是find / -name "postgresql" > text.txt
在 shell 中的。我如何在 Ansible 中发出该命令?
答案1
执行此操作的 Ansible 方法查找模块/var/log/secure
可能是(因为我没有运行 postgres,所以我用它作为示例):
---
- hosts: all
tasks:
- name: "Find file /var/log/secure"
find:
paths: /var/log
patterns: secure
register: result
- name: "Save find results to file"
copy:
content: "{{ result.files }}"
dest: "/tmp/find_result.txt"
内容/tmp/find_result.txt
:
# cat /tmp/find_result.txt
[{"uid": 0, "woth": false, "mtime": 1535012977.8429773, "inode": 9013905, "isgid": false, "size": 6867, "wgrp": false, "isuid": false, "isreg": true, "gid": 0, "ischr": false, "wusr": true, "xoth": false, "islnk": false, "nlink": 1, "issock": false, "rgrp": false, "path": "/var/log/secure", "xusr": false, "atime": 1534925281.706685, "isdir": false, "ctime": 1535012977.8429773, "isblk": false, "xgrp": false, "dev": 64768, "roth": false, "isfifo": false, "mode": "0600", "rusr": true}]
通过注册结果并检查 中的返回值files
,您可以访问大量可能有用的元数据。
如果您想要更少的输出,请使用记录的其他返回值这里。
答案2
您应该使用Ansible shell 模块在这种情况下。
这是一个例子:
- name: Find / -name "postgresql"
shell: find / -name "postgresql" > /tmp/text.txt