Again, in eXo Platform 4, cluster mode is currently supported for JBoss only, so this guideline should not be applied for Tomcat.
Typical configuration can be done all in two files: standalone-exo-cluster.xml and
exo.properties
. Besides:
UDP is the default configuration, instead of TCP.
Job Persistence for Quartz is pre-configured, you just need to activate it by the property org.quartz.properties.
Install Platform JBoss package by following Installing JBoss EAP.
Create a copy of the package for each cluster node. Assume that you have two nodes: node1.your-domain.com and node2.your-domain.com.
Configure IDM, JCR and Quartz datasources:
Use the same databases for all nodes.
Follow Database chapter, but note that the configuration
file is standalone-exo-cluster.xml
(instead of standalone-exo.xml
).
In cluster mode, there is a datasource of which JNDI name is exo-quartz
that you can find in the file.
Initiate the Quartz database.
Use an appropriate SQL script to create tables in the database that you configured for exo-quartz
.
The scripts are packaged in standalone/configuration/gatein/quartz/dbTables
.
Set org.quartz.properties
in standalone/configuration/standalone-exo-cluster.xml
:
<sytem-properties>
<property name="org.quartz.properties" value="standalone/configuration/gatein/quartz/quartz.properties"/>
</system-properties>
If you changed the default name exo-quartz
in previous step, you must match it in quartz.properties
.
Share a folder on the network that can be accessed from all nodes.
Assuming that the folder path is: /mnt/nfs/shared/data
, edit the system property
exo.shared.dir
in the standalone-exo-cluster.xml
file:
<system-properties>
<property name="exo.shared.dir" value="/mnt/nfs/shared/data"/>
</system-properties>
Edit exo.cluster.node.name
in standalone-exo-cluster.xml
. The default:
<system-properties>
<property name="exo.cluster.node.name" value="exo-node1"/>
</system-properties>
Use a different name for each node. If you do not want to configure this for every node, you can set it later by appending this to the start command:
-Dexo.cluster.node.name=node-x
Set bind_addr
to the node IP, in standalone/configuration/gatein/exo.properties
(for this file, see Configuration overview).
For example:
exo.jcr.cluster.jgroups.udp.bind_addr=192.168.1.100 exo.idm.cluster.jgroups.udp.bind_addr=192.168.1.100
Configure CometD Oort URL in standalone-exo-cluster.xml
.
You will need to uncomment the following line and replace localhost with the IP or host name of the node.
<property name="exo.cometd.oort.url" value="http://localhost:8080/cometd/cometd"/>
CometD is used to perform messaging over the web, and Oort is a CometD extension that supports clustering. The configuration is necessary to make the On-site Notification work properly.
Configure CometD group port in standalone-exo-cluster.xml
. This step is optional.
CometD Oort nodes will automatically join others in the same network and the same group,
so to prevent stranger nodes from joining your group, you might specify your group with a port
that is different from the default port (5577
).
The situation is likely to happen in a testing environment.
<!-- Configure the same port for all nodes in your cluster -->
<property name="exo.cometd.oort.multicast.groupPort" value="5579"/>
Start the servers.
Start node1:
./bin/standalone.sh -b 0.0.0.0 -c standalone-exo-cluster.xmlWait until node1 is fully started, then start node2:
./bin/standalone.sh -b 0.0.0.0 -c standalone-exo-cluster.xmlOn Windows, replace standalone.sh with standalone.bat.
Some other options that you can use in the start command:
-Dorg.quartz.properties=path/to/quartz.properties overrides the path in the configuration file.
-Dexo.cluster.node.name=a-node-name overrides the node name in the configuration file.
-Djboss.socket.binding.port-offset=101
This is useful in case you set up nodes in the same machine for testing. You will not need to configure the port for every node. Just use different port-offset in each start command.
To configure a front-end for your nodes, follow Setting up Apache front-end.
To configure load balancing, follow Setting up mod_jk.