Skip to content
/ clufter Public

Tool/library for transforming/analyzing cluster configuration formats [alternate project hosting, primary is pagure, see the link]

License

Notifications You must be signed in to change notification settings

jnpkrn/clufter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

e182b0c · Jan 22, 2020
Aug 14, 2019
Nov 30, 2017
Jan 18, 2020
Jan 18, 2020
Aug 14, 2019
Jan 18, 2020
Mar 15, 2018
Nov 27, 2015
Jul 21, 2016
Jun 6, 2017
Jan 28, 2015
Nov 27, 2015
Jan 22, 2020
Sep 12, 2014
Sep 16, 2014
Aug 15, 2019
Apr 7, 2015
Sep 22, 2014
Nov 10, 2014
Apr 25, 2014
Jan 17, 2020
Jan 17, 2020
Mar 22, 2017
Mar 21, 2017
Mar 22, 2017
Sep 11, 2014
Apr 25, 2014
Aug 13, 2019
May 25, 2017
Nov 3, 2017
Aug 14, 2019
Sep 4, 2014
Aug 14, 2019
Jan 18, 2020
Jan 17, 2020
Oct 1, 2014
Sep 12, 2014
Sep 11, 2014
Sep 11, 2014
Jan 8, 2015
Apr 7, 2017
May 25, 2017
Dec 17, 2015
Apr 15, 2015
Apr 15, 2015
Mar 21, 2017
Feb 1, 2016
Jan 17, 2020
Mar 21, 2017
Mar 21, 2017

Repository files navigation

clufter (CLUster FilTER)

$ ./run-dev -h | sed '2,8p;d'

Tool/library for transforming/analyzing cluster configuration formats

While primarily aimed at (CMAN,rgmanager)->(Corosync/CMAN,Pacemaker) cluster
stacks configuration conversion (as per RHEL trend), the command-filter-format
framework (capable of XSLT) offers also other uses through its plugin library.

And nope, the name is not a pun, typo or lisp-pronounced cluster per se :-P As mentioned elsewhere, the project is pretty composite, just as its name is.

Historical curiosity: clufter logotype should actually make f look similar to ſ letter (long s, in use some 200 years ago) as an explicit association with an s-contained word (conversely, project name searchable in A new alphabetical vocabulary, Gailic and English OCR scan).

Usage

The package can either be used as a separate CLI tool (as per What) or as a Python library, which is the case, e.g., with pcs.

Demo

When properly installed, clufter command should be only these few letters away at your shell prompt. For simplicity, I will stick with what one can use directly after cloning the repository and running ./run-check (to get the helper binary compiled):

$ ./run-dev ccs2pcscmd -gsq tests/filled.conf
#!/bin/sh
# sequence generated on 2017-03-10 17:01:31 with: clufter 0.60.0a
# invoked as: ['./run-dev', 'ccs2pcscmd', '-gsq', 'tests/filled.conf']
# targeting system: ('linux', 'fedora', '27', 'Rawhide')
# using interpreter: CPython 2.7.13
pcs cluster auth ju hele <>/dev/tty
pcs cluster setup --name test ju hele --consensus 200 --join 100 \
  --token 5000
pcs cluster start --all --wait=60
pcs cluster cib tmp-cib.xml
pcs -f tmp-cib.xml property set stonith-enabled=false
pcs cluster cib-push tmp-cib.xml --config

or using Python 3:

$ python3 ./run-dev ccs2pcscmd -gsq tests/filled.conf
#!/bin/sh
# sequence generated on 2017-03-10 17:02:34 with: clufter 0.60.0a
# invoked as: ['run-dev', 'ccs2pcscmd', '-gsq', 'tests/filled.conf']
# targeting system: ('linux', 'fedora', '27', 'Rawhide')
# using interpreter: CPython 3.6.0
pcs cluster auth ju hele <>/dev/tty
pcs cluster setup --name test ju hele --consensus 200 --join 100 \
  --token 5000
pcs cluster start --all --wait=60
pcs cluster cib tmp-cib.xml
pcs -f tmp-cib.xml property set stonith-enabled=false
pcs cluster cib-push tmp-cib.xml --config

Here we got a sequence of pcs commands that should get us started with rebuilding a cluster originally based on CMAN/rgmanager stack (with configuration captured in given file), now targetting Corosync/Pacemaker one (for which pcs is one of the high-level configuration tools).

Depending on how sensitive the target environment is (conversely, how much confident of clufter and its output you are), you can either reason about each command, possibly making correction in due course (well, clufter never had ambitions to be fully and reliably automagic), or just pipe that into the shell interpreter, for instance:

$ ./run-dev ccs2pcscmd -gsq tests/filled.conf | bash -x

which will also turn on echoing of what is being executed, just in case.

Take this just as a showcase of the primary goal for this tool, there are many other realated conversion/analysis related tasks featured and discoverable as:

$ ./run-dev -l

Dependencies

Python-wise:

  • lxml (python-lxml/python3-lxml)

general:

  • Python
    • 2.7 preferred
    • 2.6 with ordereddict or some kind of collections.OrderedDict backport (#929258) required
    • 3.2+ support currently deemed experimental (the test suite is passing), bug reports appreciated (see Reporting issues)
  • embedded ccs_flatten (originally pacemaker.git/extra/rgmanager) compiled helper
    • suitable C compiler (gcc)
    • libxml2

tests:

  • outside of Python 2.7+, unittest2 (python-unittest2) or, alternatively, nose (python-nose) is needed

Stable version

Official released tarballs (as opposed to what you can download from GitHub) can be found, together with GPG signatures, at https://pagure.io/releases/clufter/ or, alternatively, at https://people.redhat.com/jpokorny/pkgs/clufter/.

Also, the HEAD of master branch in the repository should always point to the latest stable, tagged (and GPG-signed, for that matter) release. Current status of the test run using Travis CI against this branch:

https://travis-ci.org/jnpkrn/clufter.svg?branch=master https://coveralls.io/repos/jnpkrn/clufter/badge.svg?branch=master&service=github

Development version

TBD

https://travis-ci.org/jnpkrn/clufter.svg?branch=next https://coveralls.io/repos/jnpkrn/clufter/badge.svg?branch=next&service=github

Other remarks

Bash completion

For convenience, bash completion is at user's hands by just running within the session:

$ eval "$(clufter --completion-bash)"

Indeed, to make such a feature permanent, the produced script can be appended to or referred from some relevant file like ~/.bashrc, or when bash-completion package installed, stored to ~/.config/bash_completion (per-user) or /usr/share/bash-completion/bash_completion (system-wide). It's also possible this is already performed on the packaging level.

Contact

Reporting issues

Bug reports, suggestions and feature requests are best directed at https://pagure.io/clufter/issues, alternatively check the bottom of clufter --help screen when using a distribution version.

The more feedback samples emerge, the better this project can get.

Wider community

Common cluster/HA channels falling under ClusterLabs umbrella:

About

Tool/library for transforming/analyzing cluster configuration formats [alternate project hosting, primary is pagure, see the link]

Resources

License

Stars

Watchers

Forks

Packages

No packages published