Currently, LinchPin can be run from any machine with Python 2.6+ (Python 3.x is currently experimental), and requires Ansible 2.2.1. There are many other dependencies, depending on the provider. The core providers are OpenStack, Amazon EC2, and Google Compute Cloud. If enabled on the host system, Libvirt can also be used out of the box.
Refer to your specific operating system for directions on the best method to install Python, if it is not already installed. Many modern operating systems will have Python already installed. This is typically the case in all versions of Linux and OS X, but the version present might be older than the version needed for use with Ansible. You can check the version by typing
If the system installed version of Python is older than 2.6, many systems will provide a method to install updated versions of Python in parallel to the system version (eg. virtualenv).
As LinchPin is heavily dependent on Ansible, this is a core requirement. Beyond installing Ansible, there are several packages that need to be installed:
* libffi-devel * openssl-devel * libyaml-devel * gmp-devel * libselinux-python * make
For Fedora/CentOS/RHEL the necessary packages should be installed.
$ sudo yum install python-virtualenv libffi-devel \ openssl-devel libyaml-devel gmp-devel libselinux-python make
Fedora will present an output suggesting the use of dnf as a replacement for yum.
Currently, linchpin is not packaged for any major Operating System. If you’d like to contribute your time to create a package, please contact the linchpin mailing list.
Create a virtualenv to install the package using the following sequence of commands (requires virtualenvwrapper).
$ mkvirtualenv linchpin ..snip.. (linchpin) $ pip install linchpin ..snip..
mkvirtualenv is optional dependency you can install from http://virtualenvwrapper.readthedocs.io/en/latest/install.html , if you would like to use python virtualenv use following commands instead. mkdir linchpin virtualenv linchpin source linchpin/bin/activate
To deactivate the virtualenv.
(linchpin) $ deactivate $
Then reactivate the virtualenv.
$ workon linchpin (linchpin) $
If testing or docs is desired, additional steps are required.
(linchpin) $ pip install linchpin[docs] (linchpin) $ pip install linchpin[tests]
As an alternative, LinchPin can be installed via github. This may be done in order to fix a bug, or contribute to the project.
(linchpin) $ git clone git://github.com/CentOS-PaaS-SIG/linchpin ..snip.. (linchpin) $ pip install file://$PWD/linchpin