Sunday, March 13, 2011

How to Deploy WSO2 ESB 3.2.x and above in Apache Tomcat

All WSO2 products are recommended to be deployed as stand alone servers and  we have stop supporting deploying on other 3rd party appservers from the latest releases.

In this blog post I will walk through on how you deploy Apache Tomcat 6.x.x with the new ESB which could be downloaded here. Also note that this blog will be valid from ESB 3.2.x.

Step 1
Extract the downloaded ESB to a desired location. The home directory will now be known as $ESB_HOME from here onwards.

Step 2
Extract Apache Tomcat 6.x.x to the required location which now will be known as $CATALINA_HOME. Downloadable here.

Step 3
Create a 'esb' folder within $CATALINA_HOME/webapps and copy WEB_INF folder which exists in $ESB_HOME/lib/core. You may also copy log4j.properties in $ESB_HOME/lib in to $CATALINA_HOME/webapps/esb/WEB-INF/classes to facilitate logging.

Step 4
Also copy repository and resources folders from $ESB_HOME and create a separate folder 'esb_repo' and copy them in.

From here onwards there requires some configuration tuning for them to work together.

Step 5
Edit $CATALINA_HOME/conf/server.xml to entertain https ports. Note that path of the esb_repo should be as for your location.

<connector port="8443" maxhttpheadersize="8192" maxthreads="150" minsparethreads="25" maxsparethreads="75" enablelookups="false" disableuploadtimeout="true" acceptcount="100" scheme="https" secure="true" sslenabled="true" clientauth="false" sslprotocol="TLS" keystorefile="/esb_repo/repository/resources/security/wso2carbon.jks" keystorepass="wso2carbon">

Step 6
Now we have to complete necessary changes in 'esb_repo' to start successfully
axis2.xml (esb_repo/repository/conf)

Go to the TransportListener and TransportSender section which uses org.apache.synapse.transport.nhttp.HttpCoreNIOSSLListener and change the keystore and truststore absolute paths as per accordingly. Remeber to change this in both TransportListener and TransportSender.

<parameter name="keystore" locked="false">
</parameter></connector>
/esb_repo/repository/resources/security/wso2carbon.jks<connector port="8443" maxhttpheadersize="8192" maxthreads="150" minsparethreads="25" maxsparethreads="75" enablelookups="false" disableuploadtimeout="true" acceptcount="100" scheme="https" secure="true" sslenabled="true" clientauth="false" sslprotocol="TLS" keystorefile="/esb_repo/repository/resources/security/wso2carbon.jks" keystorepass="wso2carbon"><parameter name="keystore" locked="false"><keystore><location></location>
<type>JKS</type>
<password>wso2carbon</password>
<keypassword>wso2carbon</keypassword>
</keystore>
</parameter>
<parameter name="truststore" locked="false">
<truststore>
<location>/esb_repo/repository/resources/security/client-truststore.jks</location>
<type>JKS</type>
<password>wso2carbon</password>
</truststore>
</parameter>

Also change the synapse_config directory absolute path accordingly.
<parameter name="SynapseConfig.ConfigurationFile" locked="false">/esb_repo/repository/deployment/server/synapse-configs</parameter>

Carbon.xml
You may find this file in the same location as per axis2.xml.
Change the Server_URL, WebContextRoot and RegistryHttpPort configurations as per follows

<serverurl>https://localhost:8443/esb/services/</serverurl>

<webcontextroot>/esb</webcontextroot>

<registryhttpport>8080</registryhttpport>

registry.xml
Change the necessary db url to absolute paths as per follows;
<url>jdbc:h2:/esb_repo/repository/database/WSO2CARBON_DB;DB_CLOSE_ON_EXIT=FALSE</url>

user-mgt.xml
Change the necessary db url property to absolute paths as per follows;
<property name="url">jdbc:h2:/esb_repo/repository/database/WSO2CARBON_DB;DB_CLOSE_ON_EXIT=FALSE</property>

Now we are done with the configurations :)

- Go ahead and declare the CARBON_HOME in a console;

export CARBON_HOME=/esb_repo

Start apache tomcat by cd'ng to $CATALINA_HOME/bin and using
./catalina.sh run

Upon starting the WSo2 ESB you can access the console with the server URL https://localhost:8443/esb/services/

Post in any comments if there are problems if you find any in deploying. Best of Luck!