Ash*_*har 2 installation runtime-error ansible jmespath json-query
有了这本剧本
---
- name: ReadJsonfile
hosts: localhost
tasks:
- name: Display the JSON file content
shell: "cat config.json"
register: result
- name: save the Json data to a Variable as a Fact
set_fact:
jsondata: "{{ result.stdout | from_json }}"
- name: setDomainName
set_fact:
domain_name: "{{ jsondata | json_query(jmesquery) }}"
vars:
jmesquery: '[].domain[].name'
Run Code Online (Sandbox Code Playgroud)
我的 Linux 服务器上有两个用户:user1和user2
python3.8、pip、ansible-core、ansible-base&jmespath已安装。
我登录user1 ,上面的剧本运行良好
ansible-playbook test.yml
但是,当我登录并user2运行相同的命令时,我收到以下错误
任务 [setDomainName] ************************************************** ********************************************** 2022 年 3 月 21 日星期一 01: 16:40 -0500 (0:00:00.140) 0:00:04.221 ********** 致命:[localhost]:失败!=> {“msg”:“模板化字符串时出现模板错误:没有名为“json_query”的过滤器..字符串:{{ jsondata | json_query(jmesquery) }}”}
注意:user1与剧本一起运行时效果很好。该错误是在仅运行时出现的user2。
我的设置方式有问题吗user2?
以下是详细信息user2
[user2@myhost Migrator]$ ansible --version
ansible [core 2.12.3]
config file = /etc/ansible/ansible.cfg
configured module search path = ['/home/user2/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules']
ansible python module location = /home/user2/.local/lib/python3.8/site-packages/ansible
ansible collection location = /home/user2/.ansible/collections:/usr/share/ansible/collections
executable location = /bin/ansible
python version = 3.8.12 (default, Mar 21 2022, 00:59:19) [GCC 4.8.5 20150623 (Red Hat 4.8.5-44)]
jinja version = 3.0.3
libyaml = True
[user2@myhost Migrator]$ ansible-playbook --version
ansible-playbook [core 2.12.3]
config file = /etc/ansible/ansible.cfg
configured module search path = ['/home/user2/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules']
ansible python module location = /home/user2/.local/lib/python3.8/site-packages/ansible
ansible collection location = /home/user2/.ansible/collections:/usr/share/ansible/collections
executable location = /bin/ansible-playbook
python version = 3.8.12 (default, Mar 21 2022, 00:59:19) [GCC 4.8.5 20150623 (Red Hat 4.8.5-44)]
jinja version = 3.0.3
libyaml = True
[user2@myhost Migrator]$ pip --version
bash: pip: command not found
[user2@myhost Migrator]$ pip3 --version
WARNING: pip is being invoked by an old script wrapper. This will fail in a future version of pip.
Please see https://github.com/pypa/pip/issues/5599 for advice on fixing the underlying issue.
To avoid this problem you can invoke Python with '-m pip' instead of running pip directly.
pip 21.3.1 from /home/user2/.local/lib/python3.6/site-packages/pip (python 3.6)
[user2@myhost Migrator]$ pip3 install jmespath
WARNING: pip is being invoked by an old script wrapper. This will fail in a future version of pip.
Please see https://github.com/pypa/pip/issues/5599 for advice on fixing the underlying issue.
To avoid this problem you can invoke Python with '-m pip' instead of running pip directly.
Defaulting to user installation because normal site-packages is not writeable
Requirement already satisfied: jmespath in /usr/local/lib/python3.6/site-packages (0.10.0)
[user2@myhost Migrator]$
[user2@myhost Migrator]$ python3.8 --version
Python 3.8.12
Run Code Online (Sandbox Code Playgroud)
JmesPath 安装如下:
$ sudo pip3.8 install jmespath
Collecting jmespath
Downloading jmespath-1.0.0-py3-none-any.whl (23 kB)
Installing collected packages: jmespath
Successfully installed jmespath-1.0.0
WARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv
Run Code Online (Sandbox Code Playgroud)
您能提出解决该问题的建议吗?
因为您确实使用 pip 包ansible-core&安装了 Ansible ansible-base,所以您没有community.general该过滤器所属的集合。
您有多种选择:
ansible-galaxy collection install community.general
Run Code Online (Sandbox Code Playgroud)
pip uninstall ansible-core ansible-base
pip install ansible
Run Code Online (Sandbox Code Playgroud)
-p
ansible-galaxy collection install community.general \
-p /usr/share/ansible/collections
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
13230 次 |
| 最近记录: |