- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这个问题在这里已经有了答案:
How to move/rename a file using an Ansible task on a remote system
(13 个回答)
去年关闭。
所以我一直在尝试通过使用剧本来修复我在所有服务器中犯的错误。基本上,我启动了一个带有 logrotate 的剧本来解决不断增长的日志问题,其中有一个名为 btmp 的日志,我不应该旋转它,但无论如何还是意外地做了,现在 logrotate 更改了它的名称以添加一个日期,因此刹车日志。现在我想使用一个剧本,它将在/var/log 目录中找到一个名为 btmp 的日志并将其重命名,问题是每个服务器中的文件 atm 都不同,例如 1 个服务器有 btmp-20210316,另一个有 btmp- 20210309,所以在 bash 命令行中可以使用通配符“btmp*”来绕过这个问题,但是这在剧本中似乎不起作用。到目前为止,我想出了这个:
tasks:
- name: stat btmp*
stat: path=/var/log
register: btmp_stat
- name: Move btmp
command: mv /var/log/btmp* /var/log/btmp
when: btmp_stat.stat.exists
但是,这会导致找不到文件的错误。所以我的问题是如何让通配符在剧本中工作,或者是否有一种等效的方法来查找名称中包含“btmp”的所有文件并重命名它们?顺便说一句,所有服务器都是 Centos 7 服务器。
---
- hosts: '{{ server }}'
remote_user: username
become: yes
become_method: sudo
vars_prompt:
- name: "server"
prompt: "Enter server name or group"
private: no
tasks:
- name: Move the script to target host VM
copy: src=/anywhereyouwant/bashscript.sh dest=/tmp mode=0777
- name: Execute the script
command: sh /tmp/bashscript.sh
- name: delete the script
command: rm /tmp/bashscript.sh
最佳答案
在 Ansible 中有不止一种方法可以做到这一点,并且使用 shell
模块当然是一种可行的方法(但您需要 shell
模块来代替 command
,因为后者不支持通配符)。我将按如下方式解决问题:
/var/log/btmp*
)并将它们存储在一个变量中以供以后处理 - 这看起来像这样: - name: Find all files named /var/log/btmp*
ansible.builtin.find:
paths: /var/log
patterns: 'btmp*'
register: find_btmp
此任务使用
find
用于定位所有名为
btmp*
的文件的模块在
/var/log
- 结果存储在一个名为
find_btmp
的变量中.
- name: Copy the btmp* to the required filename
ansible.builtin.copy:
src: "{{ find_btmp.files | sort(attribute='mtime',reverse=true) | map(attribute='path') | first }}"
dest: /var/log/btmp
remote_src: yes
when: find_btmp.failed == false
此任务使用 Ansible 的
copy
模块将我们选择的源文件复制到
/var/log/btmp
.
remote_src: yes
参数告诉复制模块源文件存在于远程机器上,而不是 Ansible 主机本身。
when
子句以确保我们在找不到任何文件时不会运行此复制操作。
find_btmp.files
- 这是我们find_btmp
中列出的所有文件变量 sort(attribute='mtime',reverse=true)
- 这里我们使用 mtime
对我们的文件列表进行排序(修改时间) 属性 - 我们正在反向排序,以便最新条目位于列表顶部。 map(attribute='path')
- 我们正在使用 map “提取”path
files 字典的属性,因为这是我们真正想要传递给复制模块的唯一数据 - 文件本身的路径 first
- 这只会选择列表中的第一个元素(即最新的文件,因为它们是反向排序的) - name: Delete the original file
ansible.builtin.file:
path: "{{ find_btmp.files | sort(attribute='mtime',reverse=true) | map(attribute='path') | first }}"
state: absent
when: find_btmp.failed == false
我们再次使用
when
条款,以确保如果我们一开始没有找到任何东西,我们就不会删除它。
ansible.builtin.
从模块名称(即
ansible.builtin.copy
变为
copy
。)
关于ansible - 查找文件并将其重命名为 ansible playbook,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66654451/
尽管用户是 sudo 用户,但远程主机在运行 Ansible playbook 时仍会引发错误。 "/usr/bin/python: can't open file '/home/ludd/.ansi
只是想了解 ansible 和 ansible-galaxy 之间的核心区别是什么?从文档中,ansible-galaxy 用于管理角色(创建和发布)那么ansible是做什么用的呢?只运行剧本? 我
只是想了解 ansible 和 ansible-galaxy 之间的核心区别是什么?从文档中,ansible-galaxy 用于管理角色(创建和发布)那么ansible是做什么用的呢?只运行剧本? 我
我有一个定义如下的剧本: - name: install percona rpms hosts: imdp roles: - role1 - role2 - role3
Ansible 版本:2.4.2.0 来自 here和 here ,我可以写下面的剧本 $ cat test.yml - name: Finding Master VMs hosts: all-c
我正在运行这个 Ansible 剧本: - name: Set String set_fact: string: item loop: "{{some_var|filter()}}"
我无法在我的输出变量中搜索我用于 when 语句的指定字符串。下面的代码应该检查输出变量中的字符串“distribute-list”,但是在运行 playbook 时会出现错误。 fatal: [19
在 Ansible 中是否可以仅当处理程序出现在该播放中时才有条件地通知处理程序? 例如:我有一个多主机配置的剧本。有些主机使用 Apache 运行 PHP,有些使用 PHP-FPM。根据主机,修改
我是 ansible 的新手,正在学习 ansible 并致力于定义 ansible 脚本以在服务器上安装 confluent。在查看有关如何定义和运行 ansible 脚本的示例时,一些示例使用“a
是否可以列出Ansible角色中的任务? 即除了grepping - name以外,还有没有现成的方法可以做到这一点? 最佳答案 创建一个指定角色的简单剧本,并使用ansible-playbook选项
所以ansible-playbook有 --ask-pass和 --ask-sudo-pass .有没有办法让 ssh 先尝试没有密码,然后只有在无密码登录失败时才提示输入密码?同样,ansible
Ansible 提供了许多过滤器和条件。据我所知;应该可以实现一个 Ansible playbook 来执行一组任务,这些任务实现与图灵完备语言相同的结果。那么,图灵完备吗? 最佳答案 我觉得是这样的
我一直在寻找,但没有太多关于什么 Ansible 保险库密码文件应该是什么样的。 例如我想做: ANSIBLE_VAULT_PASSWORD_FILE=./pwdfile ansible-vault
我在运行完整的剧本时遇到了麻烦,因为后来的剧本所依赖的一些事实在早期的剧本中被修改了,但是 ansible 不会在运行中更新事实。 运行ansible somehost -m setup当整个剧本开始
我对Ansible很陌生 是否可以使用Ansible检查文件中是否存在字符串。 我要检查的是用户有权访问服务器。 这可以使用cat /etc/passwd | grep username在服务器上完成
我正在尝试使用 jinja2 通过 ansible 模板循环字典以创建多个数据源,但收到此错误 [{'msg': "AnsibleUndefinedVariable: One or more unde
我正在尝试将文件复制到/ etc。但是当我运行剧本时,我收到“msg:目标/ etc不可写”的消息。这是我的Playbook任务部分。非常感谢您的帮助。 任务: - name: copy rsyslo
我正面临这个恼人的错误:Ansible hosts are randomly unreachable #18188 . 有没有办法告诉 Ansible 如果 SSH 连接失败,再试一次?还是2倍? 根
我正在编写一个简单的任务来创建用户。作为此任务的一部分,我想从defaults / main.yml中读取密码。 默认值/ main.yml test_user:testuser test_group
当我在Ansible中使用lineinfile时,它不会写',"字符 lineinfile: 'dest=/home/xyz state=present line="CACHES="default""
我是一名优秀的程序员,十分优秀!