Ich versuche, eine Datei von einem Webserver aus einem Ansible-Playbook wget. HierAnsible und Wget
ist der ansible Schnipsel:
---
- hosts: all
sudo: true
tasks:
- name: Prepare Install folder
sudo: true
action: shell sudo mkdir -p /tmp/my_install/mysql/ && cd /tmp/my_install/mysql/
- name: Download MySql
sudo: true
action: shell sudo wget http://{{ repo_host }}/MySQL-5.6.15-1.el6.x86_64.rpm-bundle.tar
Aufrufe es über:
ansible-playbook my_3rparties.yml -l vsrv644 --extra-vars "repo_host=vsrv656" -K -f 10
Es schlägt mit dem folgenden:
Cannot write to `MySQL-5.6.15-1.el6.x86_64.rpm-bundle.tar' (Permission denied).
FATAL: all hosts have already failed -- aborting
PLAY RECAP ********************************************************************
to retry, use: --limit @/usr2/ihazan/vufroria_3rparties.retry
vsrv644 : ok=2 changed=1 unreachable=0 failed=1
Beim Versuch, den Befehl zu tun, die über fehlschlagen reguläre remote ssh zu imitieren, was ansible würde tun, funktioniert es nicht wie folgt:
-bash-4.1$ ssh [email protected] 'cd /tmp/my_install/mysql && sudo wget http://vsrv656/MySQL-5.6.15-1.el6.x86_64.rpm-bundle.tar'
Enter passphrase for key '/usr2/ihazan/.ssh/id_rsa':
sudo: sorry, you must have a tty to run sudo
Aber ich kann es mit -t lösen wie folgt:
-bash-4.1$ ssh -t [email protected] 'cd /tmp/my_install/mysql && sudo wget http://vsrv656/MySQL-5.6.15-1.el6.x86_64.rpm-bundle.tar'
Dann funktioniert es.
Gibt es eine Möglichkeit, die Option -t (pseudo tty) auf ansible zu setzen?
P.S: Ich könnte es lösen, indem ich die sudoers-Datei bearbeite, wie andere vorschlagen, aber das ist ein manueller Schritt, den ich versuche zu vermeiden.
Thx, das war hilfreich !!! –