commit | b832d4a0cc8ec359249a233dbb61f888116b7de0 | [log] [tgz] |
---|---|---|
author | Andrew Kutz <101085+akutz@users.noreply.github.com> | Sat Dec 07 22:52:54 2019 -0600 |
committer | GitHub <noreply@github.com> | Sat Dec 07 22:52:54 2019 -0600 |
tree | bf672843ba63fe063b028470be4b8c7dc28cbf05 | |
parent | cb9e8e4790acacb06b1f473565535f6c6f4a595c [diff] | |
parent | 8d58dfdc37adb95d2d9c63b46baa6a9e84e7551f [diff] |
Merge pull request #23 from yvespp/vmware-rpctool Use vmware-rpctool instead of vmtoolsd for performance reasons
This project provides a cloud-init datasource for pulling meta, user, and vendor data from VMware vSphere's GuestInfo interface.
There are multiple methods of installing the data source.
There is an RPM available for installing on RedHat/CentOS:
$ yum install https://github.com/vmware/cloud-init-vmware-guestinfo/releases/download/v1.1.0/cloud-init-vmware-guestinfo-1.1.0-1.el7.noarch.rpm
The VMware GuestInfo datasource can be installed on any Linux distribution where cloud-init is already present. To do so, simply execute the following:
$ curl -sSL https://raw.githubusercontent.com/vmware/cloud-init-vmware-guestinfo/master/install.sh | sh -
The data source is configured by setting guestinfo
properties on a VM's extraconfig
data or a customizable vApp's properties
data.
Property | Description |
---|---|
guestinfo.metadata | A JSON string containing the cloud-init metadata. |
guestinfo.metadata.encoding | The encoding type for guestinfo.metadata . |
guestinfo.userdata | A YAML document containing the cloud-init user data. |
guestinfo.userdata.encoding | The encoding type for guestinfo.userdata . |
guestinfo.vendordata | A YAML document containing the cloud-init vendor data. |
guestinfo.vendordata.encoding | The encoding type for guestinfo.vendordata . |
All guestinfo.*.encoding
property values may be set to base64
or gzip+base64
.
The following series of steps is a demonstration on how to configure a VM with cloud-init and the VMX GuestInfo datasource.
First, create the network configuration for the VM. Save the following YAML to a file named network.config.yaml
:
version: 1 config: - type: physical name: ens192 subnets: - type: static address: 192.168.1.200 gateway: 192.168.1.1 dns_nameservers: - 8.8.8.8 - 8.8.4.4 dns_search: - vmware.ci
See the section on configuring the network for more information on the network configuration schema.
Next, create a JSON file named metadata.json
:
{ "network": "NETWORK_CONFIG", "network.encoding": "gzip+base64", "local-hostname": "cloud-vm", "instance-id": "cloud-vm" }
Please note that in addition to the network
key in the metadata there is also a key named network.encoding
. This key informs the datasource how to decode the network
data. Valid values for network.encoding
include:
base64
gzip+base64
Finally, create the cloud-config file cloud-config.yaml
:
#cloud-config users: - default - name: akutz primary_group: akutz sudo: ALL=(ALL) NOPASSWD:ALL groups: sudo, wheel ssh_import_id: None lock_passwd: true ssh_authorized_keys: - ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDE0c5FczvcGSh/tG4iw+Fhfi/O5/EvUM/96js65tly4++YTXK1d9jcznPS5ruDlbIZ30oveCBd3kT8LLVFwzh6hepYTf0YmCTpF4eDunyqmpCXDvVscQYRXyasEm5olGmVe05RrCJSeSShAeptv4ueIn40kZKOghinGWLDSZG4+FFfgrmcMCpx5YSCtX2gvnEYZJr0czt4rxOZuuP7PkJKgC/mt2PcPjooeX00vAj81jjU2f3XKrjjz2u2+KIt9eba+vOQ6HiC8c2IzRkUAJ5i1atLy8RIbejo23+0P4N2jjk17QySFOVHwPBDTYb0/0M/4ideeU74EN/CgVsvO6JrLsPBR4dojkV5qNbMNxIVv5cUwIy2ThlLgqpNCeFIDLCWNZEFKlEuNeSQ2mPtIO7ETxEL2Cz5y/7AIuildzYMc6wi2bofRC8HmQ7rMXRWdwLKWsR0L7SKjHblIwarxOGqLnUI+k2E71YoP7SZSlxaKi17pqkr0OMCF+kKqvcvHAQuwGqyumTEWOlH6TCx1dSPrW+pVCZSHSJtSTfDW2uzL6y8k10MT06+pVunSrWo5LHAXcS91htHV1M1UrH/tZKSpjYtjMb5+RonfhaFRNzvj7cCE1f3Kp8UVqAdcGBTtReoE8eRUT63qIxjw03a7VwAyB2w+9cu1R9/vAo8SBeRqw== sakutz@gmail.com
Please note that this step requires that the VM be powered off. All of the commands below use the VMware CLI tool, govc
.
Go ahead and assign the path to the VM to the environment variable VM
:
$ export VM="/inventory/path/to/the/vm"
Next, power off the VM:
$ govc vm.power -off "${VM}"
Export the environment variables that contain the cloud-init metadata and cloud-config:
$ export CLOUD_CONFIG=$(gzip -c9 <cloud-config.yaml | base64) $ export METADATA=$(sed 's~NETWORK_CONFIG~'"$(gzip -c9 <network.config.yaml | \ base64)"'~' <metadata.json | gzip -9 | base64)
Assign the metadata and cloud-config to the VM's extra configuration dictionary, guestinfo
:
$ govc vm.change -vm "${VM}" -e guestinfo.metadata="${METADATA}" $ govc vm.change -vm "${VM}" -e guestinfo.metadata.encoding=gzip+base64 $ govc vm.change -vm "${VM}" -e guestinfo.userdata="${CLOUD_CONFIG}" $ govc vm.change -vm "${VM}" -e guestinfo.userdata.encoding=gzip+base64
Please note the above commands include specifying the encoding for the properties. This is important as it informs the datasource how to decode the data for cloud-init. Valid values for metadata.encoding
and userdata.encoding
include:
base64
gzip+base64
Power the VM back on.
$ govc vm.power -vm "${VM}" -on
If all went according to plan, the CentOS box is:
centos-cloud
This section reviews common configurations:
The hostname is set by way of the metadata key local-hostname
.
The instance ID may be set by way of the metadata key instance-id
. However, if this value is absent then then the instance ID is read from the file /sys/class/dmi/id/product_uuid
.
The public SSH keys may be set by way of the metadata key public-keys-data
. Each newline-terminated string will be interpreted as a separate SSH public key, which will be placed in distro's default user's ~/.ssh/authorized_keys
. If the value is empty or absent, then nothing will be written to ~/.ssh/authorized_keys
.
The network is configured by setting the metadata key network
with a value consistent with Network Config Versions 1 or 2, depending on the Linux distro's version of cloud-init.
For example, CentOS 7's official cloud-init package is version 0.7.9 and does not support Network Config Version 2. However, this datasource still supports supplying Network Config Version 2 data as long as the Linux distro's cloud-init package is new enough to parse the data.
The metadata key network.encoding
may be used to indicate the format of the metadata key "network". Valid encodings are base64
and gzip+base64
.
Building the RPM locally is handled via Docker. Simple execute the following command:
$ make rpm
The resulting RPMs are located in rpmbuild/$OS/RPMS/noarch/
. The list of supported $OS
platforms are:
To learn more about how to use cloud-init with CentOS, please see the cloud-init documentation for more examples and reference information for the cloud-config files.