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:- baseWhirr integration, and entities built on Whirr such as the configurable- hadoopdeployment
- openshift: entity for deploying and managing OpenShift webapps
- ...
 
- 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:
- Writing a Brooklyn Policy
- Writing a Brooklyn Entity
- Or see the User Guide on policies and entities
Where things aren't documented please ask us at brooklyn-dev@googlegroups.com so we can remedy this!