Search code examples
linuxansiblesudo

Ansible: sudo without password


I want to run ansible with user sa1 without sudo password:

First time OK:

[root@centos1 cp]# ansible cent2 -m shell -a "sudo yum -y install httpd"

cent2 | SUCCESS | rc=0 >>

Second time FAILED:

[root@centos1 cp]# ansible cent2 -s -m yum -a "name=httpd state=absent"

cent2 | FAILED! => {
    "changed": false,
    "failed": true,
    "module_stderr": "",
    "module_stdout": "sudo: a password is required\r\n",
    "msg": "MODULE FAILURE",
    "parsed": false
}

Please help!


Solution

  • It's not ansible it's your server's configuration. Make sure that sudo is allowed for the user ansible is using without password.

    1. To do that login to the server
    2. Open the sudoers file with sudo visudo
    3. Make sure you have a line something like this: centos ALL=(ALL) NOPASSWD:ALL
    4. Replace centos with the your user
    5. Save the file

    You can try from the server itself by running:

    sudo -u [yourusername] sudo echo "success"
    

    If this works it should work from ansible too.