我打算使用ansible来部署远程文件,因为远程位置只能用'root'写,而本地文件不能用'root'下载,我使用下面的playbook:
# in the main playbook
- hosts: master
user: ec2-user
sudo: yes
# in role definition
# download only in the ansible master node
- local_action: get_url url={{ hadoop_mirrors|random }}/hadoop-{{ hadoop_version }}/hadoop-{{ hadoop_version }}.tar.gz dest=/opt/hadoop-{{ hadoop_version }}.tar.gz force=no
sudo: False
register: result
until: result|success
retries: 5
delay: 2
when: hadoop_type_of_node == 'master'
然而,Ansible似乎无法阅读sudo: False
行。当我运行这个剧本时,我仍然遇到这个错误:
TASK [ansible-role-hadoop : get_url] **************************************************************************************************
FAILED - RETRYING: ansible-role-hadoop : get_url (5 retries left).
FAILED - RETRYING: ansible-role-hadoop : get_url (4 retries left).
FAILED - RETRYING: ansible-role-hadoop : get_url (3 retries left).
FAILED - RETRYING: ansible-role-hadoop : get_url (2 retries left).
FAILED - RETRYING: ansible-role-hadoop : get_url (1 retries left).
fatal: [54.201.26.110 -> localhost]: FAILED! => {"attempts": 5, "changed": false, "module_stderr": "sudo: a password is required\n", "module_stdout": "", "msg": "MODULE FAILURE", "rc": 1}
to retry, use: --limit @/home/peng/git/datapassport/clusterops/ansible/deploy/master.retry
为什么不读这行,我该怎么做才能修复它?
答案 0 :(得分:2)
使用become: false
,而不是很久以前已弃用的sudo: false
。
sudo
声明仍然保留了播放定义中的兼容性,但由于某些原因,自Ansible 2.4以来未在任务中维护。
- 没有检查任务中的声明(您可以将foo: bar
添加到任务中,它将被忽略)。这就是为什么你没有看到任何错误/警告的原因。
- 另一方面,您应该收到关于sudo
被弃用的警告。
答案 1 :(得分:1)
Privilege Escalation在Ansible中管理非常重要。 成为关键字是此功能的运营商。
4种常见用途:
所以, sudo:是,像这样使用become:
:
- hosts: master
user: ec2-user
become: false