Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/wavesoft/dumbq

A very simple service that starts multiple project agents inside a micro-cernvm distribution in isolated linux containers.
https://github.com/wavesoft/dumbq

Last synced: about 2 months ago
JSON representation

A very simple service that starts multiple project agents inside a micro-cernvm distribution in isolated linux containers.

Awesome Lists containing this project

README

        

# DumbQ

A very simple service that starts multiple project agents inside a micro-cernvm distribution in isolated linux containers.

## How it works?

There is a configuration file in a server, where you define the different projects you have and the chance of each of these projects to be selected by a volunteer's computer.

When the VM is booted, the script will fetch this configuration, roll a dice and depending on the result, pick one of the projects defined in the configuration and start it.

Each project is started in a new CernVM fork, running in an isolated linux container. For more details on this check the `cernvm-fork` utility.

In principle if your project agent runs in CernVM or in SLC6, you are ready to use this utility off-the-shelf.

# Server-Side

The ONLY thing you need on the server is a text file served by a webserver in the following syntax:

# Comments start with '#'
# Each line defines a project in the following way:
# : : [,...] :
#
# Example:
test-app:80:sft.cern.ch:sft.cern.ch/lcg/experimental/test-app-bootstrap.sh

Each colon-seprated parameter has the following meaning:

* `` : A short name for the project
* `` : The chance this project has to be selected (0 = never, 100 = always)
* `[,...]` : A comma-separated list of cvmfs repositories this project requires to be mounted
* `` : A bootstrap application to be executed within the container. Whatever you enter in this field is *already* prefixed with `/cvmfs/`. Therefore `sft.cern.ch/lcg/experimental/test.sh` will be translated to `/cvmfs/sft.cern.ch/lcg/experimental/test.sh`.

The benefit from using this script instead of a proper job queue is that you can have **any** kind of job queue within the container, therefore allowing diverse projects to share the same resources.

_Note: Something to keep in mind is that the chances of all the projects should sum up to 100%._

# Client-Side

On the client side you have only the `dumbq-client.sh` script that should be run at the moment you want to start the containers (usually after system boot). No additional parameters are required.

The script will remain alive and monitor the status of the containers and if a container goes down it will try to re-start it (or the next available).

## Overriding chances

If you want (from the user-side) to change the chances of each project to be selected, you can do so by creating the `/var/lib/dumbq/preference.conf`

## Securing the configuration

If you want to be 100% sure that the configuration file is not tampered, you can use SSL and provide the public certificate of your server. Just modify the dumbq-client.sh and provide the required information in the configuration section:

CONFIG_SOURCE="https://myserver/dumbq.conf"
CONFIG_SSL_CERTS="/path/to/server_cert_path.pem"
CONFIG_SSL_CAPATH="/path/to/CA/list"

The script will automatically supply the required information to CURL.

# Requirements

This script requires the following utilities to exist in the distribution:

* `cernvm-fork` (available from https://github.com/wavesoft/cernvm-fork)

# License

DumbQ - A very simple project scheduler

Copyright (C) 2015 Ioannis Charalampidis, PH-SFT, CERN

This program 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 2
of the License, or (at your option) any later version.

This program 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 this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.