The Lappsgrid Database Definition Language (LDDL) is a Groovy DSL for configuring the Postgres database used by Service Manager instances. See http://lappsgrid.org/software/lddl for more information on the LDDL syntax.
Configuring the Posgres database and registering services requires the following steps.
- Run the DatabaseCreate.lddl script to create the Postgres database. If the database already exists it will be dropped first.
- Start then Stop the Tomcat instance hosting the Service Manager. The Service Manager will create all of the required tables when it first connects to the Postgres database.
- Run the DatabaseSetup.lddl script which creates the indices and stored procedure used by the Serivce Manager. Note: The Vassar.lddl script includes the DatabaseSetup.lddl script so it does not need to be run separately.
- Register your services with the Service Manager. See the Vassar.lddl script for an example setup.
For example, setting up the Vassar node might go something like:
$> lddl DatabaseCreate.lddl
$> sudo service tomcat start
$> sudo service tomcat stop
$> lddl Vassar.lddl
There are three main scripts used to initialize nodes on the LAPPS Grid:
- Brandeis.lddl
Initializes the services on the Brandeis node. - Vassar.lddl
Initializes the services on the Vassar node. - Update.lddl
Use the Update.lddl script to register one, or more, services with out re-initializing the entire database.
The Vassar.lddl scripts accepts two optional parameters:
- -server=<URL>
Specifies the URL of the server hosting the services being registered. The services being registered by the LDDL script must be online and available as the LDDL script will need to fetch the WSDL file from the service to register it with the Service Manager. - -clean
Deletes existing data from the database. Use the -clean option when the database has been previously populated by the Service Manager. If the -clean parameter is not provided it is assumed that the database is being configured for the first time and the indices and stored procedure will be added to the database.
$> lddl Vassar.lddl -clean -server=http://grid.anc.org:9080
Use the Update.lddl script to register one or more services without reinitializing the entire database. This is useful to add services to an already configured Service Manager instance. For example:
$> lddl Update.lddl -server=vassar vassar/Gate vassar/Stanford vassar/MASC
- Copyright.lddl
Edit the Copyright.lddl script to update the copyright noticed added to resources and services registered with the Service Manager. - Database.lddl
Database connection information for the Postgres database: connection URL, username, and password. - Setup.lddl
Include theSetup.lddl
script to initialize the database with the metadata, resources, and service definitions required by all nodes in the LAPPS Grid.