Rebuilding my Logstash sandbox utilizing the puppet-sandbox project which I forked to add my own yum repo and fpm package building server.
The idea is to keep this super simple and light and pull puppet modules as git submodules to fulfill my needs for installing and configuring packages.
The following machines are available right now...
- puppet.example.com - the Puppet master server
- client1.example.com - the first Puppet client machine
- client2.example.com - the second Puppet client machine
- fpm.example.com - package building machine
When fpm is fired up it will build a bunch of RPM packages (if they don't exist already) to be added to the puppet servers yum repo for local consumption. This means it can be started and then destroyed as soon as its up.
nodes.pp currently sets up a basic single server elasticsearch VM on client1. There's a bunch of config vars passed to the elasticsearch puppet module to enable this. The elasticsearch puppet module is grabbed from here.
have also added basic puppet config to client2.
To use this, you must have the following items installed and working:
This has been designed for and tested with Vagrant base boxes running:
- CentOS 6.3
...although it may work just fine with other distributions/versions.
Make sure you have a compatible Vagrant base box (if you don't have one already, it will download a 64-bit Ubuntu 12.04 box for you), and then you should be good to clone this repo and go:
$ vagrant box list
centos63
$ git clone git://github.com/paulczar/vagrant-logstash.git
$ cd vagrant-logstash/
$ git submodule init
$ git submodule update
If you want a CentOS base box to work from, I highly recommend the boxes published by Jan Vansteenkiste: http://packages.vstone.eu/vagrant-boxes/ if using other CentOS boxes watch out for iptables being turned on by default.
Build the needed RPMs with the FPM server
$ vagrant up fpm
$ vagrant destroy fpm
To bring up the Puppet server and the elasticsearch node environment, issue the following command:
$ vagrant up puppet logstash
The following tasks will be handled automatically:
- The Puppet server daemon will be installed and enabled on the master machine.
- The Puppet client agent will be installed and enabled on all three machines.
- A host-only network will be set up with all machines knowing how to communicate with each other.
- All client certificate requests will be automatically signed by the master server.
- The master server will utilize the
nodes.pp
file andmodules/
directory that exist outside of the VMs (in your puppet-sandbox Git working directory) by utilizing VirtualBox's shared folder feature. - Logstash and Kibana will be installed according to the rules set in the nodes.pp
Kibana module is a bit wacky ... may need to run
puppet agent -t
a few times on it. - Logstash will listen on TCP port 5140 for syslog like messages.
Most of this is handled using Vagrant's provisioning capabilities and is
controlled by the manifests under the provision/
directory.
If you wish to change the domain name of the VMs (it defaults to
example.com), edit the "domain" variable at the top of Vagrantfile
and
reload the machines:
$ vim Vagrantfile
$ vagrant reload
If you edit the Vagrantfile to add/remove hosts running ./make_hosts.sh will
parse the nodes.pp
file and create a new template for /etc/hosts
with all the hostnames. run vagrant provision
to catch any changes on already running vms.
$ vagrant ssh elasticsearch
$ curl elasticsearch:9200
$ curl elasticsearch:5601
or in web browser :
http://172.16.32.12:5601 - Kibana
http://172.16.32.12:9200/_status?pretty=true - Elasticsearch
A local YUM repo sandbox
is configured on the puppet server. Copy RPM files into /vagrant/packages/rpm
and then run vagrant provision puppet
to refresh the repo. Currently only supports RPM/YUM but will add APT support some time soon.
FPM is installed on the fpm host. This is an excellent tool for building OS packages where writing specfiles gets painful. FPM allows you to create RPM or APT packages from source, or from a directory with all the apps installed. Check the example redis or elasticsearch scripts on the FPM system under /tmp/ for examples of building packages using FPM. Saving the resultant RPM to /vagrant/packages/rpm
and run vagrant provision puppet
will make it immediately available to client1,client2 for installation.
$ vagrant up puppet fpm client1
$ vagrant ssh fpm
[vagrant@fpm ~]$ sudo /tmp/redis-rpm.sh
...
...
[vagrant@fpm ~]$ exit
$ vagrant provision puppet
$ vagrant ssh client1
[vagrant@client1 ~]$ sudo yum clean all
[vagrant@client1 ~]$ sudo yum -y install redis
[vagrant@client1 ~]$ sudo service redis-server start
[vagrant@client1 ~]$ redis-cli ping
PONG
[vagrant@client1 ~]$
Vagrant-Logstash is provided under the terms of The MIT License.
Copyright © 2013, Paul Czarkowski.
Puppet Sandbox is provided under the terms of The MIT License.
Copyright © 2012, Aaron Bull Schaefer.