community.general.lxd – Returns Ansible inventory from lxd host

Note

This plugin is part of the community.general collection (version 3.8.1).

You might already have this collection installed if you are using the ansible package. It is not included in ansible-core. To check whether it is installed, run ansible-galaxy collection list.

To install it, use: ansible-galaxy collection install community.general.

To use it in a playbook, specify: community.general.lxd.

New in version 3.0.0: of community.general

Synopsis

  • Get inventory from the lxd.
  • Uses a YAML configuration file that ends with ‘lxd.(yml|yaml)’.

Parameters

Parameter Choices/Defaults Configuration Comments
client_cert
path
Default:
"$HOME/.config/lxc/client.crt"
The client certificate file path.

aliases: cert_file
client_key
path
Default:
"$HOME/.config/lxc/client.key"
The client certificate key file path.

aliases: key_file
groupby
dictionary
Create groups by the following keywords location, pattern, network_range, os, release, profile, vlanid.
See example for syntax.
plugin
string / required
    Choices:
  • community.general.lxd
Token that ensures this is a source file for the 'lxd' plugin.
prefered_container_network_family
string
    Choices:
  • inet
  • inet6
If a container has multiple network interfaces, which one is the prefered by family.
Specify inet for IPv4 and inet6 for IPv6.
prefered_container_network_interface
string
Default:
"eth"
If a container has multiple network interfaces, select which one is the prefered as pattern.
Combined with the first number that can be found e.g. 'eth' + 0.
state
string
    Choices:
  • STOPPED
  • STARTING
  • RUNNING
  • none
Filter the container according to the current status.
trust_password
string
The client trusted password.
You need to set this password on the lxd server before running this module using the following command lxc config set core.trust_password <some random password> See https://www.stgraber.org/2016/04/18/lxd-api-direct-interaction/.
If trust_password is set, this module send a request for authentication before sending any requests.
url
string
Default:
"unix:/var/snap/lxd/common/lxd/unix.socket"
The unix domain socket path or the https URL for the lxd server.
Sockets in filesystem have to start with unix:.
Mostly unix:/var/lib/lxd/unix.socket or unix:/var/snap/lxd/common/lxd/unix.socket.

Examples

# simple lxd.yml
plugin: community.general.lxd
url: unix:/var/snap/lxd/common/lxd/unix.socket

# simple lxd.yml including filter
plugin: community.general.lxd
url: unix:/var/snap/lxd/common/lxd/unix.socket
state: RUNNING

# grouping lxd.yml
groupby:
  testpattern:
    type: pattern
    attribute: test
  vlan666:
    type: vlanid
    attribute: 666
  locationBerlin:
    type: location
    attribute: Berlin
  osUbuntu:
    type: os
    attribute: ubuntu
  releaseFocal:
    type: release
    attribute: focal
  releaseBionic:
    type: release
    attribute: bionic
  profileDefault:
    type: profile
    attribute: default
  profileX11:
    type: profile
    attribute: x11
  netRangeIPv4:
    type: network_range
    attribute: 10.98.143.0/24
  netRangeIPv6:
    type: network_range
    attribute: fd42:bd00:7b11:2167:216:3eff::/24

Authors

  • Frank Dornheim (@conloos)

© 2012–2018 Michael DeHaan
© 2018–2021 Red Hat, Inc.
Licensed under the GNU General Public License version 3.
https://docs.ansible.com/ansible/latest/collections/community/general/lxd_inventory.html