04 December 2022
Processing Unit
GigaSpaces allows to configure, package and deploy a Processing Unit. The OpenSpaces Mule integration allows you to run a pure Mule application (with or without OpenSpaces special extension points and transports) as a Processing Unit.
Configuration
In order to run Mule as a Processing Unit within the pu.xml
file (which is a Spring application context), the following needs to be defined:
<bean class="org.openspaces.esb.mule.pu.OpenSpacesMuleContextLoader">
<property name="location" value="/META-INF/spring/mule.xml"/>
</bean>
In the example above, the OpenSpacesMuleContextLoader
loads a Mule application as defined in the mule.xml
configuration file. The location
parameter is optional and defaults to the value specified in the example above.
Packaging
Packaging of the Processing Unit should follow the Processing Unit structure.
When deploying a Processing Unit into the SLA-driven container, Mule JAR files should be "installed" into the GigaSpaces installation (on each node). The following minimum set of JARs need to be copied into $GS_HOME\lib\platform\mule
(if the Mule directory does not exists, create it).
-
Download Mule 3.7 distribution from mule's website and extract the file.
-
Copy the following JAR files from
<Mule Root>\lib\mule
to$GS_HOME\lib\platform\mule
:mule-commons
,mule-core
,mule-core-tests
,mule-module-annotations
,mule-module-client
,mule-module-jbossts
,mule-module-spring-config
,mule-module-spring-extras
,mule-mvel2-2.1.9-MULE-003
,mule-transport-http
,mule-transport-quartz
,mule-transport-stdio
,mule-transport-vm
. Other transports (if used) should be copied as well. -
Copy the following JAR files from
<Mule Root>\lib\opt
to$GS_HOME\lib\platform\mule
:commons-beanutils
,commons-io
,commons-lang
,dom4j
,guava
,jaxen
,quartz
,uuid
,jgrapht-jdk1.5
. Other required JAR files can be copied as well (or they can be put in the Processing Unitlib
directory). -
Copy the following JAR files from
<Mule Root>\lib\boot
to$GS_HOME\lib\platform\mule
:commons-cli
,log4j
,mule-module-logging
,wrapper
. Other required JAR files can be copied as well (or they can be put in the Processing Unitlib
directory).
The required mule jar files can also be placed within the processing unit lib
directory, without "installing" mule into each GSC node installation.
Packaging for Mule example
In the Mule ESB example, the following jars are required and should be placed under $GS_HOME\lib\platform\mule
commons-beanutils-1.8.0.jar
commons-cli-1.2.jar
commons-io-1.4.jar
commons-lang-2.4.jar
dom4j-1.6.1.jar
guava-16.0.1.jar
jaxen-1.1.1.jar
jgrapht-jdk1.5-0.7.3.jar
log4j-1.2.16.jar
mule-common-3.7.0.jar
mule-core-3.7.0.jar
mule-core-3.7.0-tests.jar
mule-module-annotations-3.7.0.jar
mule-module-client-3.7.0.jar
mule-module-jbossts-3.7.0.jar
mule-module-logging-3.7.0.jar
mule-module-spring-config-3.7.0.jar
mule-module-spring-extras-3.7.0.jar
mule-mvel2-2.1.9-MULE-003.jar
mule-transport-http-3.7.0.jar
mule-transport-quartz-3.7.0.jar
mule-transport-stdio-3.7.0.jar
mule-transport-vm-3.7.0.jar
quartz-1.8.5.jar
uuid-3.4.0.jar
wrapper-3.2.3.jar
Running/Deploying
Once the Processing Unit is packaged, it can be run using the different options that come with OpenSpaces: