![]() With python2 not being supported anymore, let's drop six. Change-Id: I22f3d28e22ad209806b78ad78f46671a74179157 |
2 years ago | |
---|---|---|
os_collect_config | 2 years ago | |
releasenotes/notes | 3 years ago | |
zuul.d | 3 years ago | |
.coveragerc | 8 years ago | |
.gitignore | 5 years ago | |
.gitreview | 4 years ago | |
.stestr.conf | 5 years ago | |
LICENSE | 10 years ago | |
MANIFEST.in | 10 years ago | |
README.rst | 4 years ago | |
os-collect-config-and-friends.odg | 9 years ago | |
os-collect-config-and-friends.svg | 9 years ago | |
requirements.txt | 2 years ago | |
setup.cfg | 2 years ago | |
setup.py | 6 years ago | |
test-requirements.txt | 2 years ago | |
tox.ini | 2 years ago |
README.rst
Team and repository tags
os-collect-config
Collect configuration from cloud metadata sources
What does it do?
It collects data from defined configuration sources and runs a defined hook whenever the metadata has been changed.
Usage
You must define what sources to collect configuration data from in /etc/os-collect-config.conf.
The format of this file is:
[DEFAULT]
command=os-refresh-config
[cfn]
metadata_url=http://192.0.2.99:8000/v1/
access_key_id = ABCDEFGHIJLMNOP01234567890
secret_access_key = 01234567890ABCDEFGHIJKLMNOP
path = MyResource
stack_name = my.stack
These sources will be polled and whenever any of them is changed, default.command will be run. A file will be written to the cache dir, os_config_files.json, which will be a json list of the file paths to the current copy of each metadata source. This list will also be set as a colon separated list in the environment variable OS_CONFIG_FILES for the command that is run. So in the example above, os-refresh-config would be executed with something like this in OS_CONFIG_FILES:
/var/lib/os-collect-config/ec2.json:/var/lib/os-collect-config/cfn.json
The previous version of the metadata from a source (if available) is present at $FILENAME.last.
When run without a command, the metadata sources are printed as a json document.
Quick Start
Install:
sudo pip install -U git+https://opendev.org/openstack/os-collect-config.git
Run it on an OpenStack instance with access to ec2 metadata:
os-collect-config
That should print out a json representation of the entire ec2 metadata tree.
Recommend using LibreOffice draw to edit os-collect-config-and-friends.odg and regenerate the svg file. Alternatively edit the svg directly, but remove the .odg file if that is done.↩︎