| 12
 3
 4
 5
 
 | 作者:李晓辉
 微信联系:Lxh_Chat
 
 联系邮箱: 939958092@qq.com
 
 | 
你可以为 ansible-navigator 创建一个配置文件(或设置文件),来覆盖默认的配置选项。如果你希望使用与默认环境不同的自动化执行环境,并且不想每次运行 ansible-navigator 命令时都手动输入正确的 --eei 选项,那这个配置文件就非常有用。设置文件可以使用 JSON 或 YAML 格式,方便你灵活地定制配置。
不同设置⽂件的优先级
以下是配置文件的优先级,从高到低:
- 如果设置了 ANSIBLE_NAVIGATOR_CONFIG环境变量,将使用该变量指定位置的配置文件。
- 当前 Ansible 项目目录中的 ansible-navigator.yml文件。
- 用户主目录下的 ~/.ansible-navigator.yml文件(注意文件名前有一个点)。
其中,推荐使用项目目录和家目录的配置文件,原因如下:
- 项目目录中的配置文件可以随着 Ansible playbook 等项目文件一起纳入版本控制,方便管理和共享。
- 如果无法使用项目目录,家目录中的配置文件是一个不错的备选方案,这样你就可以在任何地方运行 ansible-navigator命令,而无需担心配置问题。
⽣成设置⽂件
你可以使用 ansible-navigator settings 命令来生成设置文件:
- 使用 - --sample选项运行该命令,命令会以 YAML 格式输出示例的- ansible-navigator配置文件,文件中会包含各种注释。
 
- 使用 - --effective选项运行该命令,命令会输出与- ansible-navigator当前有效配置匹配的配置文件,这个文件将不包含注释。
 
注意
如果你把 ansible-navigator settings 命令的输出重定向到当前目录下的 ansible-navigator.yml 文件,ansible-navigator 命令会尝试使用这个配置文件,最后可能会失败。为了避免这种情况,最好将命令的输出重定向到其他目录下的文件,比如 /tmp/ansible-navigator.yml,或者当前目录下一个不同名称的文件,例如 sample.yml。
生成样例文件
注意
如果在导出样例文件时,指定了-eei参数使用特定镜像时,你生成的ansible-navigator.yml ⽂件前面可能会有一段镜像下载的内容,这个需要删除,不然此文件将无效
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 
 | [root@workstation ~]# ansible-navigator settings --sample --eei hub.lab.example.com/ee-supported-rhel8 > ansible-navigator.yaml-1Trying to pull hub.lab.example.com/ee-supported-rhel8:latest...
 Getting image source signatures
 Copying blob afea8ac1fb6f skipped: already exists
 Copying blob 85461b6812d9 skipped: already exists
 Copying blob 1e8637dd83cb skipped: already exists
 Copying blob ac278321f2bd skipped: already exists
 Copying blob 431069e2d54d skipped: already exists
 Copying config b1eaaee1b7 done
 Writing manifest to image destination
 Storing signatures
 
 [root@workstation ~]# head -n 20 ansible-navigator.yaml-1
 b1eaaee1b70ed29a40dc3848a6a75119bee65e11c82f54bd7c600f226284e136
 --------------------------------------------------------------------------------
 Execution environment image and pull policy overview
 --------------------------------------------------------------------------------
 Execution environment image name:     hub.lab.example.com/ee-supported-rhel8:latest
 Execution environment image tag:      latest
 Execution environment pull arguments: None
 Execution environment pull policy:    tag
 Execution environment pull needed:    True
 --------------------------------------------------------------------------------
 Updating the execution environment
 --------------------------------------------------------------------------------
 Running the command: podman pull hub.lab.example.com/ee-supported-rhel8:latest
 ---
 ansible-navigator:
 #   ansible:
 #     config:
 #       # Help options for ansible-config command in stdout mode
 #       help: False
 #       # Specify the path to the ansible configuration file
 
 
 | 
获取当前正在生效的配置文件
如果我们没有配置文件,也有一些默认值,我们可以用默认值来生成配置文件,将其调整为我们预期的参数即可
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 
 | [root@workstation ~]# ansible-navigator settings --effective --eei hub.lab.example.com/ee-supported-rhel8 -m stdout --pp never > ansible-navigator.yaml-2
 [root@workstation ~]# head -n 20 ansible-navigator.yaml-2
 ---
 ansible-navigator:
 ansible:
 config:
 help: false
 doc:
 help: false
 plugin:
 type: module
 inventory:
 help: false
 playbook:
 help: false
 ansible-builder:
 help: false
 workdir: /root
 app: settings
 collection-doc-cache-path: /root/.cache/ansible-navigator/collection_doc_cache.db
 color:
 enable: true
 
 | 
常用参数分享
我们注意到刚才的命令很长,--eei --pp -m,这些其实都包含在配置文件中,只要我们在配置文件中写好,执行命令就很简单了
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 
 | [root@workstation ~]# cat ansible-navigator.yaml-2---
 ansible-navigator:
 ansible:
 config:
 help: false
 doc:
 help: false
 plugin:
 type: module
 inventory:
 help: false
 playbook:
 help: false
 ansible-builder:
 help: false
 workdir: /root
 app: settings
 collection-doc-cache-path: /root/.cache/ansible-navigator/collection_doc_cache.db
 color:
 enable: true
 osc4: true
 editor:
 command: vi +{line_number} {filename}
 console: true
 exec:
 command: /bin/bash
 shell: true
 execution-environment:
 container-engine: podman
 enabled: true
 image: hub.lab.example.com/ee-supported-rhel8:latest
 pull:
 policy: never
 images:
 details:
 - everything
 logging:
 append: true
 file: /root/ansible-navigator.log
 level: warning
 mode: stdout
 playbook-artifact:
 enable: true
 save-as: '{playbook_dir}/{playbook_name}-artifact-{time_stamp}.json'
 settings:
 effective: true
 sample: false
 schema: json
 sources: false
 time-zone: UTC
 
 | 
ansible
execution-environment
mode
- 指定 ansible-navigator的运行模式为stdout,即标准输出模式。
playbook-artifact
editor
通过以上内容,我们大概了解到了ansible-navigator.yml不同位置的优先级情况以及如何来生成ansible-navigator.yml,也了解到ansible-navigator.yml文件中常见参数的含义。
版权声明: 本博客中的内容未经允许不得转载和引用,转载和引用需获得作者同意, 作者微信: Lxh_Chat