Roboconf :: Messaging :: API

A solution for elastic deployments

License

License

Categories

Categories

Net Messaging Application Layer Libs
GroupId

GroupId

net.roboconf
ArtifactId

ArtifactId

roboconf-messaging-api
Last Version

Last Version

0.9.1
Release Date

Release Date

Type

Type

bundle
Description

Description

Roboconf :: Messaging :: API
A solution for elastic deployments

Download roboconf-messaging-api

Dependencies

provided (2)

Group / Artifact Type Version
net.roboconf : roboconf-core jar 0.9.1
org.osgi : org.osgi.core jar 4.3.1

test (3)

Group / Artifact Type Version
junit : junit jar 4.12
net.roboconf : roboconf-core test-jar 0.9.1
org.mockito : mockito-core jar 1.10.19

Project Modules

There are no modules declared in this project.

Roboconf

Build Status Coverage Status License Join us on Gitter.im Web site

Snapshots Maven Central

This repository contains the source code for the Roboconf platform.
This includes the manager, the agent, their default distributions, the tooling core and the Maven plugin.

What is Roboconf?

Roboconf is both a platform and framework to manage elastic applications in the cloud.
Elastic applications designate those whose deployment topology may vary over time (e.g. scaling up or down). Roboconf manages deployments, probes, automatic reactions and reconfigurations. Beyond applications, Roboconf could also be defined as a « PaaS framework »: a solution to build PaaS (Platform as a Service). Most PaaS, such as Cloud Foundry or Openshift, target developers and support application patterns. However, some applications require more flexible architectures or design. Roboconf addresses such cases.

With Roboconf, there is no constraint about the programming language, the kind of application or the operating system. You define what you put in your platform, you specify all the interactions, administration procedures and so on.

Roboconf handles application life cycle: hot reconfiguration (e.g. for elasticity issues) and consistency (e.g. maintaining a consistent state when a component starts or stops, even accidentally). This relies on a messaging queue (currently Rabbit MQ). Application parts know what they expose to and what they depend on from other parts. The global idea is to apply to applications the concepts used in component technologies like OSGi. Roboconf achieves this in a non-intrusive way, so that it can work with legacy Software.

Roboconf's workflow

Application parts use the message queue to communicate and take the appropriate actions depending on what is deployed or started. These appropriate actions are executed by plug-ins (such as bash or Puppet).

Roboconf's architecture

Roboconf is distributed technology, based on AMQP and REST / JSon. It is IaaS-agnostic, and supports many well-known IaaS (including OpenStack, Amazon Web Services, Microsoft Azure, VMWare, as well as a "local" deployment plug-in for on-premise hosts).

More information and tutorials are available on the web site.
Build instructions can be found here.
Roboconf is licensed under the terms of the Apache License v2.

net.roboconf

Roboconf

A solution for elastic applications

Versions

Version
0.9.1
0.9
0.8
0.7
0.6.1
0.6
0.5
0.4