forked from ungleich-public/cdist
		
	Merge remote branch 'nico/master'
This commit is contained in:
		
				commit
				
					
						4bf1216f12
					
				
			
		
					 11 changed files with 118 additions and 52 deletions
				
			
		
							
								
								
									
										9
									
								
								.gitignore
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								.gitignore
									
										
									
									
										vendored
									
									
								
							|  | @ -2,13 +2,8 @@ | |||
| .*.swp | ||||
| 
 | ||||
| # Ignore generated manpages | ||||
| doc/man/*.[1-9] | ||||
| doc/man/.marker | ||||
| doc/man/man*/ | ||||
| 
 | ||||
| doc/html | ||||
| 
 | ||||
| conf/type/*/*.7 | ||||
| conf/type/*/man.html | ||||
| 
 | ||||
| 
 | ||||
| # Ignore cache for version control | ||||
| cache/ | ||||
|  |  | |||
							
								
								
									
										37
									
								
								README
									
										
									
									
									
								
							
							
						
						
									
										37
									
								
								README
									
										
									
									
									
								
							|  | @ -52,22 +52,28 @@ You can [browse the documentation for the latest version online](man) as well. | |||
| 
 | ||||
| ### Features | ||||
| 
 | ||||
| Stuff that should probably be included in every configuration management, | ||||
| but is not. Or: Why I began to write cdist: | ||||
| 
 | ||||
|  * Speed | ||||
|  * Elegant code | ||||
|  * Clean design | ||||
|  * Elegant code and clean design | ||||
|   * Type and core cleanly seperated | ||||
|   * Small codebase in core | ||||
|  * Good documentation (man pages) | ||||
|  * Meaningful error messages | ||||
|  * The no surprise factor | ||||
|  * Consistency in behaviour, naming and documentation | ||||
|  * Meaningful error messages | ||||
|   * Either standard error messages from tools or added description for clearification | ||||
|  * The no surprise factor | ||||
|   * No magic guessing of what the user wants | ||||
|  * Simple and well-known DSL | ||||
|   * Posix shell | ||||
|  * Easy integration into bare metal installations | ||||
|  * Simple and well-known DSL: posix shell | ||||
|  * It must be very easy to extend and debug cdist | ||||
|  * Focus on reuse of existing functionality (like sh, ssh, find, rm, ...) | ||||
|  * Easy upgrade: ***There is no need to update cdist on target hosts!*** | ||||
|   * cdist only needs to be update on the master server | ||||
|   * requires only ssh + sh | ||||
|  * Easy upgrade | ||||
|   * ***There is no need to update cdist on target hosts!*** | ||||
|   * cdist only needs to be updated on the master server(s) | ||||
|  * Very easy to extend | ||||
|   * Can be done via types, which can be stacked on top of others | ||||
|  * Reuse of existing functionality | ||||
|   * sh, ssh, find, rm, mv, ... | ||||
|  * Very easy to debug | ||||
|   * Just add set -x in the scripts | ||||
| 
 | ||||
| ### OS support | ||||
| 
 | ||||
|  | @ -77,6 +83,7 @@ cdist was tested or is know to run on at least | |||
|  * [Debian](http://www.debian.org/) | ||||
|  * [Gentoo](http://www.gentoo.org/) | ||||
|  * [Mac OS X](http://www.apple.com/macosx/) | ||||
|  * [OpenBSD](http://www.openbsd.org) | ||||
|  * [Redhat](http://www.redhat.com/) | ||||
|  * [Ubuntu](http://www.ubuntu.com/) | ||||
| 
 | ||||
|  | @ -108,7 +115,7 @@ To install cdist, execute the following commands: | |||
|     export PATH=$PATH:$(pwd -P)/bin | ||||
| 
 | ||||
|     # If you want the manpages (requires gmake and asciidoc to be installed) | ||||
|     make man | ||||
|     ./build.sh man | ||||
|     export MANPATH=$MANPATH:$(pwd -P)/doc/man | ||||
| 
 | ||||
| 
 | ||||
|  | @ -150,7 +157,7 @@ To upgrade cdist in the current branch use | |||
|     git pull | ||||
| 
 | ||||
|     # Also update the manpages | ||||
|     make man | ||||
|     ./build.sh man | ||||
|     export MANPATH=$MANPATH:$(pwd -P)/doc/man | ||||
| 
 | ||||
| If you stay on a version branche (i.e. 1.0, 1.1., ...), nothing should break. | ||||
|  |  | |||
							
								
								
									
										37
									
								
								bin/cdist-cache
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										37
									
								
								bin/cdist-cache
									
										
									
									
									
										Executable file
									
								
							|  | @ -0,0 +1,37 @@ | |||
| #!/bin/sh | ||||
| # | ||||
| # 2010 Nico Schottelius (nico-cdist at schottelius.org) | ||||
| # | ||||
| # This file is part of cdist. | ||||
| # | ||||
| # cdist is free software: you can redistribute it and/or modify | ||||
| # it under the terms of the GNU General Public License as published by | ||||
| # the Free Software Foundation, either version 3 of the License, or | ||||
| # (at your option) any later version. | ||||
| # | ||||
| # cdist is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| # GNU General Public License for more details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with cdist. If not, see <http://www.gnu.org/licenses/>. | ||||
| # | ||||
| #  | ||||
| # Let's build a cconfig tree from a configuration | ||||
| # And save it into the cache tree | ||||
| # | ||||
| 
 | ||||
| . cdist-config | ||||
| [ $# -eq 1 ] || __cdist_usage "<target host>" | ||||
| set -u | ||||
| 
 | ||||
| __cdist_target_host="$1"; shift | ||||
| 
 | ||||
| mkdir -p "${__cdist_local_base_cache_dir}" | ||||
| __cdist_abs_cache_dir="$(cd "$__cdist_local_base_cache_dir" && pwd -P)" | ||||
| __cdist_abs_ddir="$__cdist_abs_cache_dir/$__cdist_target_host" | ||||
| 
 | ||||
| echo "Saving cache to $__cdist_abs_ddir ..." | ||||
| rm -rf "$__cdist_abs_ddir" | ||||
| mv "$__cdist_local_base_dir" "$__cdist_abs_ddir" | ||||
|  | @ -41,6 +41,7 @@ __cdist_abs_myname="$__cdist_abs_mydir/$__cdist_myname" | |||
| # | ||||
| 
 | ||||
| : ${__cdist_name_bin:=bin} | ||||
| : ${__cdist_name_cache:=cache} | ||||
| : ${__cdist_name_code:=code} | ||||
| : ${__cdist_name_code_finished:=codedone} | ||||
| : ${__cdist_name_conf_dir:=conf} | ||||
|  | @ -100,6 +101,7 @@ __cdist_tmp_file=$(mktemp "$__cdist_tmp_dir/cdist.XXXXXXXXXXXX") | |||
| # Local Base | ||||
| #  | ||||
| : ${__cdist_local_base_dir:=$__cdist_tmp_dir} | ||||
| : ${__cdist_local_base_cache_dir:=$__cdist_abs_mydir/../$__cdist_name_cache} | ||||
| 
 | ||||
| : ${__cdist_conf_dir:="$(cd "$__cdist_abs_mydir/../conf" && pwd -P)"} | ||||
| 
 | ||||
|  |  | |||
|  | @ -58,5 +58,6 @@ cdist-dir push "$__cdist_target_host" "$__cdist_out_object_dir" \ | |||
|    "${__cdist_remote_out_object_base_dir}" | ||||
| 
 | ||||
| cdist-code-run-all            "$__cdist_target_host" | ||||
| cdist-cache                   "$__cdist_target_host" | ||||
| 
 | ||||
| echo "cdist $__cdist_version: Successfully finished run on $__cdist_target_host" | ||||
|  |  | |||
							
								
								
									
										7
									
								
								build.sh
									
										
									
									
									
								
							
							
						
						
									
										7
									
								
								build.sh
									
										
									
									
									
								
							|  | @ -41,6 +41,7 @@ case "$1" in | |||
|    man) | ||||
|       set -e | ||||
|       "$0" mandirs | ||||
|       "$0" mangen | ||||
|       "$0" mantype | ||||
|       "$0" man1 | ||||
|       "$0" man7 | ||||
|  | @ -61,7 +62,7 @@ case "$1" in | |||
|    ;; | ||||
| 
 | ||||
|    mantype) | ||||
| 	   for mansrc in ${MAN7TYPESRC}; do | ||||
| 	   for mansrc in conf/type/*/man.text; do | ||||
|          dst="$(echo $mansrc | sed -e 's;conf/;cdist-;'  -e 's;/;;' -e 's;/man;;' -e 's;^;doc/man/man7/;')" | ||||
|          ln -sf "../../../$mansrc" "$dst" | ||||
|       done | ||||
|  | @ -83,9 +84,9 @@ case "$1" in | |||
|    ;; | ||||
| 
 | ||||
|    man7) | ||||
|       for man in cdist.text cdist-best-practise.text cdist-hacker.text         \ | ||||
|       for man in cdist.text cdist-best-practice.text cdist-hacker.text         \ | ||||
|       cdist-quickstart.text cdist-reference.text cdist-stages.text             \ | ||||
|       cdist-type.text | ||||
|       cdist-type.text cdist-cache.text | ||||
|          do | ||||
|          ln -sf ../$man ${MAN7DSTDIR} | ||||
|       done | ||||
|  |  | |||
|  | @ -1,3 +1,6 @@ | |||
| 1.5.0: | ||||
| 	* Add cache functionality | ||||
| 
 | ||||
| 1.4.1: 2011-03-25 | ||||
| 	* New type __key_value (Steven Armstrong) | ||||
| 	* New type __apt_ppa (Steven Armstrong) | ||||
|  | @ -41,7 +44,6 @@ | |||
| 	* Document cdist-object-gencode-all | ||||
| 	* Document cdist-manifest-run | ||||
| 
 | ||||
| 
 | ||||
| 1.1.0: 2011-03-16 | ||||
| 	* Replace type __file with __file, __directory, __link | ||||
| 	* Document cdist-env | ||||
|  |  | |||
|  | @ -1,23 +1,9 @@ | |||
| Cache: | ||||
|    - add example how to use  | ||||
|    - export variable $__cache | ||||
|       -> for current host | ||||
|       -> add function to cdist-config, import from cdist-cache | ||||
| 
 | ||||
| 
 | ||||
| Core: | ||||
|    - support $__self = relative_type/object_id | ||||
|    - cache | ||||
| 
 | ||||
| Cache: | ||||
|    Assume you want to configure stuff one host ("monitor node"), | ||||
|    depending on the configuration of other hosts ("cluster nodes"). | ||||
| 
 | ||||
|    For instance, the monitor host would like to know, | ||||
|    which hosts are configured with the provider | ||||
|    "apache" and option --start true. | ||||
| 
 | ||||
|    This requires the monitor node to be able to | ||||
|    query all other configured nodes. It can't | ||||
|    ask for all hosts, because cdist does not | ||||
|    know which hosts are configured or may exist. | ||||
| 
 | ||||
|    Example implementation | ||||
| 
 | ||||
|    If cdist keeps ("caches") the configuration of every | ||||
|    node it configures, each new node can query the | ||||
|    cache for existing nodes that acquired the given | ||||
|    configuration. | ||||
|  |  | |||
|  | @ -1,10 +1,10 @@ | |||
| cdist-best-practise(7) | ||||
| cdist-best-practice(7) | ||||
| ====================== | ||||
| Nico Schottelius <nico-cdist--@--schottelius.org> | ||||
| 
 | ||||
| NAME | ||||
| ---- | ||||
| cdist-best-practise - Practises used in real environments | ||||
| cdist-best-practice - Practices used in real environments | ||||
| 
 | ||||
| 
 | ||||
| PASSWORDLESS CONNECTIONS | ||||
|  | @ -61,7 +61,6 @@ machine-b % git clone git://your-git-server/cdist | |||
| -------------------------------------------------------------------------------- | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| SEE ALSO | ||||
| -------- | ||||
| - cdist(7) | ||||
							
								
								
									
										31
									
								
								doc/man/cdist-cache.text
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								doc/man/cdist-cache.text
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,31 @@ | |||
| cdist-cache(1) | ||||
| ============== | ||||
| Nico Schottelius <nico-cdist--@--schottelius.org> | ||||
| 
 | ||||
| 
 | ||||
| NAME | ||||
| ---- | ||||
| cdist-cache - Cache output of last run | ||||
| 
 | ||||
| 
 | ||||
| SYNOPSIS | ||||
| -------- | ||||
| cdist-cache TARGET_HOST | ||||
| 
 | ||||
| 
 | ||||
| DESCRIPTION | ||||
| ----------- | ||||
| cdist-cache moves away the objects created during last run so the | ||||
| next run can use the previous information and compare them with | ||||
| the current status. | ||||
| 
 | ||||
| 
 | ||||
| SEE ALSO | ||||
| -------- | ||||
| cdist(7) | ||||
| 
 | ||||
| 
 | ||||
| COPYING | ||||
| ------- | ||||
| Copyright \(C) 2011 Nico Schottelius. Free use of this software is | ||||
| granted under the terms of the GNU General Public License version 3 (GPLv3). | ||||
|  | @ -10,8 +10,13 @@ cdist - Configuration management system | |||
| 
 | ||||
| DESCRIPTION | ||||
| ----------- | ||||
| Cdist is a very simple, elegant, cleanly designed configuration management | ||||
| system. The easiest way to get started with cdist is to run cdist-quickstart. | ||||
| Cdist is a usable configuration management system. | ||||
| The easiest way to get started with cdist is to initialise | ||||
| the environment and run cdist-quickstart: | ||||
| 
 | ||||
| -------------------------------------------------------------------------------- | ||||
| eval `./bin/cdist-env` && cdist-quickstart | ||||
| -------------------------------------------------------------------------------- | ||||
| 
 | ||||
| Cdist configurations are written in the shell scripting language. | ||||
| The mapping of configurations to hosts is defined in so called manifests, | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue