私の要件は、AzureからVNET IDを収集し、そのIDをロールベースのアクセスを割り当てる範囲として使用することです.これには、azure_rm_virtualnetwork_infoとazure_rm_role割り当てを使用します。
azure_rm_virtualnetwork_infoを使用してその事実を変数に登録しようとすると、データ型 "dict"として保存されます。実はこんな感じです。
スコープとして使用されるVNET IDに興味があります。
ok: [localhost] => changed=false
invocation:
module_args:
ad_user: null
adfs_authority_url: null
api_profile: latest
auth_source: null
cert_validation_mode: null
client_id: null
cloud_environment: AzureCloud
name: VNT-NAME
password: null
profile: NPE
resource_group: ARG
secret: null
subscription_id: null
tags: null
tenant: null
virtualnetworks:
- address_prefixes:
- 111.41.240.0/22
dns_servers:
- 11.4.0.36
- 11.4.0.37
- 174.31.43.92
- 174.23.43.92
id: /subscriptions/SUB-ID/resourceGroups/ARG/providers/Microsoft.Network/virtualNetworks/VNT-NAME
location: australiaeast
name: VNT-NAME
provisioning_state: Succeeded
subnets:
- address_prefix: 10.4.240.0/24
id: /subscriptions/SUB-ID/resourceGroups/ARG/providers/Microsoft.Network/virtualNetworks/VNT-NAME/subnets/SUB-001
name: SUB-001
network_security_group: null
provisioning_state: Succeeded
route_table: null
service_endpoints:
- locations:
- '*'
service: Microsoft.KeyVault
- locations:
- australiaeast
- australiasoutheast
service: Microsoft.Storage
- address_prefix: 10.4.241.0/25
id: /subscriptions/SUB-ID/resourceGroups/ARG/providers/Microsoft.Network/virtualNetworks/VNT-NAME/subnets/SUB-001
name: BGL-NPE-SND-SYD-SUB-APG-INT-Cluster01
network_security_group: /subscriptions/SUB-ID/resourceGroups/ARG/providers/Microsoft.Network/virtualNetworks/VNT-NAME/subnets/SUB-001
provisioning_state: Succeeded
route_table: null
tags:
Environment: General-Non-Production
Owner: BGL IT
これが私のコードの外観です
- name: Get facts for one virtual network
azure_rm_virtualnetwork_info:
resource_group: "{{ npe_vnet_resource_group }}"
name: "{{ snd_syd_vnet }}"
profile: "{{ profilename }}"
register: snd_mel_vnet_reg
- debug:
var: snd_mel_vnet_reg.virtualnetworks.id
しかし、以下のようにエラーが発生します。
TASK [debug] *****************************************************************************************************************************************************************************************************************************
task path: /home/devans/AZ-vnet-role-assignment.yml:39
ok: [localhost] =>
snd_mel_vnet_reg.virtualnetworks.id: 'VARIABLE IS NOT DEFINED!: ''list object'' has no attribute ''id'''
助けてくれてありがとう。
答え1
私も同じ問題があります。私は新しい事実を作りますjson_query
。
状況に応じて、以下を追加する必要があります。
- set_fact:
myvnetid: "{{ snd_mel_vnet_reg| json_query('virtualnetworks[0].id') }}"
デバッグを使用して、出力が正しいことを確認します。
- debug: var=myvnetid