Adapter Grouping
Overview
Persistent Mobile Foundation adapters execute the server-side logic and the transfer or retrieval of data from back-end systems. Adapters are deployed on all the instances of Persistent Mobile Foundation runtime, adapters consume system resources irrespective of its usage. In a situation where some adapters are infrequently used by the mobile application, there exists no way to scale the Persistent Mobile Foundation instance only with the frequently used adapters. Scaling the environment results in all the adapters getting deployed and running on all the newly added nodes. This behavior results in a slow start-up of the Persistent Mobile Foundation instance as the runtime needs to deploy and run all the adapters.
The adapter grouping feature enables you to group a bunch of resource adapters and run them together on a set of Persistent Mobile Foundation nodes. This set of nodes is called a group. The group can be scaled by adding more nodes based on the adapter load. Customers can decide beforehand the number of nodes in each group based on the expected load reaching the adapters running in that group.
Adapter grouping is only supported for resource adapters and not for security check adapters.
Configuration
A group in adapter grouping is a collection of Persistent Mobile Foundation nodes to run a bunch of resource adapters on it. For example, in a farm topology with 10 nodes, customers can create three groups, Group 1 with 5 nodes (node 1, node 2, node 3, node 4, node 5), Group 2 with 3 nodes (node 6, node 7, node 8) and Group 3 with 2 nodes (node 9 , node 10).
The next section explains how to get adapter grouping to work with Persistent Mobile Foundation by defining an adapter group configuration and making the nodes a part of an adapter group. Two configuration changes need to be applied to Persistent Mobile Foundation to get adapter grouping to work.
Define and deploy adapter group configuration
Adapter group configuration defines groups and resource adapters that belong to the group. The adapter group configuration has the following structure and needs to be deployed using the Administration API.
{
"groups": [
{
"id": "finance",
"adapters": [
{
"name": "SavingAccountAdapter"
},
{
"name": "LoanProcessingAdapter"
}
]
},
{
"id": "hr",
"adapters": [
{
"name": "EmployeeInfoAdapter"
},
{
"name": "OnboardingAdapter"
}
]
}
]
}
Adapter group configuration defines adapter groups and the adapters that need to be part of those groups. The name of the adapter group is the value against the key id
. The adapters
key holds a value, which is a list of the resource adapters that will be deployed in the respective groups.
Listed below are the Administration APIs available for adapter group configuration.
Deploy Adapter Configuration
To deploy an adapter group configuration, use the following Persistent Mobile Foundation Administration API and provide the configuration parameters described above as a json payload.
POST http://<host>:<port>/mfpadmin/management-apis/2.0/runtimes/<runtime>/adapterGroupConfig
For example,
curl -X POST --user admin:admin --header 'Content-Type: application/json' -- header 'Accept: application/json' -d '{ "groups": [{ "id": "finance", "adapters":
[ {"name": "SavingAccountAdapter" }, {"name": "LoanProcessingAdapter"}] },{"id": "hr", "adapters": [ {"name": "EmployeeInfoAdapter"}, {"name": "OnboardingAdapter"}]}]}' "http://<host>:<port>/mfpadmin/management apis/2.0/ runtimes/mfp/adapterGroupConfig"
Retrieve Adapter Group Configuration
To get an already deployed adapter group configuration, use the following Persistent Mobile Foundation Administration API.
GET http://<host>:<port>/mfpadmin/management-apis/2.0/runtimes/<runtime>/adapterGroupConfig
For example,
curl -X GET --user admin:admin --header 'Content-Type: application/json' "http://<host>:<port>/mfpadmin/management-apis/2.0/runtimes/mfp/adapterGroupConfig"
Delete Adapter Group Configuration
To delete an already deployed adapter group configuration, use the following Persistent Mobile Foundation Administration API.
DELETE http://<host>:<port>/mfpadmin/management-apis/2.0/runtimes/<runtime>/adapterGroupConfig
For example,
curl -X DELETE --user admin:admin --header 'Content-Type: application/json' "http://<host>:<port>/mfpadmin/management-apis/2.0/runtimes/mfp/adapterGroupConfig"
Define groups for adapter grouping
After you define and deploy the adapter group configuration, the next step is to create the groups. Add a runtime JNDI property called mfp.adaptergroup.name
with value as the group name, to make the Persistent Mobile Foundation nodes part of a group.
For example,
<jndiEntry jndiName="mfp/mfp.adaptergroup.name" value="finance"/>
In a farm topology, if you add the JNDI property mfp.adaptergroup.name
in the server.xml
of a farm node then that node becomes a part of the group mentioned in the JNDI. If the above JNDI property is not mentioned for a node then the default behavior is observed, which means all the adapters get deployed on that node.
If Group1 consists of node1, node2, node3, node4, and node5, then on all nodes the server.xml
should be modified to add the JNDI property with a value Group1
.
For example, Group1 = [node 1, node 2, node 3, node 4, node 5]
<jndiEntry jndiName="mfp/mfp.adaptergroup.name" value=”Group1”/>
Similarly, other groups can be defined.
Adapter deployment
After you deploy the adapter group configuration and define groups, subsequent resource adapter deployments will honor the rules mentioned in the adapter group configuration. If an adapter is in the list of adapters in a group, then the adapter is deployed only on those nodes of the group that is identified by the mfp.adaptergroup.name
JNDI property.
Some changes such as moving an adapter from one group to another group, for an already running Persistent Mobile Foundation instance, would require the restart of the Persistent Mobile Foundation instance on all the groups. However, adding a new adapter to the adapters list does not require the restart of the nodes.
Adapter call changes
To leverage the benefits of adapter grouping, the client side adapter calls needs to be changed to include the group information in the resource request URI. The URI will be of the form /adaptergroups/<groupname>/adapters/<adaptername>/<method>
.
For example,
adapterPath = new URI(“/adaptergroups/finance/adapters/SavingAccountAdapter/getBalance”);
WLResourceRequest request = new WLResourceRequest(adapterPath, WLResourceRequest.GET);
Including adapter group information in the URI informs the load balancer (as explained below) that the call should be routed to adapters running in the specified group.
Load Balancer changes
To get the adapter grouping to work, the main changes required are in the Load Balancer. Load Balancer should be configured to route the adapter calls to appropriate group based on the URI patterns.
Here is a sample load balancer configuration for HAProxy for a farm topology. In this configuration, the farm nodes host1 and host2 are configured to be part of group1, farm nodes host3 and host4 are configured to be part of group2 and farm node host5 is the default host. When the adapter call request reaches the HAProxy and if the url contains group1, the call is routed to host1 and host2. If the request url contains group2, the request is routed to host3 and host4. All the rest of the requests are routed to host5.
frontend localnodes
bind *:81
mode http
acl is_group1 url_sub group1
use_backend group1_server if is_group1
acl is_group2 url_sub group2
use_backend group2_server if is_group2
default_backend nodes
backend group1_server
mode http
balance roundrobin
option forwardfor
http-request set-header X-Forwarded-Port %[dst_port]
http-request add-header X-Forwarded-Proto https if { ssl_fc }
option httpchk HEAD / HTTP/1.1\r\nHost:localhost
server group1_server1 <host1>:<port> check
server group1_server2 <host2>:<port> check
backend group2_server
mode http
balance roundrobin
option forwardfor
http-request set-header X-Forwarded-Port %[dst_port]
http-request add-header X-Forwarded-Proto https if { ssl_fc }
option httpchk HEAD / HTTP/1.1\r\nHost:localhost
server group2_server1 <host3>:<port> check
server group2_server2 <host4>:<port> check
backend nodes
mode http
balance roundrobin
option forwardfor
http-request set-header X-Forwarded-Port %[dst_port]
http-request add-header X-Forwarded-Proto https if { ssl_fc }
option httpchk HEAD / HTTP/1.1\r\nHost:localhost
server default_server <host5>:<port> check
▲Note: Adapter Grouping feature is not enabled via Persistent Mobile Foundation console. The deployment of adapter group configuration can only be done through Persistent Mobile Foundation Administration Service APIs.