Server Requirements
The installation of the OLE Server requires the following:
Ant (OLE is using 1.7.1)
Maven (OLE is using 2.2.1)
Tomcat (OLE is currently running under Tomcat6 and has only been tested with Tomcat6)
Oracle or MySQL Database. (OLE is using Oracle 11.2.0.2.v3 and MySQL 5.1.57)
The easiest means of installing the software is to have access to root or the ability to sudo root.
Oracle Requirements
Two empty schemas will be needed. One for the OLE/Rice/KFS installation and one for the OLE Docstore installation. Username, Password, Host Address, Port and SID are needed for installation configuration.
MySQL Requirements
Two empty databases will be needed. One for the OLE/Rice/KFS installation and one for the OLE Docstore installation. Username, Password, Host Address and Port are needed for installation configuration.
Tomcat Requirements
The following JAVA_OPTS need to be added to the configuration file for Tomcat.
JAVA_OPTS="$JAVA_OPTS -Xmx1024m -Xms768m -XX:MaxPermSize=256m -XX:PermSize=256m -XX:MaxNewSize=256m -XX:NewSize=256m"
JAVA_OPTS="$JAVA_OPTS -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:SurvivorRatio=128 -XX:MaxTenuringThreshold=0 -XX:+UseTLAB"
JAVA_OPTS="$JAVA_OPTS -XX:+CMSClassUnloadingEnabled -XX:+CMSPermGenSweepingEnabled"
JAVA_OPTS="$JAVA_OPTS -Dorg.apache.jasper.compiler.Parser.STRICT_QUOTE_ESCAPING=false -Djava.awt.headless=true"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.jndi.ldap.read.timeout=60000 -Dcom.sun.jndi.ldap.connect.pool.timeout=30000 -Dcom.sun.jndi.ldap.connect.timeout=10000"
JAVA_OPTS="$JAVA_OPTS -Dnetworkaddress.cache.ttl=60 -Doracle.net.CONNECT_TIMEOUT=10000 -Djava.util.prefs.syncInterval=2000000"
JAVA_OPTS="$JAVA_OPTS -Duser.timezone=-05:00 -Duser.language=en -Duser.region=US"
JAVA_OPTS="$JAVA_OPTS -Dapp.environment=dist"
JAVA_OPTS="$JAVA_OPTS -Dhttp.url=localhost:8080"
JAVA_OPTS="$JAVA_OPTS -Dorg.apache.jackrabbit.repository.home=/opt/docstore -Dorg.apache.jackrabbit.repository.conf=/opt/docstore/repository.xml"
OLE Server Installation
Software Checkout
Checkout the software from the OLE SVN repository into a local working directory:
svn co
<A href="https://svn.kuali.org/repos/ole/trunk/ole/" mce_href="https://svn.kuali.org/repos/ole/trunk/ole/" target="_Blank">https://svn.kuali.org/repos/ole/trunk/ole/</A>
<local working directory>
This will checkout a copy of the current distribution onto your machine for local configuration.
Modification of impex-build.properties
Change to the home directory of the installation user (cd ~) and create an impex-build.properties file and add the following options(only options in <> need to be provided):
For Oracle Installations:
import.torque.database.user=<database username>
import.torque.database.schema=<schema name>
import.torque.database.password=<password>
torque.project=ole
torque.schema.dir=<local working directory>/ole-cfg-dbs/rice
torque.output.dir=${torque.schema.dir}
torque.schema.dir.2=<local working directory>/ole-cfg-dbs/development
torque.output.dir.2=${torque.schema.dir.2}
import.torque.database=oracle
import.torque.database.driver = oracle.jdbc.OracleDriver
import.torque.database.url = jdbc:oracle:thin:@<hostname>:<port>:<SID>
post.import.liquibase.project=ole
post.import.liquibase.xml.directory=<local working directory>/work/db/rice-data
For MySQL Installation:
import.torque.database.user=<database username>
import.torque.database.schema=<schema name>
import.torque.database.password=<password>
torque.project=ole
torque.schema.dir=<local working directory>/ole-cfg-dbs/rice
torque.output.dir=${torque.schema.dir}
torque.schema.dir.2=<local working directory>/ole-cfg-dbs/development
torque.output.dir.2=${torque.schema.dir.2}
import.torque.database=mysql
import.torque.database.driver=com.mysql.jdbc.Driver
import.torque.database.url=jdbc:mysql://<host address>:3306/<db name>
post.import.liquibase.project=ole
post.import.liquibase.xml.directory=/opt/ole-src/work/db/rice-data
Run Impex Script
Change directory to <local working directory>/ole-cfg-dbs/db-impex/impex
Run the Ant build: ant import
This will run the impex script, creating the OLE/Rice/KFS schemas and initial importing of data.
Modify dist-build.properties
Change directory to the local working directory and edit the dist-build.properties file. Modify the following entries (no <>).:
user.home=<local working directory> i.e. user.home=/opt/ole-src
appserver.url=<application server url>
rice.url=http://<rice host url>/ole-<build environment>
deploy.working.directory=<local working directory>
build.environment=<name of environment i.e. dist or dev or test>
For Oracle
datasource.url=jdbc:oracle:thin:@jdbc:oracle:thin:@<hostname>:<port>:<SID>
For MySQL
datasource.url= jdbc:mysql://<host address>:3306/<db name>
datasource.username=<db username>
datasource.password=<db password>
For Oracle
rice.server.datasource.url=jdbc:oracle:thin:@jdbc:oracle:thin:@<hostname>:<port>:<SID>
For MySQL
rice.server.datasource.url= jdbc:mysql://<host address>:3306/<db name>
rice.server.datasource.username=<db username>
rice.server.datasource.password=<db password>
ole.docstore.url=http://<docstore url>/ole-docsearch/
ole.docstoreapp.url=http://<docstore url>/oledocstore/document
ole.bibeditor.url=http://<ole server url>/ole-demo/bibEditor
ole.bibeditor.create.url=http://<ole server url>/ole-demo/bibEditor
ole.docsearch.url=http://<docstore url>/ole-docsearch/bib/select
ole.docsearch.app.url=http://<docstore url>/ole-docsearch/
There will be other entries in the file that do not require local modification.
Build War File
From the local working directory, enter the following command:
ant -propertyfile ./dist-build.properties clean-project dist dist-external
This will create the ole war file ole-<build.enviroment>.war in the local working directory. It will also create three configuration files:
skel.zip
settings.zip
security.zip
Zip Files
The three zipfiles need to be unpacked. Copy the following into a shell script and execute. The lines may need to be changed to meet local requirements, but will unpack the files into the location OLE is expecting to find the various configuration options*. INSTANCE must match the build.enviroment option in the dist-build.properties file.*
INSTANCE=<build environment>
mkdir -p /opt/sa_forms/java/${INSTANCE}/olemkdir -p /opt/j2ee/${INSTANCE}/ole
mkdir -p /opt/logs/${INSTANCE}/ole
mkdir -p /opt/work/${INSTANCE}/ole
# changing the owner so that tomcat can read/write these directories
chown -R tomcat /opt/sa_forms
chown -R tomcat /opt/j2ee
chown -R tomcat /opt/logs
chown -R tomcat /opt/work
# Unpacking as tomcat for proper permissions
sudo -u tomcat unzip -o skel.zip -d /opt/work/${INSTANCE}/olesudo -u tomcat unzip -o security.zip -d /opt/sa_forms/java/${INSTANCE}/ole
sudo -u tomcat unzip -o settings.zip -d /opt/j2ee/${INSTANCE}/ole
Copy war file
Copy the ole-<build.environment>.war to your local Tomcat webapps directory for deployment.
Restart Tomcat">Restart Tomcat
Restart Tomcat and the OLE application should be available at http://<application url>:<port>/ole-<build environment>