The latest stable patch release of KOLE is 1.5.2 version released on Aug 4th, 2014. The table below highlights some of the differences in the 1.5.0 and the consecutive patch versions.
Version | SVN Location | Notes |
---|---|---|
1.5.0 | https://svn.kuali.org/repos/ole/tags/ole-1.5.0/ | This was the first 1.5.0 stable tag, but wasn't deemed to be "Go live" version by Chicago/Lehigh |
1.5.1 | https://svn.kuali.org/repos/ole/tags/ole-1.5.1/ | This is a "Go Live" version for Lehigh with solr 3.6 |
1.5.2 | https://svn.kuali.org/repos/ole/tags/ole-1.5.2/ | This is a "Go Live" version for Chicago with Solr 4.9. The major difference was in the performance of solr on a huge data volume. |
1.5.2.1 | https://svn.kuali.org/repos/ole/tags/ole-1.5.2.1/ | This is an intermediate critical-patch fix on 1.5.2 which was critical for Chicago. |
1.5.3 | https://svn.kuali.org/repos/ole/tags/ole-1.5.3/ | This is be the final "GO LIVE" version for Chicago university. |
1.5.3.1 | COMING SOON | Intermediate patch release before 1.5.4 to fix some critical performance issues regarding 1. Editing a big with large number of items 2. Generation of overdue notices. |
The guide below will describe in as much detail as possible the process of building one of the 1.5 tags and database migration processes for in between versions.
- Pre-requisites:
- Hardware: Kuali OLE can be built on both windows and linux platforms. The hardware specs will differ from institution to institution, but the default cloud settings where the codebase is deployed on a regular basis is as follows;
- Amazon EC2 instance (type m1.medium)
- AMD 64 bit
- Dual core
- 7.5 GB RAM
- 840 GB HDD
- Amazon EC2 instance (type m1.medium)
- Software:
- Building the application
- Maven 3
- Java 7
- svn client
- Running the application
- Apache tomcat 6 or 7
- MySQL 5.5 or greater
or Oracle 11g
Database drivers
Don't forget to add the database drivers either MySQL or Oracle to the lib folder under tomcat.
- Building the application
- Hardware: Kuali OLE can be built on both windows and linux platforms. The hardware specs will differ from institution to institution, but the default cloud settings where the codebase is deployed on a regular basis is as follows;
- Checking out the deployable units: Depending on how you intend to run KOLE you can do the following;
- Install defaults and deploy the war(s): This is recommended for those who simply want to get the application up and running with the default data.
- Checkout the olefs.war from:http://shrub.appspot.com/maven.kuali.org/release/org/kuali/ole/olefs-webapp/${version.number}/olefs-webapp-${version.number}.war (Rename it olefs.war before deploying)
- Checkout the oledocstore.war from:http://shrub.appspot.com/maven.kuali.org/release/org/kuali/ole/ole-docstore-webapp//${version.number}/ole-docstore-webapp-${version.number}.war (Rename oledocstore.war before deploying)
- Customize the build: This is ideal for implementors or others who want to start with a base OLE (without defaults) and then add their data.
- Checkout the codebase from https://svn.kuali.org/repos/ole/tags/${tag.number}; Here tag.number is either 1.5 or 1.5.1 or 1.5.2
- Build it using the following maven command from the root directory of the project location i.e OLE_DEVELOPMENT_WORKSPACE_ROOT
- The above command will output two war files under
- ${project.root.location}/ole-app/olefs/target/olefs.war
- ${project.root.location}/ole-docstore/ole-docstore-webapp/target/oledocstore.war
- Install defaults and deploy the war(s): This is recommended for those who simply want to get the application up and running with the default data.
- Loading local data (institution specific): This applies only if you are doing step 2.b.ii
- If you want to load your own values for the various reference tables, you will need to first populate them as per the documentation at Impex, Bootstrap, Demo and Local Data (points #7, #8, #9 b or #9 c). Once the data has been made available in .csv files under the appropriate folder, run the following maven commands to output the sql that we will later use to load the database with. The process automatically takes care of generating the right sql for MySQL and Oracle
- This will generate sql for the data files that you have which the ole build process can later use while setting up the database.
- To load the institution specific data after the above executions, execute the following command:
- If you want to load your own values for the various reference tables, you will need to first populate them as per the documentation at Impex, Bootstrap, Demo and Local Data (points #7, #8, #9 b or #9 c). Once the data has been made available in .csv files under the appropriate folder, run the following maven commands to output the sql that we will later use to load the database with. The process automatically takes care of generating the right sql for MySQL and Oracle
- Customizing default parameters
- If you are running on a local server where access via localhost is sufficient for local testing, then there is no need to customize the defaults.
- For those who want to make the application available to the external public will need to override few defaults. Detailed information is available at OLE externalizable parameters and pay attention to the entries in common-config.xml. An example is provided here (DEV environment)
- Deploying to the server:
- Once you have the final deployable artifacts olefs.war and oledocstore.war; you can place it in your app server and restart.
- Testing the application
- To access the web apps, http://[host]/olefs and http://[host]/oledocstore should bring the apps up; Ofcourse this is assuming you have two deployables in one single instance.
- Upgrades: When upgrading if there are any database changes, they can easily be applied after the above steps have completed.
- Upgrade sql: Depending on which version you are working on, the location is ${SVN.LOCATION}/ole-app/ole-db/ole-sql/ole-liquibase-upgrade-sql/src/main/resources/org/kuali/ole/sql/mysql/
- There is mysql and oracle folders with the respective sql.
You can take the sql and manually apply it on your database.
Remember
The sql will have some "DATABASECHANGELOG" statements which you can ignore and execute the rest.