This chapter describes the recommended procedure for upgrading to JasperReports Server 6.4 from version 6.3. The examples show you how to upgrade using the js-upgrade shell scripts.
This chapter contains the following sections:
• | Upgrade Steps Overview |
• | Upgrading with Customizations |
• | Back Up Your JasperReports Server Instance |
• | Preparing the JasperReports Server 6.4 WAR File Distribution |
• | Configuring Buildomatic for Your Database and Application Server |
• | Upgrading to JasperReports Server 6.4 |
• | Starting and Logging into JasperReports Server6.4 |
• | Additional Tasks to Complete the Upgrade |
• | Old Manual Upgrade Steps: 6.3 to 6.4 |
Upgrade Steps Overview
These are the general steps used in this section:
1. | Identify your customizations. |
2. | Back up your current JasperReports Server instance. |
3. | Download and set up the new 6.4 JasperReports Server WAR file distribution zip. |
4. | Run the js-upgrade script as described in Upgrading to JasperReports Server 6.4. |
If your current instance of JasperReports Server has modifications or extensions, keep track of these and re-integrate them into your 6.4 instance after upgrading.
Upgrading with Customizations
If your current instance of JasperReports Server has modifications or extensions, keep track of these and re-integrate them into your 6.4 instance after upgrading. See Planning Your Upgrade to determine if any customizations you've made to your existing version of JasperReports Server are affected by changes to the updated version.
Back Up Your JasperReports Server Instance
First back up your JasperReports Server WAR file and jasperserver database so you can restore them if necessary. Perform these steps from the command line in a Windows or Linux shell.
This backup example is for Tomcat with the PostgreSQL or MySQL database. For other databases, consult your DB administration documentation for backup information.
Back up your JasperReports Server War File:
1. | Create a folder where you can save your jasperserver war file. For example, C:JS_BACKUP or /opt/JS_BACKUP. |
2. | Copy <tomcat>/webapps/jasperserver to <path>/JS_BACKUP |
Back up your jasperserver Database:
1. | Create a folder (if you did not do so in the step above) where you can save your jasperserver database, For example, C:JS_BACKUP or /opt/JS_BACKUP. |
2. | Run the following commands for PostgreSQL or MySQL: |
• | PostgreSQL |
cd <path>/JS_BACKUP
pg_dump --username=postgres jasperserver > js-db-dump.sql
• | MySQL |
cd <path>/JS_BACKUP
Windows: | |
Linux: |
For MySQL, If you receive an error about packet size, see the Troubleshooting appendix of the JasperReports Server Community Project Installation Guide. |
Preparing the JasperReports Server 6.4 WAR File Distribution
Use the buildomatic js-upgrade scripts included in the 6.4 WAR file distribution ZIP release package to carry out the upgrade. The WAR file distribution comes in a compressed ZIP file named TIB_js-jrs_cp_6.4.0_bin.zip.
Follow these steps to obtain and unpack the WAR file distribution ZIP file:
1. | Download the WAR file distribution from (http://community.jaspersoft.com). |
2. | Extract all files from TIB_js-jrs_cp_6.4.0_bin.zip. Choose a destination, such as a C:Jaspersoft folder on Windows, /home/<user> on Linux, or /Users/<user> on Mac. |
After you unpack the WAR File Distribution, the resulting location will be known as:
<js-install-6.4>
Configuring Buildomatic for Your Database and Application Server
This upgrade procedure uses the js-upgrade-samedb-ce shell script.
For Unix, the bash shell is required for the js-upgrade scripts. If you're installing to a non-Linux Unix platform such as HP-UX, IBM AIX, FreeBSD or Solaris, you need to download and install the bash shell. See the Troubleshooting appendix of the JasperReports Server Community Project Installation Guide for more information. |
This section shows example configurations for the PostgreSQL and MySQL databases.
Example Buildomatic Configuration
The default_master.properties file handles the upgrade configuration. We provide a sample configuration file for each database. You must specify your database credentials and application server location, and rename the file to default_master.properties.
PostgreSQL Example
To configure default_master.properties for PostgreSQL:
1. | Locate the postgresql_master.properties sample configuration file: |
Database | Master Properties File |
PostgreSQL | <js-install-6.4>/buildomatic/sample_conf/postgresql_master.properties |
2. | Copy the file to <js-install-6.4>/buildomatic |
3. | Rename the file default_master.properties |
4. | Edit default_master.properties for your database and application server: |
Database | Sample Property Values |
PostgreSQL | appServerType=tomcat6 [tomcat7, jboss, glassfish2, glassfish3]appServerDir=c:Apache Software FoundationTomcat 7dbUsername=postgresdbPassword=postgresdbHost=localhost[/code] |
MySQL Example
To configure default_master.properties for MySQL:
1. | Locate the mysql_master.properties sample configuration file: |
Database | Master Properties File |
MySQL | <js-install-6.4>/buildomatic/sample_conf/mysql_master.properties |
2. | Copy the file to <js-install-6.4>/buildomatic |
3. | Rename the file default_master.properties |
4. | Edit default_master.properties for your database and application server. |
Database | Sample Property Values |
MySQL | appServerType=tomcat6 [tomcat7, jboss, glassfish2, glassfish3]appServerDir=C:Apache Software FoundationTomcat 7dbUsername=rootdbPassword=passworddbHost=localhost[/code] |
Upgrading to JasperReports Server 6.4
Now that your buildomatic scripts are configured, you can complete the upgrade.
Make sure you've backed up your jasperserver database before proceeding. Make sure you've backed up your old JasperReports Server WAR file before proceeding. |
1. | Stop your application server |
2. | Start your database server |
3. | Run the following commands: |
Commands | Description |
cd <js-install-6.4>/buildomatic |
|
js-upgrade-samedb-ce.bat | (Windows) Upgrade jasperserver war file, upgrade jasperserver database to 6.4, add 6.4 repository resources into the database |
./js-upgrade-samedb-ce.sh | (Linux) Upgrade jasperserver war file, upgrade jasperserver database to 6.4, add 6.4 repository resources into the database |
js-upgrade Test Mode
Use the test option to run the js-upgrade script in test mode. For example, on Windows, enter:
cd <js-install-6.4>/buildomatic
js-upgrade-samedb-ce.bat test
In test mode, the js-upgrade scripts check your default_master.properties settings and validate your application server location and its ability to connect to your database. Test mode can help you debug issues like an incorrect database password without altering your system.
Output Log Location
The js-upgrade script creates an output log that captures both standard and error output. If problems occur during script execution, or you just want to remember which options you chose, open the output log file located here:
<js-install-6.4>/buildomatic/logs/js-upgrade-<date>-<number>.log
Errors
If you encounter errors running the js-upgrade script, first look at the output log to see if you can spot the errors. For help, refer to the Troubleshooting appendix of the JasperReports Server Community Project Installation Guide. The information in this appendix applies to both js-upgrade scripts and js-install scripts.
If you need to modify values in your default_master.properties file, you can simply edit the file. When you run the js‑upgrade script again, it uses the new values.
Starting and Logging into JasperReports Server6.4
Start your application server. Your database should already be running.
Clearing Your Browser Cache
Before you log in, make sure you and your end users clear the browser cache. JavaScript files, which enable the UI elements of JasperReports Server, are typically cached by the browser. Clear the cache to ensure that the newer files are used.
Logging into JasperReports Server
Log in using the following URL, user IDs, and passwords:
URL: http://localhost:8080/jasperserver
User ID | Password | Description |
Administrator for the default organization |
Your JasperReports Server instance has now been upgraded to 6.4. If you have startup or login problems, refer to the Troubleshooting appendix of the JasperReports Server Community Project Installation Guide.
Additional Tasks to Complete the Upgrade
Perform these tasks with the application server shutdown.
Handling JasperReports Server Customizations
If you made modifications to the original JasperReports Server application, these configurations are typically found in the WEB-INF/applicationContext-*.xml set of files.
You'll need to manually copy configuration changes, like client-specific security classes or LDAP server configurations, from your previous environment and integrate them with your upgraded environment.
Clearing the Application Server Work Folder
Application servers have work folders where JasperReports Server files are compiled and cached and other objects are stored. When you update the WAR file, the buildomatic deploy-webapp-ce target should automatically clear the application server’s work directory, but it’s a good practice to double-check. A permission problem, or some other problem, could prevent the clearing of the work folder.
To clear the work folder in Tomcat:
1. | Change directory to <tomcat>/work. |
2. | Delete all the files and folders in this directory. |
Clearing the Application Server Temp Folder
JasperReports Server uses caching to speed operations within the application. Caching files are created and stored in the application server, usually in a temp folder. Clear this temp folder to avoid any post-upgrade conflicts. Typically, the temp folder used by an application server corresponds to the path referenced by the java.io.tmpdir Java system property. For Apache Tomcat the temp folder is <tomcat>/temp.
To clear the temp folder in Apache Tomcat:
1. | Change directory to <tomcat>/temp |
2. | Delete all the files and folders in this directory |
Clearing the Repository Cache Database Table
In the jasperserver database, compiled JasperReports Library resources are cached in the JIRepositoryCache table for increased efficiency at runtime. Because the JasperReports Library JAR is typically updated with each new release, old cached items can get out of date and cause errors at runtime. If you encounter errors that mention a JasperReports Library “local class incompatible,” check your repository cache table. In summary, you can clear your jasperserver database cache table as part of this upgrade process whether or not there are errors.
To manually clear the repository cache database table, run a SQL command similar to one shown below:
update JIRepositoryCache set item_reference = null;
delete from JIRepositoryCache;
Old Manual Upgrade Steps: 6.3 to 6.4
This section describes the older, manual upgrade steps used before we implemented the js-upgrade shell scripts in release 4.0. They're provided here mainly as a reference for internal use.
We recommend using the js-upgrade shell scripts described in the beginning of this chapter instead of these manual commands:
Commands | Description |
cd <js-install-6.4>/buildomatic |
|
js-ant upgrade-6.3-6.4-ce | Execute SQL script to upgrade database to 6.4. Execute script buildomatic/install_resources/sql/<dbType>/upgrade-<dbType>-6.3.0-6.4.0-ce.sql |
js-ant import-minimal-for-upgrade-ce | Load themes and other core resources for 6.4. Note: "import-minimal-for-upgrade" will import core resources in an "update" mode so that the older 6.3 core resources will be overwritten. Additionally, the "skip-user-update" option will be applied so that jasperadmin users will not have their passwords modified. |
js-ant import-sample-data-upgrade-ce | (Optional) Load the 6.4 sample data. |
js-ant deploy-webapp-ce | Delete old 6.3 war file, deploy the 6.4 war file. |
Recommended Comments
There are no comments to display.