Code Structure

The Basics

Brooklyn is available at GitHub brooklyncentral/brooklyn. Check it out using:

git clone git@github.com:brooklyncentral/brooklyn.git
cd brooklyn

Build it with:

mvn clean install

And launch it with:

cd usage/dist/target/brooklyn-dist/
bin/brooklyn launch

Plenty of examples are in the examples sub-dir, described here, and pushed to the brooklyn-examples GitHub project when a version is released.

Information on using Brooklyn -- configuring locations (in brooklyn.properties) and adding new projects to a catalog -- can be found in the User's Guide. This document is intended to help people become familiar with the codebase.

Project Structure

Brooklyn is split into the following projects and subprojects:

  • api: the pure-Java interfaces for interacting with the system
  • core: the base class implementations for entities and applications, entity traits, locations, policies, sensor and effector support, tasks, and more
  • policies: collection of useful policies for automating entity activity
  • software: entities which are mainly launched by launched software processes on machines, and collections thereof
    • base: software process lifecycle abstract classes and drivers (e.g. SSH)
    • webapp: web servers (JBoss, Tomcat), load-balancers (Nginx), and DNS (Geoscaling)
    • database: relational databases (SQL)
    • nosql: datastores other than RDBMS/SQL (often better in distributed environments)
    • messaging: messaging systems, including Qpid, Apache MQ
    • ...
  • systems: entities which are mainly created or managed by other systems, where Brooklyn integrates with those (multi-machine) systems and is removed from the processes
    • whirr: base Whirr integration, and entities built on Whirr such as the configurable hadoop deployment
    • ...
  • usage: projects which make Brooklyn easier to use, either for end-users or Brooklyn developers
    • all: maven project to supply a shaded JAR (containing all dependencies) for convenience
    • cli: backing implementation for Brooklyn's command line interface
    • dist: builds brooklyn as a downloadable .zip and .tar.gz
    • jsgui: Javascript web-app for the brooklyn management web console (builds a WAR)
    • launcher: for launching brooklyn, either using a main method or invoked from the cli project
    • qa: longevity and stress tests
    • rest: implementation of brooklyn's REST api
    • scripts: various scripts useful for building, updating, etc. (see comments in the scripts)
    • test-support: provides support for tests, used by nearly all projects in scope test
  • docs: the markdown source code for this documentation, as described here
  • examples: some canonical examples, as listed here
  • sandbox: various projects, entities, and policies which the Brooklyn Project is incubating

Next Steps

If you're interested in building and editing the code, check out:

If you want to start writing your own policies and entities, have a look at:

Where things aren't documented please ask us at the brooklyn mailing list so we can remedy this!