07 March 2024
Resource Sharing
Grid Management Service Infrastructure
There are numerous ways for different systems/applications/groups to share the same pool of servers (in a development or production environment) on the network. A non-exhaustive list of some of the options is:
-
Outside of GigaSpaces: Dedicated hardware for each group, where each set of servers runs an independent GigaSpaces runtime environment (Service Grid) without sharing the same server between different groups. This naive approach is good for simple or temporary scenarios. When using this option, each GigaSpaces runtime environment is isolated from the others using different GS_LOOKUP_LOCATORS or different GS_LOOKUP_GROUPS value.
-
Using Multiple Zones: A single GigaSpaces runtime environment spans all servers, where each group of GigaSpaces containers (across several machines) is labeled with a specific Zone. Multiple Zones can used by different containers on the same server. For example, server A has two containers labeled zoneX and four containers labeled zoneY, and server B has two containers labeled zoneX and four containers labeled zoneY. At deployment time, application services (Processing Units) are deployed using a specific Zone. This instructs the system to provision the services into the corresponding containers. Using multiple Zones breaks the runtime environment into different logical segments.
-
Using Multiple Lookup Groups (multicast lookup discovery): All servers run multiple GigaSpaces runtime environments, where each GigaSpaces container uses a specific lookup group when registering with the Lookup Service. At deployment time, application services (Processing Units) are deployed using a specific lookup group. Using multiple lookup group breaks the infrastructure into different logical segments. The Lookup Group value is controlled via the
GS_LOOKUP_GROUPS
environment variable. When using this option, ensure that multicast is enabled on all machines. -
Using Multiple Lookup Locators (unicast lookup discovery): All servers run multiple GigaSpaces runtime environments, where each GigaSpaces container uses a specific lookup locator when registering with the Lookup Service. At deployment time, application services (Processing Units) are deployed using a specific lookup locator. Using multiple lookup locators breaks the infrastructure into different logical segments. If you have multiple lookup services running on the same server, each will use a different listening port. You can control this port using the
com.sun.jini.reggie.initialUnicastDiscoveryPort
system property. The Lookup Locators value is controlled via theGS_LOOKUP_LOCATORS
environment variable. -
Using a shared GigaSpaces runtime environment: A single GigaSpaces runtime environment spans all servers, with no use of Zones or Lookup Groups/Locators. Application services share the servers and allocation done in a random manner, without using any pre-defined segmentation.
For any of the above options, GigaSpaces exposes the ability to control a deployed application service in runtime, so that new application service instances can be created or existing instances can be relocated. This tight operational control enables even more creative resource-sharing possibilities.
When devising the appropriate resource sharing strategy for your system, consider the breadth of operational requirements and application service characteristics. For example, it may be problematic to run two applications with variable load on a fixed-size shared environment if peak loads coincide.
GigaSpaces provides consultancy services for the environment-planning stage that addresses the above, as well as other considerations that affect your environment. For more information, refer to GigaPro Services