About the Code
The Basics
Brooklyn is available at GitHub apache/incubator-brooklyn. Check it out using:
git clone git@github.com:apache/incubator-brooklyn.git
cd brooklyn
Build it with:
mvn clean install
And launch it with:
cd usage/dist/target/brooklyn-dist/
bin/brooklyn launch
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 sub-projects:
camp
: the components for a server which speaks with the CAMP REST API and understands the CAMP YAML plan languageapi
: the pure-Java interfaces for interacting with the systemcore
: the base class implementations for entities and applications, entity traits, locations, policies, sensor and effector support, tasks, and morelocations
: specific location integrationsjclouds
: integration with many cloud APIs and providers via Apache jclouds
policies
: collection of useful policies for automating entity activitysoftware
: entities which are mainly launched by launched software processes on machines, and collections thereofbase
: 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, RabbitMQmonitoring
: monitoring tools, including Monitosgi
: OSGi servers- …
utils
: projects with lower level utilities- common: Utility classes and methods developed for Brooklyn but not dependent on Brooklyn
- groovy: Groovy extensions and utility classes and methods developed for Brooklyn but not dependent on Brooklyn
- jmx/jmxmp-ssl-agent: An agent implementation that can be attached to a Java process, to give expose secure JMXMP
- jmx/jmxrmi-agent: An agent implementation that can be attached to a Java process, to give expose JMX-RMI without requiring all high-number ports to be open
- rest-swagger: Swagger REST API utility classes and methods developed for Brooklyn but not dependent on Brooklyn
- test-support: Test utility classes and methods developed for Brooklyn but not dependent on Brooklyn
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
- archetypes: A maven archetype for easily generating the structure of new downstream projects
- camp: Brooklyn bindings for the CAMP REST API
- 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
- logback-includes: Various helpful logback XML files that can be included; does not contain logback.xml
- logback-xml: Contains a logback.xml that references the include files in brooklyn-logback-includes
- rest-api: The API classes for the Brooklyn REST api
- rest-client: A client Java implementation for using the Brooklyn REST API
- rest-server: The server-side implementation of the Brooklyn REST API
- scripts: various scripts useful for building, updating, etc. (see comments in the scripts)
- qa: longevity and stress tests
- test-support: provides Brooklyn-specific support for tests, used by nearly all projects in scope
test
docs
: the markdown source code for this documentationexamples
: some canonical examplessandbox
: 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:
Where things aren’t documented please ask us at the brooklyn mailing list so we can remedy this!