Ansible의 모든 호스트에 대해 기본 ssh 사용자를 설정하는 방법은 무엇입니까? – include: tasks/main.yml 방금 놀이를 시작하면 ansible-playbook

사용 가능한 버전 2.1

인벤토리 파일이 있습니다 hosts

[nodes]
host1
host2
...

간단한 플레이 북 site.yml

---
- hosts: all
  tasks:
    - include: tasks/main.yml

방금 놀이를 시작하면

ansible-playbook -i hosts site.yml -vvvv

모든 호스트에 대해이 오류가 발생합니다.

ESTABLISH SSH CONNECTION FOR USER: None
fatal: [host1]: UNREACHABLE! => {"changed": false, "msg": "Failed to connect to the host via ssh.", "unreachable": true}
...

그러나 Ansible Inventory doc을 읽고 파일에 추가 ansible_user했습니다.hosts

[nodes]
host1    ansible_user=root
host2    ansible_user=root
...

이것은 SSH CONNECTION UNREACHABLE오류를 해결합니다 . 그러나 ansible_user=root모든 호스트 옆에 추가해야 합니까? 아니면 더 간단한 방법이 있습니까?



답변

예제 / 기본 ansible.cfg파일을 확인하면 다음에서 찾을 수 있습니다 [defaults].

# default user to use for playbooks if user is not specified
# (/usr/bin/ansible will use current user as default)
#remote_user = root

주석 remote_user을 해제하고 로그인하려는 사용자를 설정하십시오.

Ansible은 어디에서 얻 ansible.cfg습니까? 같은 파일이 설명합니다 :

# nearly all parameters can be overridden in ansible-playbook
# or with command line flags. ansible will read ANSIBLE_CONFIG,
# ansible.cfg in the current working directory, .ansible.cfg in
# the home directory or /etc/ansible/ansible.cfg, whichever it
# finds first


답변

다른 방법은 --user원격 ssh 사용자를 정의하는 데 사용 하는 것입니다. ansible-playbook --help자세히 읽으려면 입력하십시오 . 이것은 내 일반적인 명령입니다.

ansible-playbook -i hosts site.yml --user <user> --ask-pass -vvvv

--ask-pass 암호를 입력하라는 메시지가 표시됩니다 --user


답변

ansible.cfgu 를 수정하는 것 외에도 u는 ‘all’그룹 또는 다른 그룹에 대한 변수를 정의 할 수도 있습니다.

https://docs.ansible.com/ansible/latest/user_guide/intro_inventory.html#group-variables

[all:vars]
ansible_user = root
ansible_port = 22


답변