3.2 Building and installing GreenPages

Building with Apache Maven

GreenPages uses Apache Maven as its primary build system. Each module of the application can be built separately and the entire application can built and assembled into a PAR file from a single location. To build the PAR file:

  1. Make $GREENPAGES_HOME/solution the current directory.

  2. Run the command mvn package. The first time this is run several files will be downloaded from Maven repositories and SpringSource repositories. Subsequent runs will not need to do this.

  3. Verify that the greenpages-2.0.0.SNAPSHOT.par file exists in $GREENPAGES_HOME/solution/greenpages/target.

Installing dependencies into dm Server

Unlike traditional Java EE applications, GreenPages does not package all of its dependencies inside its deployment unit. Instead, it relies on the mechanisms of OSGi to locate its dependencies at runtime. When running an OSGi application on dm Server, these dependencies can be loaded into memory as needed, but first they must be made available to dm Server.

The Maven build included with GreenPages uses the dependency:copy-dependencies plugin to gather all the artifacts that GreenPages depends on that are not supplied by the dm Server runtime. These dependencies can then be installed into the dm Server repository. Dependencies are gathered automatically during the package phase. These dependencies can be found in $GREENPAGES_HOME/solution/greenpages/target/par-provided. To install dependencies simply copy all the bundles from this directory into $DMS_HOME/repository/bundles/usr.

Installing dependencies on Windows:

cd %GREENPAGES_HOME%\solution\greenpages 
copy target\par-provided\* %DMS_HOME%\repository\bundles\usr

Installing Dependencies on UNIX:

cd $GREENPAGES_HOME/solution/greenpages 
cp target/par-provided/* $DMS_HOME/repository/bundles/usr

Notice that dm Server will not necessarily see these dependencies unless its repository indexes are rebuilt. Different repositories behave differently in this respect; the bundles-usr repository is passive. The next time dm Server is started use the -clean option to re-scan the repository directories. It is always safe to start dm Server with this option; it may take a little longer if the repositories are large.

Starting and configuring the database

GreenPages uses the H2 database to store all its data. Before the application can be started, the database server must be started and the database populated with data.

  1. Make $GREENPAGES_HOME/db the current directory.

  2. Run the database startup script appropriate to the operating system.

  3. Run the data population script appropriate to the operating system.

Starting and configuring the database on Windows:

cd %GREENPAGES_HOME%\db
run
data

Starting and configuring the database on UNIX:

cd $GREENPAGES_HOME/db
./run.sh &

./data.sh

After ./run.sh & press Return to continue.

These instructions need only be run once to start a database server for H2; this will continue to run in the background. A browser window offering a connection to the database may open: this should be closed.

Installing and starting GreenPages PAR

To install the GreenPages PAR into dm Server and start it:

  1. Copy the GreenPages PAR to the $DMS_HOME/pickup directory.

  2. Start dm Server with the -clean option.

    $DMS_HOME/bin/startup.sh -clean

    or

    "%DMS_HOME%"\bin\startup.bat -clean

    as appropriate.

  3. Verify that GreenPages starts correctly by checking in the dm Server output for the log message:

    <SPDE0010I> Deployment of 'greenpages' version '2.0.0.SNAPSHOT' completed.
    

Installing and starting GreenPages on Windows:

cd %DMS_HOME%
copy %GREENPAGES_HOME%\solution\greenpages\target\greenpages-solution-2.0.0.SNAPSHOT.par pickup\               
bin/startup.bat

Installing and starting GreenPages on UNIX:

cd $DMS_HOME
cp $GREENPAGES_HOME/solution/greenpages/target/greenpages-solution-2.0.0.SNAPSHOT.par pickup/
bin/startup.sh