From e7209609b0ecc90409ad07f1e44b8d92e09c93ee Mon Sep 17 00:00:00 2001 From: Nico Schottelius Date: Wed, 16 Mar 2011 10:45:23 +0100 Subject: [PATCH] cdist update --- software/cdist.mdwn | 44 +++++++++++++++++++++++++------------------- 1 file changed, 25 insertions(+), 19 deletions(-) diff --git a/software/cdist.mdwn b/software/cdist.mdwn index 0938289f..9c645e97 100644 --- a/software/cdist.mdwn +++ b/software/cdist.mdwn @@ -40,7 +40,6 @@ it ticks differently: ### Architecture * Push mode (server pushes configuration) - * Pull mode planned (client triggers configuration) * User defines configuration in shell scripts (called ***manifests***) * Generates internal configuration (cconfig style) * Uses ***types*** to generate code be executed on the target @@ -58,15 +57,10 @@ but is not. Or: The reason why I began to write cdist. * Meaningful error messages * No surprise factor * Consistency in behaviour, naming and documentation - * Easy integration nacked installations + * Easy integration into bare metal installations * Simple and well-known DSL: posix shell - * It is very easy to - * extend cdist - * debug cdist-core and cdist-types - * Focus on reuse of existing functionality - * ssh - * sh - * find, rm, ... + * It must be very easy to extend and debug cdist + * Focus on reuse of existing functionality (like sh, ssh, find, rm, ...) ## Requirements @@ -104,21 +98,22 @@ how to use cdist. ### Available versions -There are at least two branches available: +There are at least the following branches available: * master: the development branch - * 1.0: stable branch of version 1.0 + * 1.0: First official release + * 1.1: Current stable (includes __file type change) -Other branches may be available as well for features or bugfixes, but they +Other branches may be available for features or bugfixes, but they may vanish at any point. To select a specific branch use # Generic code git checkout -b origin/ - # Stay on version 1.0 - git checkout -b 1.0 origin/1.0 + # Stay on version 1.1 + git checkout -b 1.1 origin/1.1 -### Update +## Update To upgrade cdist in the current branch use @@ -128,10 +123,20 @@ To upgrade cdist in the current branch use make man export MANPATH=$MANPATH:$(pwd -P)/doc/man +If you stay on a version branche (i.e. 1.0, 1.1., ...), nothing should break. +The master branch on the other hand is the development branch and may not be +working, break your setup or eat the tree in your garden. + +### Upgrading from 1.0 to 1.1 + +In 1.1 the type **__file** was split into **__directory**, **__file** and +**__link**. The parameter **--type** was removed from **__file**. Thus you +need to replace **__file** calls in your manifests: + + * Remove --type from all __file calls + * If type was symlink, use __link and --type symbolic + * If type was directory, use __directory -The version branches are designed to change if there are incompatibilities. -Or the other way round: As long as you stay on 1.0 and do git pull, nothing -should break. ## Support @@ -165,7 +170,8 @@ Yes, I'm actually eating my own dogfood and currently managing * [kerberos (mit)](http://web.mit.edu/kerberos/) (authentication) * [ircd-hybrid](http://www.ircd-hybrid.org/) (chat) * [stunnel](http://stunnel.mirt.net/) (SSL tunnel) + * [mercurial-server](http://www.lshift.net/mercurial-server.html) -with cdist on a total of **3** production servers of the +with cdist on a total of **4** production servers of the [Systems Group](http://www.systems.ethz.ch) at the [ETH Zurich](http://www.ethz.ch).