diff options
author | Scott Moser <smoser@ubuntu.com> | 2010-01-26 22:53:00 -0500 |
---|---|---|
committer | Scott Moser <smoser@ubuntu.com> | 2010-01-26 22:53:00 -0500 |
commit | eb74cd6f36a2f4d2ebdee04d6b388834b1bc72d4 (patch) | |
tree | 89d6cdf38758b68639bf5f8d8fbcb220f2ce1f71 | |
parent | 4f389802609dd1a764bd93f2babda7e9eef7f1ba (diff) | |
download | vyos-cloud-init-eb74cd6f36a2f4d2ebdee04d6b388834b1bc72d4.tar.gz vyos-cloud-init-eb74cd6f36a2f4d2ebdee04d6b388834b1bc72d4.zip |
add doc/userdata.txt, move examples to doc/.
-rw-r--r-- | doc/examples/cloud-config-TODO.txt (renamed from examples/cloud-config-TODO.txt) | 0 | ||||
-rw-r--r-- | doc/examples/cloud-config.txt (renamed from examples/cloud-config.txt) | 0 | ||||
-rw-r--r-- | doc/examples/include.txt (renamed from examples/include.txt) | 0 | ||||
-rw-r--r-- | doc/examples/plain-ignored.txt (renamed from examples/plain-ignored.txt) | 0 | ||||
-rw-r--r-- | doc/examples/upstart-cloud-config.txt (renamed from examples/upstart-cloud-config.txt) | 0 | ||||
-rw-r--r-- | doc/examples/upstart-rclocal.txt (renamed from examples/upstart-rclocal.txt) | 0 | ||||
-rw-r--r-- | doc/examples/user-script.txt (renamed from examples/user-script.txt) | 0 | ||||
-rw-r--r-- | doc/userdata.txt | 57 | ||||
-rwxr-xr-x | tools/write-mime-multipart | 2 |
9 files changed, 58 insertions, 1 deletions
diff --git a/examples/cloud-config-TODO.txt b/doc/examples/cloud-config-TODO.txt index 20db618f..20db618f 100644 --- a/examples/cloud-config-TODO.txt +++ b/doc/examples/cloud-config-TODO.txt diff --git a/examples/cloud-config.txt b/doc/examples/cloud-config.txt index b808f99a..b808f99a 100644 --- a/examples/cloud-config.txt +++ b/doc/examples/cloud-config.txt diff --git a/examples/include.txt b/doc/examples/include.txt index 5bdc7991..5bdc7991 100644 --- a/examples/include.txt +++ b/doc/examples/include.txt diff --git a/examples/plain-ignored.txt b/doc/examples/plain-ignored.txt index fb2b59dc..fb2b59dc 100644 --- a/examples/plain-ignored.txt +++ b/doc/examples/plain-ignored.txt diff --git a/examples/upstart-cloud-config.txt b/doc/examples/upstart-cloud-config.txt index 1fcec34d..1fcec34d 100644 --- a/examples/upstart-cloud-config.txt +++ b/doc/examples/upstart-cloud-config.txt diff --git a/examples/upstart-rclocal.txt b/doc/examples/upstart-rclocal.txt index 5cd049a9..5cd049a9 100644 --- a/examples/upstart-rclocal.txt +++ b/doc/examples/upstart-rclocal.txt diff --git a/examples/user-script.txt b/doc/examples/user-script.txt index 6a87cad5..6a87cad5 100644 --- a/examples/user-script.txt +++ b/doc/examples/user-script.txt diff --git a/doc/userdata.txt b/doc/userdata.txt new file mode 100644 index 00000000..7ada0ba5 --- /dev/null +++ b/doc/userdata.txt @@ -0,0 +1,57 @@ +=== Overview === +Userdata is data provided by the entity that launches an instance. +The cloud provider makes this data available to the instance via in one +way or anohter. + +In EC2, the data is provided by the user via the '--user-data' or +'user-data-file' argument to ec2-run-instances. The EC2 cloud makes the +data available to the instance via its meta-data service at +http://169.254.169.254/latest/user-data + +ec2-init can read this input and act on it in different ways. + +=== Input Formats === +ec2-init will download and cache to filesystem any user-data that it +finds. However, certain types of user-data are handled specially. + + * Gzip Compressed Content + content found to be gzip compressed will be uncompressed, and + these rules applied to the uncompressed data + + * Mime Multi Part archive + This list of rules is applied to each part of this multi-part file + Using a mime-multi part file, the user can specify more than one + type of data. For example, both a user data script and a + cloud-config type could be specified. + + * User-Data Script + begins with: #! or Content-Type: text/x-shellscript + script will be executed at "rc.local-like" level during first boot. + rc.local-like means "very late in the boot sequence" + + * Include File + begins with #include or Content-Type: text/x-include-url + This content is a "include" file. The file contains a list of + urls, one per line. Each of the URLs will be read, and their content + will be passed through this same set of rules. Ie, the content + read from the URL can be gzipped, mime-multi-part, or plain text + + * Cloud Config Data + begins with #cloud-config or Content-Type: text/cloud-config + + This content is "cloud-config" data. See the examples for a + commented example of supported config formats. + + * Upstart Job + begins with #upstart-job or Content-Type: text/upstart-job + + Content is placed into a file in /etc/init, and will be consumed + by upstart as any other upstart job. + +=== Examples === +There are examples in the examples subdirectory. +Additionally, the 'tools' directory contains 'write-mime-multipart', +which can be used to easily generate mime-multi-part files from a list +of input files. That data can then be given to an instance. + +See 'write-mime-multipart --help' for usage. diff --git a/tools/write-mime-multipart b/tools/write-mime-multipart index a6781876..b83073c1 100755 --- a/tools/write-mime-multipart +++ b/tools/write-mime-multipart @@ -96,7 +96,7 @@ def main(): ofile = file(options.output,"wb") if options.compress: - gfile = gzip.GzipFile(fileobj=ofile) + gfile = gzip.GzipFile(fileobj=ofile, filename = options.output ) gfile.write(outer.as_string()) gfile.close() else: |