我必须检查/etc/中是否存在一个文件。如果文件存在,那么我必须跳过该任务。 这是我正在使用的代码:
- name: checking the file exists
command: touch file.txt
when: $(! -s /etc/file.txt)
我必须检查/etc/中是否存在一个文件。如果文件存在,那么我必须跳过该任务。 这是我正在使用的代码:
- name: checking the file exists
command: touch file.txt
when: $(! -s /etc/file.txt)
当前回答
您可以使用shell命令检查文件是否存在
- set_fact:
file: "/tmp/test_file"
- name: check file exists
shell: "ls {{ file }}"
register: file_path
ignore_errors: true
- name: create file if don't exist
shell: "touch {{ file }}"
when: file_path.rc != 0
其他回答
下面是ansible play,我用来删除文件,如果文件存在于操作系统端。
- name: find out /etc/init.d/splunk file exists or not'
stat:
path: /etc/init.d/splunk
register: splunkresult
tags:
- always
- name: 'Remove splunk from init.d file if splunk already running'
file:
path: /etc/init.d/splunk
state: absent
when: splunkresult.stat.exists == true
ignore_errors: yes
tags:
- always
我使用的发挥条件如下
when: splunkresult.stat.exists == true --> Remove the file
你可以根据你的要求给出真/假
when: splunkresult.stat.exists == false
when: splunkresult.stat.exists == true
通常情况下,您可以使用stat模块来完成此操作。但是命令模块有创建选项,这使得这非常简单:
- name: touch file
command: touch /etc/file.txt
args:
creates: /etc/file.txt
我猜你的触摸命令只是一个例子?最好的做法是不检查任何东西,让ansible用正确的模块完成它的工作。所以如果你想确保文件存在,你可以使用file模块:
- name: make sure file exists
file:
path: /etc/file.txt
state: touch
关于相对路径的注释,以补充其他答案。
当把基础设施作为代码使用时,我通常使用接受相对路径的角色和任务,特别是对于在这些角色中定义的文件。
像playbook_dir和role_path这样的特殊变量对于创建测试存在性所需的绝对路径非常有用。
发现调用stat很慢,并且收集了很多文件存在检查不需要的信息。 在花了一些时间寻找解决方案后,我发现了以下解决方案,它的工作速度更快:
- raw: test -e /path/to/something && echo -n true || echo -n false
register: file_exists
- debug: msg="Path exists"
when: file_exists.stdout == "true"
stat模块将执行此操作,并为文件获取许多其他信息。从示例文档中:
- stat: path=/path/to/something
register: p
- debug: msg="Path exists and is a directory"
when: p.stat.isdir is defined and p.stat.isdir