LiveCycle ES 8.2 comes with a new distributed cache from Gemstone called Gemfire. Here’s a press release from Gemstone in this regard. In cluster deployments, it is critical that all members of a LiveCycle cluster be able to find one another so that they can keep their individual caches in synch with one another.
Members of a LiveCycle cluster find one another using IP multicasting. UDP is simpler to configure than TCP because TCP requires that you run an additional TCP Locator service. However, UDP has limitations of its own, especially when cluster members are not all in the same IP subnet.
Please note that once cluster members “discover” one another, they establish peer-to-peer sockets with one another and communicate using TCP. Therefore, if the TCP locator service goes down, LiveCycle will not stop working. However, cluster member arrivals and departures will not be communicated to all of the cluster members until the TCP locator service is re-started.
To over-ride the default IP address used by Gemfire, a JVM argument can be used. The following example sets the address a well as the port (35001):
For guidelines from Cisco about allocating IP Multicast addresses, see here. The most restrictive (“Site-Local Scope”) is the range 22.214.171.124 to 126.96.36.199
To verify that the cache is working, navigate to the LiveCycle Temporary Folder (configured using the LiveCycle Configuration Manager and later on changeable via the LiveCycle Admin UI) and open Gemfire.log. In WebSphere, the path will be:
If the cache is working, you should see entries such as these:
GemFire P2P Listener started on tcp:///10.10.20.22:41585
Starting distribution manager aix1:62840/41585
Initial (membershipManager) view = [aix2:42282/35386, aix1:62840/41585]
admitting member ; now there are 1 non-admin member(s)
admitting member ; now there are 2 non-admin member(s)
In environments were UDP does not work, TCP has to be used. Copy the folder %LIVECYCLE_INSTALL_ROOT%\lib\caching\ and its contents to at least two of the horizontal cluster members. If only one TCP Locator instance is run, it will become a single point of failure. Edit and then run startlocator.bat (or startlocator.sh in Unix) so that the last line looks something as follows:
java -cp .\gemfire.jar com.gemstone.gemfire.internal.SystemAdmin start-locator -port=22345 -Dgemfire.license-type=production -Dlocators=node1.company.com
where 22345 is the port specified by you while running LiveCycle Configuration Manager (LCM) and added as a JVM argument
Before you run the startlocator batch/sh file, make sure that there are no files named .locator or PID_file in that folder. If they exist, delete them first.
In 64-bit Windows environments, edit and use the file startlocator_win64.bat
See the LiveCycle clustering guides for more details.