Skip to content
This repository has been archived by the owner on Oct 18, 2018. It is now read-only.

Latest commit

 

History

History
257 lines (176 loc) · 7.42 KB

README.md

File metadata and controls

257 lines (176 loc) · 7.42 KB

Surfnet's Apache Rave Template

This is a minimal WAR overlay project to run Apache Rave at SURFnet. New features should preferably be generalized and contributed to Apache Rave.

Most of the instructions were written for a Unix (Linux, MacOS) operating system. Their equivalents should work on Microsoft Windows systems as well. For some steps specific instructions are given for Windows users.

Building

Building this template requires a git client, JDK version 6 or higher and that latest Apache Maven 3.0.

git clone git://github.com/OpenConextApps/OpenConextApps-rave-template.git
cd OpenConextApps-rave-template
mvn -P dist clean install

Running locally

After building this project, you can run it locally. Please perform the following steps in your OpenConextApps-rave-template directory:

cd coin-rave-portal-design
mvn cargo:start

And visit http://localhost:8080/portal/

Custom deploy on a server

Step 1 Build the Rave template

git clone git://github.com/OpenConextApps/OpenConextApps-rave-template.git
cd OpenConextApps-rave-template
mvn -P dist clean install

Step 2 Setup Tomcat 6.0

We recommend that you get Tomcat from your package manager. If this is not possible, install it yourself. In this manual we assume that tomcat is installed in /opt/tomcat.

At the time of writing 6.0.35 was the latest Tomcat 6.0 version. Please verify if there was not a newer release so you can use that one instead.

On Unix

As root:

wget http://archive.apache.org/dist/tomcat/tomcat-6/v6.0.35/bin/apache-tomcat-6.0.35.tar.gz
tar xvfz apache-tomcat-6.0.35.tar.gz
mkdir /opt
cp -r apache-tomcat-6.0.35 /opt/tomcat
groupadd tomcat
useradd tomcat -g tomcat
chown -R tomcat:tomcat /opt/tomcat

And add the tomcat to your services.

On Windows

Download the Tomcat installer and install it as a service.

Step 2.1 Copy the web application archives to tomcat.

You can find these in coin-rave-dist/target/coin-rave-dist-1.0-SNAPSHOT-bin.tar.gz. The files are called coin-rave-portal-dist-1.0-SNAPSHOT.war and coin-rave-shindig-1.0-SNAPSHOT.war.

mkdir -p /opt/tomcat/wars
cp coin-rave-portal-dist-1.0-SNAPSHOT.war /opt/tomcat/wars
cp coin-rave-shindig-1.0-SNAPSHOT.war /opt/tomcat/wars

Step 2.2 Add more memory to Tomcat.

The following step depends on whether you are using unix or windows.

On Unix

Create a file called /opt/tomcat/bin/setenv.sh with the following contents:

export JAVA_OPTS="$JAVA_OPTS -Xmx512m -XX:MaxPermSize=256m"

And make this file executable:

chmod +x bin/setenv.sh
On Windows

Create a file called bin/setenv.bat with the following contents:

@echo off
set JAVA_OPTS=%JAVA_OPTS% -Xmx512m -XX:MaxPermSize=256m

Step 2.3 Configure Rave

Create a directory for the properties files.

mkdir -p /opt/tomcat/conf/classpath_properties

Edit /opt/tomcat/conf/catalina.properties so that the common.loader also includes the /opt/tomcat/conf/classpath_properties directory.

common.loader=${catalina.home}/lib,${catalina.home}/lib/*.jar,${catalina.home}/conf/classpath_properties

Next, copy the files:

  • rave-shindig-container.js
  • rave.shindig.properties
  • rave-opensaml.properties
  • portal.properties

to /opt/tomcat/conf/classpath_properties.

You can find these files in OpenConextApps-rave-template/coin-rave-dist/src/main/resources/tomcat.

Edit all files so they match your server configuration, find every rave.example.com and rave-shindig.example.com and replace them with your own hostname.

Step 2.4 Add the shared libraries

Edit /opt/tomcat/conf/catalina.properties so that the shared.loader loads the libraries from the /opt/tomcat/shared/lib directory.

shared.loader=${catalina.home}/shared/lib,${catalina.home}/shared/lib/*.jar

Create the shared/lib directory:

mkdir -p /opt/tomcat/shared/lib

Next, copy the following three libraries to /opt/tomcat/shared/lib:

  • activation-1.1.jar
  • mail-1.4.4.jar
  • mysql-connector-java-5.1.20-bin.jar

The MySQL jar is available under GPL, which is incompatible with our Apache License. Therefore you need to install it by hand. You can find these files on the locations mentioned below.

cd /opt/tomcat/shared/lib
wget http://repo1.maven.org/maven2/javax/activation/activation/1.1/activation-1.1.jar
wget http://download.java.net/maven/2/javax/mail/mail/1.4.4/mail-1.4.4.jar
wget http://repo1.maven.org/maven2/mysql/mysql-connector-java/5.1.20/mysql-connector-java-5.1.20.jar

Step 2.5 Configure a MySQL Database

Create a database (for example "rave-portal") in MySQL and give a user access. Next, set the database name, user name and password in portal.properties and rave.shindig.properties.

For example:

/opt/tomcat/conf/classpath_properties/rave.shindig.properties:

rave-shindig.dataSource.url=jdbc:mysql://localhost:3306/ravedb
rave-shindig.dataSource.driver=com.mysql.jdbc.Driver
rave-shindig.dataSource.username=rave
rave-shindig.dataSource.password=SecretPassword123

/opt/tomcat/conf/classpath_properties/portal.properties:

portal.dataSource.url=jdbc:mysql://localhost:3306/ravedb?allowMultiQueries=true
portal.dataSource.driver=com.mysql.jdbc.Driver
portal.dataSource.username=rave
portal.dataSource.password=SecretPassword123

The allowMultiQueries=true is only needed to populate the database for the first time. When the project is fully setup and running, the value of this parameter can be set to false.

Step 2.6 Configure the hosts

Add the following host configuration to /opt/tomcat/conf/server.xml:

<Host name="rave.example.com" appBase="webapps/rave.example.com"/>
<Host name="rave-shindig.example.com" appBase="webapps/rave-shindig.example.com"/>

Create the directories /opt/tomcat/conf/Catalina/rave.example.com and /opt/tomcat/conf/Catalina/rave-shindig.example.com.

mkdir -p /opt/tomcat/conf/Catalina/rave.example.com
mkdir -p /opt/tomcat/conf/Catalina/rave-shindig.example.com

Create a file /opt/tomcat/conf/Catalina/rave.example.com/portal.xml. Please change the docBase parameter to the correct location.

<Context path="/portal" docBase="/opt/tomcat/wars/coin-rave-portal-dist-1.0-SNAPSHOT.war"/>

Create a file /opt/tomcat/conf/Catalina/rave-shindig.example.com/ROOT.xml. Please change the docBase parameter to the correct location.

<Context path="" docBase="/opt/tomcat/wars/coin-rave-shindig-1.0-SNAPSHOT.war"/>

Lastly, create the webapps directories.

mkdir -p /opt/tomcat/webapps/rave.example.com
mkdir -p /opt/tomcat/webapps/rave-shindig.example.com

Step 2.7 Make user "tomcat" the owner

As root execute:

chown -R tomcat:tomcat /opt/tomcat

Step 2.8 Start the server

On Unix systems

As user tomcat execute:

service tomcat start

On Windows systems

Open 'services' and start the service "Apache Tomcat 6.0 Tomcat6" (this is the default name and can differ on the values you entered during installation)

Step 3

Configure your webserver to forward to the tomcat application server. This is optional as you can connect directly to tomcat.