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). Please, refer to the FAQ for more details.

History

Roboconf was created to be the foundations of Open PaaS.
Open PaaS is an Enterprise Social Network, i.e. a platform dedicated to collaborations within organizations (messaging, groups and projects management, video conference…). The project is led by Linagora, which also works on Roboconf in collaboration with the Laboratoire Informatique de Grenoble. This entity is part of the Research department in Computer Science and Software Engineering of Université Joseph Fourier, in Grenoble, France.

Technical requirements for Open PaaS’ foundations were clear.

The real business value for the company was clearly about the applications to run in the cloud.
At the time (end of 2012), some cloud solutions were emerging, but none of them matched all the criteria above. Contacts between Linagora and Université Joseph Fourier led to a partnership to prototype such a solution with a focus on industrial applications. Roboconf was born…

Use Cases

General use cases are listed here.
The following list includes cases we illustrated through samples, demos or for real requirements.