Ansible Tower: sudo task on localhost job failed

1,481 views
Skip to first unread message

Do Hoang Khiem

unread,
Jul 29, 2015, 12:18:43 AM7/29/15
to Ansible Project
I've deployed an instance of Ansible Tower (using official Ansible EC2 AMI) on one of our server. There're some of our playbooks that always run locally (so, hosts = localhost, connection = local). Normally those playbooks run fine when run with ansible-playbook from command line but I always got this error when run the same playbook from Ansible Tower job

failed: [localhost] => (item=git,ruby,npm,nodejs-legacy) => {"failed": true, "item": "git,ruby,npm,nodejs-legacy", "parsed": false} sudo: effective uid is not 0, is /usr/bin/sudo on a file system with the 'nosuid' option set or an NFS file system without root privileges?

the task is a simple apt

- name: "ensure required packages: git, ruby, npm and nodejs-legacy are installed"
  apt: pkg={{item}} state=installed force=yes
  with_items:
    - git
    - ruby
    - npm
    - nodejs-legacy
  sudo: yes

Another thing I don't know is whether run playbook from Ansible Tower with connection=local like with ansible-playbook? As with ansible-playbook when running on localhost and connection=local I don't need credentials while with Ansible Tower currently I have to provide credentials (SSH key) for localhost access. 

Thanks  in advance for any comments!

Do Hoang Khiem

unread,
Jul 29, 2015, 2:01:47 AM7/29/15
to Ansible Project, dohoan...@gmail.com
Updated on this:

This problem occurred if I set connection: local in playbook, I often use it when running local playbook from command line, if remove that line the playbook runs successfully from Ansible Tower.

So question: Doesn't Ansible Tower run playbook with 'local' connection? As in the case run local playbook from Ansible Tower I still need to provide credentials.

Bill Nottingham

unread,
Jul 29, 2015, 9:43:49 AM7/29/15
to ansible...@googlegroups.com, dohoan...@gmail.com
Do Hoang Khiem (dohoan...@gmail.com) said:
> This problem occurred if I set connection: local in playbook, I often use
> it when running local playbook from command line, if remove that line the
> playbook runs successfully from Ansible Tower.
>
> So question: Doesn't Ansible Tower run playbook with 'local' connection? As
> in the case run local playbook from Ansible Tower I still need to provide
> credentials.

It has to do with Tower's multi-tenancy support. Hit up sup...@ansible.com
(ansible-project is not a Tower support list) and they can help you with it.

Bill
Reply all
Reply to author
Forward
0 new messages