Ошибка: ansible требует json-модуль, ни один не найден
Ошибка при выполнении доступного модуля ping
bash ~ ansible webservers -i inventory -m ping -k -u root -vvvv
SSH password:
<~> ESTABLISH CONNECTION FOR USER: root on PORT 22 TO ~
<my-lnx> ESTABLISH CONNECTION FOR USER: root on PORT 22 TO my-lnx
~ | FAILED => FAILED: [Errno 8] nodename nor servname provided, or not known
<my-lnx> REMOTE_MODULE ping
<my-lnx> EXEC /bin/sh -c 'mkdir -p $HOME/.ansible/tmp/ansible-tmp-1423302966.66-77716810353582 && echo $HOME/.ansible/tmp/ansible-tmp-1423302966.66-77716810353582'
<my-lnx> PUT /var/folders/8n/fftvnbbs51q834y16vfvb1q00000gn/T/tmpP6zwZj TO /root/.ansible/tmp/ansible-tmp-1423302966.66-77716810353582/ping
<my-lnx> EXEC /bin/sh -c 'LANG=en_US.UTF-8 LC_CTYPE=en_US.UTF-8 /usr/bin/python /root/.ansible/tmp/ansible-tmp-1423302966.66-77716810353582/ping; rm -rf /root/.ansible/tmp/ansible-tmp-1423302966.66-77716810353582/ >/dev/null 2>&1'
my-lnx | FAILED >> {
"failed": true,
"msg": "Error: ansible requires a json module, none found!",
"parsed": false
}
Это мой файл инвентаря
bash ~ cat inventory
[webservers]
my-lnx ansible_ssh_host=my-lnx ansible_ssh_port=22
Я установил модуль simplejosn также как на клиенте, так и на удаленной машине
bash ~ pip list | grep json
simple-json (1.1)
simplejson (3.6.5)
Ответы
Ответ 1
Мне кажется, вам нужно установить модуль python-simplejson
.
Попробуйте выполнить эту команду сначала, а затем нужные команды:
ansible webservers -i inventory -m raw -a "sudo yum install -y python-simplejson" -k -u root -vvvv
Я предполагаю, что его старая система Red Hat/CentOS.
Ответ 2
Если вы не хотите или не можете установить модуль python-simplejson на удаленных серверах, вы можете просто запросить исходный вывод:
> ansible webservers -i inventory -m ping -m raw
Или, как и я, добавил его в свой файл ~/.bash_profile
alias ansible="ansible -m raw"
# And then simply running:
> ansible webservers -i inventory -m ping
Ответ 3
in centos 5. * версия отсутствует python-simple json, доступная на репо для загрузки и установки. вы можете просто использовать нижеуказанный метод.
убедитесь, что для доступа к источнику и получателю доступ к паролю меньше, а от источника к пункту назначения - пароль меньше.
использовать ssh-keygen -t rsa для генерации ключа
ssh-copy-id user @host_ip
"---
- хосты: (незаменимый хост) стать: да remote_user: root gather_facts: false задания: - имя: копирование копий temps shell: ssh (источник) && & rsync -parv/root/temp/* root @(Destination):/root/temp/"