Configuring PMF Server
Overview
Consider your backup and recovery policy, optimize your Persistent Mobile Foundation Server configuration, and apply access restrictions and security options.
Jump to
- Endpoints of Persistent Mobile Foundation Server production server
- Configuring Persistent Mobile Foundation Server to enable TLS V1.2
- Configuring user authentication for Persistent Mobile Foundation Server administration
- List of JNDI properties of the Persistent Mobile Foundation Server web applications
- Configuring data sources
- Configuring logging and monitoring mechanisms
- Configuring multiple runtimes
- Configuring license tracking
- WebSphere Application Server SSL configuration and HTTP adapters
Endpoints of the Persistent Mobile Foundation Server production server
You can create allowlists and blocklists for the endpoints of the Persistent Mobile Foundation Server.
Note: Information regarding URLs that are exposed by PMF is provided as a guideline. Organizations must ensure the URLs are tested in an enterprise infrastructure, based on what has been enabled for allow and block lists.
API URL under <runtime context root>/api/ |
Description | Suggested for allowlist? |
---|---|---|
/adapterdoc/* | Return the adapter’s Swagger documentation for the named adapter | No. Used only internally by the administrator and the developers |
/adapters/* | Adapters serving | Yes |
/az/v1/authorization/* | Authorize the client to access a specific scope | Yes |
/az/v1/introspection | Introspect the client’s access token | No. This API is for confidential clients only. |
/az/v1/token | Generate an access token for the client | Yes |
/clientLogProfile/* | Get client log profile | Yes |
/directupdate/* | Get Direct Update .zip file | Yes, if you plan to use Direct Update |
/loguploader | Upload client logs to server | Yes |
/preauth/v1/heartbeat | Accept heartbeat from the client and note the last activity time | Yes |
/preauth/v1/logout | Log out from a security check | Yes |
/preauth/v1/preauthorize | Map and execute security checks for a specific scope | Yes |
/reach | The server is reachable | No, for internal use only |
/registration/v1/clients/* | Registration-service clients API | No. This API is for confidential clients only. |
/registration/v1/self/* | Registration-service client self-registration API | Yes |
Configuring Persistent Mobile Foundation Server to enable TLS V1.2
For Persistent Mobile Foundation Server to communicate with devices that support only Transport Layer Security v1.2 (TLS) V1.2, among the SSL protocols, you must complete the following instructions.
The steps to configure Persistent Mobile Foundation Server to enable Transport Layer Security (TLS) V1.2 depend on how Persistent Mobile Foundation Server connects to devices.
- If Persistent Mobile Foundation Server is behind a reverse proxy that decrypts SSL-encoded packets from devices before it passes the packets to the application server, you must enable TLS V1.2 support on your reverse proxy. If you use IBM HTTP Server as your reverse proxy, see Securing IBM HTTP Server for instructions.
- If Persistent Mobile Foundation Server communicates directly with devices, the steps to enable TLS V1.2 depend on whether your application serveris Apache Tomcat, or WebSphere Application Server Liberty profile.
Apache Tomcat
- Confirm that the Java Runtime Environment (JRE) supports TLS V1.2.
Ensure that you have one of the following JRE versions:
- Oracle JRE 17.x or later
- Edit the conf/server.xml file and modify the
Connector
element that declares the HTTPS port so that the sslEnabledProtocols attribute has the following value:sslEnabledProtocols="TLSv1.2,TLSv1.1,TLSv1,SSLv2Hello"
.
WebSphere Application Server Liberty profile
- Confirm that the Java Runtime Environment (JRE) supports TLS V1.2.
- If you use an openJdk Java, ensure that you have one of the following versions:
- openJdk 17.x or later
- If you use an openJdk Java, ensure that you have one of the following versions:
Configuring user authentication for Persistent Mobile Foundation Server administration
Persistent Mobile Foundation Server administration requires user authentication. You can configure user authentication and choose an authentication method. Then, the configuration procedure depends on the web application server that you use.
You must configure authentication after the installer deploys the Persistent Mobile Foundation Server administration web applications in the web application server.
The Persistent Mobile Foundation Server administration has the following Java Platform, Enterprise Edition (Java EE) security roles defined:
- mfpadmin
- mfpdeployer
- mfpoperator
- mfpmonitor
You must map the roles to the corresponding sets of users. The mfpmonitor role can view data but cannot change any data. The following tables list Persistent Mobile Foundation roles and functions for production servers.
Deployment
Administrator | Deployer | Operator | Monitor | |
---|---|---|---|---|
Java EE security role. | mfpadmin | mfpdeployer | mfpoperator | mfpmonitor |
Deploy an application. | Yes | Yes | No | No |
Deploy an adapter. | Yes | Yes | No | No |
Persistent Mobile Foundation Server management
Administrator | Deployer | Operator | Monitor | |
---|---|---|---|---|
Java EE security role. | mfpadmin | mfpdeployer | mfpoperator | mfpmonitor |
Configure runtime settings. | Yes | Yes | No | No |
Application management
Administrator | Deployer | Operator | Monitor | |
---|---|---|---|---|
Java EE security role. | mfpadmin | mfpdeployer | mfpoperator | mfpmonitor |
Upload new PMF application. | Yes | Yes | No | No |
Remove PMF application. | Yes | Yes | No | No |
Upload new adapter. | Yes | Yes | No | No |
Remove adapter. | Yes | Yes | No | No |
Turn on or off application authenticity testing for an application. | Yes | Yes | No | No |
Change properties on PMF application status: Active, Active Notifying, and Disabled. | Yes | Yes | Yes | No |
Basically, all roles can issue GET requests, the mfpadmin, mfpdeployer, and mfpmonitor roles can also issue POST and PUT requests, and the mfpadmin and mfpdeployer roles can also issue DELETE requests.
Requests related to push notifications
Administrator | Deployer | Operator | Monitor | |
---|---|---|---|---|
Java EE security role. | mfpadmin | mfpdeployer | mfpoperator | mfpmonitor |
GET requests
|
Yes | Yes | Yes | Yes |
POST and PUT requests
|
Yes | Yes | Yes | No |
DELETE requests
|
Yes | Yes | No | No |
Disabling
Administrator | Deployer | Operator | Monitor | |
---|---|---|---|---|
Java EE security role. | mfpadmin | mfpdeployer | mfpoperator | mfpmonitor |
Disable the specific device, marking the state as lost or stolen so that access from any of the applications on that device is blocked. | Yes | Yes | Yes | No |
Disable a specific application, marking the state as disabled so that access from the specific application on that device is blocked. | Yes | Yes | Yes | No |
If you choose to use an authentication method through a user repository such as LDAP, you can configure the Persistent Mobile Foundation Server administration so that you can use users and groups with the user repository to define the Access Control List (ACL) of the Persistent Mobile Foundation Server administration. This procedure depends on the type and version of the web application server that you use.
Configuring WebSphere Application Server Liberty profile for Persistent Mobile Foundation Server administration
In WebSphere Application Server Liberty profile, you configure the roles of mfpadmin, mfpdeployer, mfpmonitor, and mfpoperator in the server.xml configuration file of the server.
To configure the security roles, you must edit the server.xml file. In the <application-bnd>
element of each <application>
element, create <security-role>
elements. Each <security-role>
element is for each roles: mfpadmin, mfpdeployer, mfpmonitor, and mfpoperator. Map the roles to the appropriate user group name, in this example: mfpadmingroup, mfpdeployergroup, mfpmonitorgroup, or mfpoperatorgroup. These groups are defined through the <basicRegistry>
element. You can customize this element or replace it entirely with an <ldapRegistry>
element or a <safRegistry>
element.
Then, to maintain good response times with a large number of installed applications, for example with 80 applications, you should configure a connection pool for the administration database.
-
Edit the server.xml file. For example:
<security-role name="mfpadmin"> <group name="mfpadmingroup"/> </security-role> <security-role name="mfpdeployer"> <group name="mfpdeployergroup"/> </security-role> <security-role name="mfpmonitor"> <group name="mfpmonitorgroup"/> </security-role> <security-role name="mfpoperator"> <group name="mfpoperatorgroup"/> </security-role> <basicRegistry id="mfpadmin"> <user name="admin" password="admin"/> <user name="guest" password="guest"/> <user name="demo" password="demo"/> <group name="mfpadmingroup"> <member name="guest"/> <member name="demo"/> </group> <group name="mfpdeployergroup"> <member name="admin" id="admin"/> </group> <group name="mfpmonitorgroup"/> <group name="mfpoperatorgroup"/> </basicRegistry>
-
Define the AppCenterPool size:
<connectionManager id="AppCenterPool" minPoolSize="10" maxPoolSize="40"/>
-
In the
<dataSource>
element, define a reference to the connection manager:<dataSource id="MFPADMIN" jndiName="mfpadmin/jdbc/mfpAdminDS" connectionManagerRef="AppCenterPool"> ... </dataSource>
Configuring Apache Tomcat for Persistent Mobile Foundation Server administration
You must configure the Java EE security roles for the Persistent Mobile Foundation Server administration on the Apache Tomcat web application server.
-
If you installed the Persistent Mobile Foundation Server administration manually, declare the following roles in the conf/tomcat-users.xml file:
<role rolename="mfpadmin"/> <role rolename="mfpmonitor"/> <role rolename="mfpdeployer"/> <role rolename="mfpoperator"/>
-
Add roles to the selected users, for example:
<user name="admin" password="admin" roles="mfpadmin"/>
-
You can define the set of users as described in the Apache Tomcat documentation, Realm Configuration HOW-TO.
List of JNDI properties of the Persistent Mobile Foundation Server web applications
Configure the JNDI properties for the Persistent Mobile Foundation Server web applications that are deployed to the application server.
- Setting up JNDI properties for Persistent Mobile Foundation Server web applications
- List of JNDI properties for Persistent Mobile Foundation Server administration service
- List of JNDI properties for Persistent Mobile Foundation Server config service
- List of JNDI properties for Persistent Mobile Foundation Server live update service
- List of JNDI properties for PMF runtime
- List of JNDI properties for Persistent Mobile Foundation Server push service
- List of JNDI properties for Persistent Mobile Foundation Server liveupdate service
Setting up JNDI properties for Persistent Mobile Foundation Server web applications
Set up JNDI properties to configure the Persistent Mobile Foundation Server web applications that are deployed to the application server.
Set the JNDI environment entries in one of the following ways:
-
Configure the server environment entries. The steps to configure the server environment entries depends on which application server you use:
-
WebSphere Application Server Liberty:
In liberty_install_dir/usr/servers/serverName, edit the server.xml file, and declare the JNDI properties as follows:
<application id="app_context_root" name="app_context_root" location="app_war_name.war" type="war"> ... </application> <jndiEntry jndiName="app_context_root/JNDI_property_name" value="JNDI_property_value" />
The context root (in the previous example: app_context_root) connects between the JNDI entry and a specific PMF application. If multiple PMF applications exist on the same server, you can define specific JNDI entries for each application by using the context path prefix.
Note: Some properties are defined globally on WebSphere Application Server Liberty, without prefixing the property name by the context root. For a list of these properties, see Global JNDI entries.
For all other JNDI properties, the names must be prefixed with the context root of the application:
- For the config service, the context root must be /[adminContextRoot]config. For example, if the context root of the administration service is /mfpadmin, then the context root of the config service must be /mfpadminconfig.
- For the push service, you must define the context root as /imfpush. Otherwise, the client devices cannot connect to it as the context root is hardcoded in the SDK.
- For the liveupdate service, you must define the context root as /mfpliveupdate. Otherwise, the client devices cannot connect to it as the context root is hardcoded in the SDK.
- For the PMF Administration Service application, the PMF Operations Console and PMF runtime, you can define the context root as you want. However, by default it is /mfpadmin for PMF Administration Service, /mfpconsole for PMF Operations Console, and /mfp for PMF runtime.
For example:
<application id="mfpadmin" name="mfpadmin" location="mfp-admin-service.war" type="war"> ... </application> <jndiEntry jndiName="mfpadmin/mfp.admin.actions.prepareTimeout" value = "2400000" />
-
Apache Tomcat:
In tomcat_install_dir/conf, edit the server.xml file, and declare the JNDI properties as follows:
<Context docBase="app_context_root" path="/app_context_root"> <Environment name="JNDI_property_name" override="false" type="java.lang.String" value="JNDI_property_value"/> </Context>
- The context path prefix is not needed because the JNDI entries are defined inside the
<Context>
element of an application. override="false"
is mandatory.- The
type
attribute is alwaysjava.lang.String
, unless specified differently for the property.
For example:
<Context docBase="app_context_root" path="/app_context_root"> <Environment name="mfp.admin.actions.prepareTimeout" override="false" type="java.lang.String" value="2400000"/> </Context>
- The context path prefix is not needed because the JNDI entries are defined inside the
-
-
If you install with Ant tasks, you can also set the values of the JNDI properties at installation time.
In pmf_install_dir/MobileFoundationServer/configuration-samples, edit the configuration XML file for the Ant tasks, and declare the values for the JNDI properties by using the property element inside the following tags:
<installpmfadmin>
, for Persistent Mobile Foundation Server administration, PMF Operations Console, and config services. For more information, see Ant tasks for installation of PMF Operations Console, Persistent Mobile Foundation Server artifacts, Persistent Mobile Foundation Server administration, and config services.<installpmfruntime>
, for PMF runtime configuration properties. For more information, see Ant tasks for installation of PMF runtime environments.<installpmfpush>
, for configuration of the push service. For more information, see Ant tasks for installation of Persistent Mobile Foundation Server push service.
For example:
<installpmfadmin ..> <property name = "mfp.admin.actions.prepareTimeout" value = "2400000" /> </installpmfadmin>
List of JNDI properties for Persistent Mobile Foundation Server administration service
When you configure Persistent Mobile Foundation Server administration service and PMF Operations Console for your application server, you set optional or mandatory JNDI properties, in particular for Java Management Extensions (JMX).
The following properties can be set on the administration service web application mfp-admin-service.war.
JNDI properties for administration service: JMX
Property | Optional or mandatory | Description | Restrictions |
---|---|---|---|
mfp.admin.jmx.host | Optional | Host name for the JMX REST connection. | Liberty profile only. |
mfp.admin.jmx.port | Optional | Port for the JMX REST connection. | Liberty profile only. |
mfp.admin.jmx.user | Mandatory for the Liberty profile | User name for the JMX REST connection. | WebSphere Application Server Liberty profile: The user name for the JMX REST connection. WebSphere Application Server farm: the user name for the SOAP connection. Liberty collective: the user name of the controller administrator that is defined in the <administrator-role> element of the server.xml file of the Liberty controller. |
mfp.admin.jmx.pwd | Mandatory for the Liberty profile and for WebSphere Application Server farm, optional otherwise | User password for the JMX REST connection. | WebSphere Application Server Liberty profile: the user password for the JMX REST connection. WebSphere Application Server farm: the user password for the SOAP connection. Liberty collective: the password of the controller administrator that is defined in the <administrator-role> element of the server.xml file of the Liberty controller. |
mfp.admin.rmi.registryPort | Optional | RMI registry port for the JMX connection through a firewall. | Tomcat only. |
mfp.admin.rmi.serverPort | Optional | RMI server port for the JMX connection through a firewall. | Tomcat only. |
mfp.admin.enable.adapter.generation | Optional | The JNDI property enables the adapter generation feature , allowing for the automatic creation of adapters that connect mobile applications to back-end services. This feature is particularly useful for rapidly developing and managing adapters, maintaining consistency across environments, and reducing manual configuration efforts. | Liberty only. |
JNDI properties for administration service: timeout
Property | Optional or mandatory | Description |
---|---|---|
mfp.admin.actions.prepareTimeout | Optional | Timeout in milliseconds to transfer data from the adminstration service to the runtime during a deployment transaction. If the runtime cannot be reached within this time, an error is raised and the deployment transaction ends. Default value: 1800000 ms (30 min) |
mfp.admin.actions.commitRejectTimeout | Optional | Timeout in milliseconds, when a runtime is contacted, to commit or reject a deployment transaction. If the runtime cannot be reached within this time, an error is raised and the deployment transaction ends. Default value: 120000 ms (2 min) |
mfp.admin.lockTimeoutInMillis | Optional | Timeout in milliseconds for obtaining the transaction lock. Because deployment transactions run sequentially, they use a lock. Therefore, a transaction must wait until a previous transaction is finished. This timeout is the maximal time during which a transaction waits. Default value: 1200000 ms (20 min) |
mfp.admin.maxLockTimeInMillis | Optional | The maximal time during which a process can take the transaction lock. Because deployment transactions run sequentially, they use a lock. If the application server fails while a lock is taken, it can happen in rare situations that the lock is not released at the next restart of the application server. In this case, the lock is released automatically after the maximum lock time so that the server is not blocked forever. Set a time that is longer than a normal transaction. Default value: 1800000 (30 min) |
JNDI properties for administration service: logging
Property | Optional or mandatory | Description |
---|---|---|
mfp.admin.logging.formatjson | Optional | Set this property to true to enable pretty formatting (extra blank space) of JSON objects in responses and log messages. Setting this property is helpful when you debug the server. Default value: false. |
mfp.admin.logging.tosystemerror | Optional | Specifies whether all logging messages are also directed to System.Error. Setting this property is helpful when you debug the server. |
JNDI properties for administration service: proxies
Property | Optional or mandatory | Description |
---|---|---|
mfp.admin.proxy.port | Optional | If the PMF administration server is behind a firewall or reverse proxy, this property specifies the address of the host. Set this property to enable a user outside the firewall to reach the PMF administration server. Typically, this property is the port of the proxy, for example 443. It is necessary only if the protocol of the external and internal URIs are different. |
mfp.admin.proxy.protocol | Optional | If the PMF administration server is behind a firewall or reverse proxy, this property specifies the protocol (HTTP or HTTPS). Set this property to enable a user outside the firewall to reach the PMF administration server. Typically, this property is set to the protocol of the proxy. For example, wl.net. This property is necessary only if the protocol of the external and internal URIs are different. |
mfp.admin.proxy.scheme | Optional | This property is just an alternative name for mfp.admin.proxy.protocol. |
mfp.admin.proxy.host | Optional | If the PMF administration server is behind a firewall or reverse proxy, this property specifies the address of the host. Set this property to enable a user outside the firewall to reach the PMF administration server. Typically, this property is the address of the proxy. |
JNDI properties for administration service: topologies
Property | Optional or mandatory | Description |
---|---|---|
mfp.admin.audit | Optional. | Set this property to false to disable the audit feature of the PMF Operations Console. The default value is true. |
mfp.admin.environmentid | Optional. | The environment identifier for the registration of the MBeans. Use this identifier when different instances of the Persistent Mobile Foundation Server are installed on the same application server. The identifier determines which administration service, which console, and which runtimes belong to the same installation. The administration service manages only the runtimes that have the same environment identifier. |
mfp.admin.serverid | Mandatory for server farms and Liberty collective, optional otherwise. | Server farm: the server identifier. Must be different for each server in the farm. Liberty collective: the value must be controller. |
mfp.admin.hsts | Optional. | Set to true to enable HTTP Strict Transport Security according to RFC 6797. |
mfp.topology.platform | Optional | Server type. Valid values:
|
mfp.topology.clustermode | Optional | In addition to the server type, specify here the server topology. Valid values:
|
mfp.admin.farm.heartbeat | Optional | This property enables you to set in minutes the heartbeat rate that is used in server farm topologies. The default value is 2 minutes. In a server farm, all members must use the same heartbeat rate. If you set or change this JNDI value on one server in the farm, you must also set the same value on every other server in the farm. For more information, see Lifecycle of a server farm node. |
mfp.admin.farm.missed.heartbeats.timeout | Optional | This property enables you to set the number of missed heartbeats of a farm member before the status of the farm member is considered to be failed or down. The default value is 2. In a server farm all members must use the same missed heartbeat value. If you set or change this JNDI value on one server in the farm, you must also set the same value on every other server in the farm. For more information, see Lifecycle of a server farm node. |
mfp.admin.farm.reinitialize | Optional | A Boolean value (true or false) for re-registering or re-initializing the farm member. |
mfp.server.swagger.ui.url | Optional | This property defines the URL of the Swagger user interface to be displayed in the administration console. |
JNDI properties for administration service: relational database
Property | Optional or mandatory | Description |
---|---|---|
mfp.admin.db.jndi.name | Optional | The JNDI name of the database. This parameter is the normal mechanism to specify the database. The default value is java:comp/env/jdbc/mfpAdminDS. |
mfp.admin.db.openjpa.ConnectionDriverName | Optional/Conditionally mandatory | The fully qualified name of the database connection driver class. Mandatory only when the data source that is specified by the mfp.admin.db.jndi.name property is not defined in the application server configuration. |
mfp.admin.db.openjpa.ConnectionURL | Optional/Conditionally mandatory | The URL for the database connection. Mandatory only when the data source that is specified by the mfp.admin.db.jndi.name property is not defined in the application server configuration. |
mfp.admin.db.openjpa.ConnectionUserName | Optional/Conditionally mandatory | The user name for the database connection. Mandatory only when the data source that is specified by the mfp.admin.db.jndi.name property is not defined in the application server configuration. |
mfp.admin.db.openjpa.ConnectionPassword | Optional/Conditionally mandatory | The password for the database connection. Mandatory only when the data source that is specified by the mfp.admin.db.jndi.name property is not defined in the application server configuration. |
mfp.admin.db.openjpa.Log | Optional | This property is passed to OpenJPA and enables JPA logging. For more information, see the Apache OpenJPA User’s Guide. |
mfp.admin.db.type | Optional | This property defines the type of database. The default value is inferred from the connection URL. |
JNDI properties for administration service: licensing
Property | Optional or mandatory | Description |
---|---|---|
mfp.admin.license.key.server.host |
|
Host name of the Rational License Key Server. |
mfp.admin.license.key.server.port |
|
Port number of the Rational License Key Server. |
JNDI properties for administration service: JNDI configurations
Property | Optional or mandatory | Description |
---|---|---|
mfp.jndi.configuration | Optional | The name of the JNDI configuration if the JNDI properties (except this one) must be read from a property file that is injected into the WAR file. If you do not set this property, JNDI properties are not read from a property file. |
mfp.jndi.file | Optional | The name of the file that contains the JNDI configuration if the JNDI properties (except this one) must be read from a file installed in the web server. If you do not set this property, JNDI properties are not read from a property file. |
The administration service uses a config service as an auxiliary facility to store various configurations. Use these properties to configure how to reach the config service.
JNDI properties for administration service: config service
Property | Optional or mandatory | Description |
---|---|---|
mfp.config.service.url | Optional The URL of the config service. The default URL is derived from the URL of administration service by adding config to the context root of the administration service. | |
mfp.config.service.user | Mandatory | The user name that is used to access the config service. In a server farm topology, the user name must be the same for all the members of the farm. |
mfp.config.service.password | Mandatory | The password that is used to access the config service. In a server farm topology, the password must be the same for all the members of the farm. |
mfp.config.service.schema | Optional | The name of the schema that is used by the config service. |
The administration service uses a push/liveupdate service as an auxiliary facility to store various push/liveupdate settings. Use these properties to configure how to reach the push/liveupdate service. Because the push/liveupdate service is protected by the OAuth security model, you must set various properties to enable confidential clients in OAuth.
JNDI properties for administration service: push service
Property | Optional or mandatory | Description |
---|---|---|
mfp.admin.push.url | Optional | The URL of the push service. If the property is not specified, the push service is considered disabled. If the property is not properly set, the administration service cannot contact the push service and the administration of push services in PMF Operations Console does not work. |
mfp.admin.authorization.server.url | Optional | The URL of the OAuth authorization server that is used by the push service. The default URL is derived from the URL of the administration service by changing the context root to the context root of the first installed runtime. If you install multiple runtimes, it is best to set the property. If the property is not set properly, the administration service cannot contact the push service and the administration of push services in PMF Operations Console does not work. |
mfp.push.authorization.client.id | Optional/conditionally mandatory | The identifier of the confidential client that handles OAuth authorization for the push service. Mandatory only if the mfp.admin.push.url property is specified. |
mfp.push.authorization.client.secret | Optional/conditionally mandatory | The secret of the confidential client that handles OAuth authorization for the push service. Mandatory only if the mfp.admin.push.url property is specified |
mfp.admin.authorization.client.id | Optional/conditionally mandatory | The identifier of the confidential client that handles OAuth authorization for the administration service. Mandatory only if the mfp.admin.push.url property is specified. |
mfp.admin.authorization.client.secret | Optional/conditionally mandatory | The secret of the confidential client that handles OAuth authorization for the administration service. Mandatory only if the mfp.admin.push.url property is specified. |
JNDI properties for administration service: liveupdate service
Property | Optional or mandatory | Description |
---|---|---|
mfp.admin.liveupdate.url | Optional | The URL of the liveupdate service. If the property is not specified, the liveupdate service is considered disabled. If the property is not properly set, the administration service cannot contact the liveupdate service and the administration of liveupdate services in PMF Operations Console does not work. |
mfp.admin.authorization.server.url | Optional | The URL of the OAuth authorization server that is used by the liveupdate service. The default URL is derived from the URL of the administration service by changing the context root to the context root of the first installed runtime. If you install multiple runtimes, it is best to set the property. If the property is not set properly, the administration service cannot contact the liveupdate service and the administration of liveupdate services in PMF Operations Console does not work. |
mfp.liveupdate.authorization.client.id | Optional/conditionally mandatory | The identifier of the confidential client that handles OAuth authorization for the liveupdate service. Mandatory only if the mfp.admin.liveupdate.url property is specified. |
mfp.liveupdate.authorization.client.secret | Optional/conditionally mandatory | The secret of the confidential client that handles OAuth authorization for the liveupdate service. Mandatory only if the mfp.admin.liveupdate.url property is specified |
mfp.admin.authorization.client.id | Optional/conditionally mandatory | The identifier of the confidential client that handles OAuth authorization for the administration service. Mandatory only if the mfp.admin.liveupdate.url property is specified. |
mfp.admin.authorization.client.secret | Optional/conditionally mandatory | The secret of the confidential client that handles OAuth authorization for the administration service. Mandatory only if the mfp.admin.liveupdate.url property is specified. |
JNDI properties for PMF Operations Console
The following properties can be set on the web application (mfp-admin-ui.war) of PMF Operations Console.
Property | Optional or mandatory | Description |
---|---|---|
mfp.admin.endpoint | Optional | Enables the PMF Operations Console to locate the Persistent Mobile Foundation Server administration REST service. Specify the external address and context root of the mfp-admin-service.war web application. In a scenario with a firewall or a secured reverse proxy, this URI must be the external URI and not the internal URI inside the local LAN. For example, https://wl.net:443/mfpadmin. |
mfp.admin.hsts | Optional | Set this property to true to enable HTTP Strict Transport Security according to RFC 6797. For more information, see the W3C Strict Transport Security page. The default value is false. |
mfp.admin.ui.cors | Optional | The default value is true. For more information, see the W3C Cross-Origin Resource Sharing page. |
mfp.admin.ui.cors.strictssl | Optional | Set to false to allow CORS situations where the PMF Operations Console is secured with SSL (HTTPS protocol) while the Persistent Mobile Foundation Server administration service is not, or conversely. This property takes effect only if the mfp.admin.ui.cors property is enabled. |
List of JNDI properties for Persistent Mobile Foundation Server live update service
When you configure the Persistent Mobile Foundation Server live update service for your application server, you can set the following JNDI properties. The table lists the JNDI properties for the relational database live update service.
Property | Optional or mandatory | Description |
---|---|---|
mfp.db.relational.queryTimeout | Optional | Timeout for executing a query in RDBMS, in seconds. A value of zero means an infinite timeout. A negative value means the default (no override). In case no value is configured, a default value is used. For more information, see setQueryTimeout. |
List of JNDI properties for Persistent Mobile Foundation Server config service
When you configure the Persistent Mobile Foundation Server config service for your application server, you can set the following JNDI properties. The table lists the JNDI properties for the IBM relational database config service.
Property | Optional or mandatory | Description |
---|---|---|
mfp.db.relational.queryTimeout | Optional | Timeout for executing a query in RDBMS, in seconds. A value of zero means an infinite timeout. A negative value means the default (no override). In case no value is configured, a default value is used. For more information, see setQueryTimeout. |
To know how to set those properties, see Setting up JNDI properties for Persistent Mobile Foundation Server web applications.
List of JNDI properties for PMF runtime
When you configure the Persistent Mobile Foundation Server runtime for your application server, you need to set the optional or mandatory JNDI properties.
The following table lists the PMF properties that are always available as JNDI entries:
Property | Description |
---|---|
mfp.scheduler.startHour | Optional. Scheduler run can be set for any time of customer’s choice instead of the default 1 AM. This property can take a value from 1 to 23. This property will ensure that the customer can configure their scheduler to start at a time when their traffic is light and also can ensure the scheduler runs despite the daily start of the server. Important Note: The value configured should have 4 hours difference with the server start time. Scheduler will skip its run, if the scheduler start time is within 4 hours of the server start and will schedule to run for same time next day. |
mfp.admin.jmx.host | Liberty only. The host name for the JMX REST connection. For Liberty collective, use the host name of the controller. |
mfp.admin.jmx.port | Liberty only. The port number for the JMX REST connection. For Liberty collective, the port of the REST connector must be identical to the value of the httpsPort attribute that is declared in the <httpEndpoint> element. This element is declared in the server.xml file of the Liberty controller. |
mfp.admin.jmx.user | Optional. WebSphere Application Server farm: the user name of the SOAP connection. Liberty collective: the user name of the controller administrator that is defined in the <administrator-role> element of the server.xml file of the Liberty controller. |
mfp.admin.jmx.pwd | Optional. WebSphere Application Server farm: the user passsword of the SOAP connection. Liberty collective: the password of the controller administrator that is defined in the <administrator-role> element of the server.xml file of the Liberty controller. |
mfp.admin.serverid | Mandatory for server farms and Liberty collective, optional otherwise. Server farm: the server identifier. Must be different for each server in the farm. Liberty collective: the member identifier. The identifier must be different for each member in the collective. The value controller cannot be used as it is reserved for the collective controller. |
mfp.topology.platform | Optional. The server type. Valid values are:<ul><li>Liberty</li><li>Tomcat</li></ul>If you do not set the value, the application tries to guess the server type. |
mfp.topology.clustermode | Optional. In addition to the server type, specify here the server topology. Valid values:<ul><li>Standalone<li>Cluster</li><li>Farm</li></ul>The default value is Standalone. |
mfp.admin.jmx.replica | Optional. For Liberty collective only. Set this property only when the administration components that manage this runtime are deployed in different Liberty controllers (replicas). Endpoint list of the different controller replicas with the following syntax: replica-1 hostname:replica-1 port, replica-2 hostname:replica-2 port,..., replica-n hostname:replica-n port |
mfp.analytics.console.url | Optional. The URL that is exposed by Persistent Persistent Mobile Foundation Analytics that links to the Analytics console. Set this property if you want to access the Analytics console from the PMF Operations Console. For example, http://<hostname>:<port>/analytics/console |
mfp.analytics.password | The password that is used if the data entry point for the Persistent Persistent Mobile Foundation Analytics is protected with basic authentication. |
mfp.analytics.url | The URL that is exposed by the Persistent Persistent Mobile Foundation Analytics that receives incoming analytics data. For example, http://<hostname>:<port>/analytics-service/rest |
mfp.analytics.username | The user name that is used if the data entry point for the Persistent Persistent Mobile Foundation Analytics is protected with basic authentication. |
mfp.analytics.event.qsize | Optional. Size of analytic event queue size. It should be added with caution by providing ample JVM heap size. Default queue size 10000 |
mfp.device.decommissionProcessingInterval | Defines how often (in seconds) the decommissioning task is executed. Default: 86400, which is one day. |
mfp.analytics.receiver.password | The password that is used if the data entry point for the Persistent Persistent Mobile Foundation Analytics Receiver is protected with basic authentication. |
mfp.analytics.receiver.url | The URL that is exposed by the Persistent Persistent Mobile Foundation Analytics Receiver that receives incoming analytics data. For example, http://<hostname>:<port>/analytics-receiver/rest |
mfp.analytics.receiver.username | The user name that is used if the data entry point for the Persistent Persistent Mobile Foundation Analytics Receiver is protected with basic authentication. |
mfp.device.decommissionProcessingInterval | Defines how often (in seconds) the decommissioning task is executed. Default: 86400, which is one day. |
mfp.device.decommission.when | The number of days of inactivity after which a client device is decommissioned by the device decommissioning task. Default: 90 days. |
mfp.device.archiveDecommissioned.when | The number of days of inactivity, after which a client device that has been decommissioned is archived. This task writes the client devices that were decommissioned to an archive file. The archived client devices are written to a file in the Persistent Mobile Foundation Server home\devices_archive directory. The name of the file contains the time stamp when the archive file is created. Default: 90 days. |
mfp.licenseTracking.enabled | A value that is used to enable or disable device tracking in PMF. For performance reasons, you can disable device tracking when PMF runs only Business-to-Consumer (B2C) apps. When device tracking is disabled, the license reports are also disabled and no license metrics are generated. Possible values are true (default) and false. |
mfp.runtime.temp.folder | Defines the runtime temporary files folder. Uses the default temporary folder location of the web container when not set. |
mfp.adapter.invocation.url | The URL to be used for invoking adapter procedures from inside Java adapters, or JavaScript adapters that are invoked using the rest endpoint. If this property is not set, the URL of the currently executing request will be used (this is the default behavior). This value should contain the full URL, including the context root. |
mfp.authorization.server | Authorization-server mode. Can be one of the following mode:
|
mfp.external.authorization.server.secret | Secret of the external authorization server. This property is required when using an external authorization server, meaning mfp.authorization.server is set to external and is ignored otherwise. |
mfp.external.authorization.server.introspection.url | URL of the introspection endpoint of the external authorization server. This property is required when using an external authorization server, meaning mfp.authorization.server is set to external and is ignored otherwise. |
ssl.websphere.config | Used to configure the keystore for an HTTP adapter. When set to false (default), instructs the PMF runtime to use the PMF keystore. When set to true, instructs the PMF runtime to use the WebSphere SSL configuration. For more information, see WebSphere Application Server SSL configuration and HTTP adapters. |
mfp.purgedata.enabled | A value that is used to enable or disable expired records purge in Persistent Mobile Foundation runtime tables. Default is true in liberty. |
mfp.purgeOldData.age | When this property is set to a value greater than 0, records from MFP_PERSISTENT_DATA with last_activity_time field value prior to the given number of days is removed. This property is applicable only if mfp.purgedata.enabled is true. The records are archived into Persistent Mobile Foundation Server home\devices_archive directory. Do not have this property value less than 90. |
List of JNDI properties for Persistent Mobile Foundation Server push service
Property | Optional or mandatory | Description |
---|---|---|
mfp.push.db.type | Optional | Database type. Possible values: DB, CLOUDANT. Default: DB |
mfp.push.db.queue.connections | Optional | Number of threads in the thread pool that does the database operation. Default: 3 |
mfp.push.db.cloudant.url | Optional | The Cloudant account URL. When this property is defined, the Cloudant DB will be directed to this URL. |
mfp.push.db.cloudant.dbName | Optional | The name of the database in the Cloudant account. It must start with a lowercase letter and consist only of lowercase letters, digits, and the characters _, $, and -. Default: mfp_push_db |
mfp.push.db.cloudant.username | Optional | The user name of the Cloudant account, used to store the database. when this property is not defined, a relational database is used. |
mfp.push.db.cloudant.password | Optional | The password of the Cloudant account, used to store the database. This property must be set when mfp.db.cloudant.username is set. |
mfp.push.db.cloudant.doc.version | Optional | The Cloudant document version. |
mfp.push.db.cloudant.socketTimeout | Optional | A timeout for detecting the loss of a network connection for Cloudant, in milliseconds. A value of zero means an infinite timeout. A negative value means the default (no override). Default. See https://github.com/cloudant/java-cloudant#advanced-configuration. |
mfp.push.db.cloudant.connectionTimeout | Optional | A timeout for establishing a network connection for Cloudant, in milliseconds. A value of zero means an infinite timeout. A negative value means the default (no override). Default. See https://github.com/cloudant/java-cloudant#advanced-configuration. |
mfp.push.db.cloudant.maxConnections | Optional | The Cloudant connector’s max connections. Default. See https://github.com/cloudant/java-cloudant#advanced-configuration. |
mfp.push.db.cloudant.ssl.authentication | Optional | A Boolean value (true or false) that specifies whether the SSL certificate chain validation and host name verification are enabled for HTTPS connections to the Cloudant database. Default: True |
mfp.push.db.cloudant.proxyHost | Optional | Cloudant connector’s proxy host. Default: See https://github.com/cloudant/java-cloudant#advanced-configuration. |
mfp.push.db.cloudant.proxyPort | Optional | Cloudant connector’s proxy port. Default: See https://github.com/cloudant/java-cloudant#advanced-configuration. |
mfp.push.services.ext.security | Optional | The security extension plugin. |
mfp.push.security.endpoint | Optional | The endpoint URL for the authorization server. |
mfp.push.security.user | Optional | The username to access the authorization server. |
mfp.push.security.password | Optional | The password to access the authorization server. |
mfp.push.services.ext.analytics | Optional | The analytics extension plugin. |
mfp.push.analytics.endpoint | Optional | The endpoint URL for the analytics server. |
mfp.push.analytics.user | Optional | The username to access the analytics server. |
mfp.push.analytics.password | Optional | The password to access the analytics server. |
mfp.push.analytics.events.notificationDispatch | Optional | The analytic event when the notification is about to be dispatched. Default: true |
mfp.push.internalQueue.maxLength | Optional | The length of the queue which holds the notification tasks before dispatch. Default: 200000 |
mfp.push.gcm.proxy.enabled | Optional | Shows whether Google GCM must be accessed through a proxy. Default: false |
mfp.push.gcm.proxy.protocol | Optional | Can be either http or https. |
mfp.push.gcm.proxy.host | Optional | GCM proxy host. Negative value means default port. |
mfp.push.gcm.proxy.port | Optional | GCM proxy port. Default: -1 |
mfp.push.gcm.proxy.user | Optional | Proxy user name, if the proxy requires authentication. Empty user name means no authentication. |
mfp.push.gcm.proxy.password | Optional | Proxy password, if the proxy requires authentication. |
mfp.push.gcm.connections | Optional | Push GCM max connections. Default : 10 |
mfp.push.apns.proxy.enabled | Optional | Shows whether APNs must be accessed through a proxy. Default: false |
mfp.push.apns.proxy.type | Optional | APNs proxy type. |
mfp.push.apns.proxy.host | Optional | APNs proxy host. |
mfp.push.apns.proxy.port | Optional | APNs proxy port. Default: -1 |
mfp.push.apns.proxy.user | Optional | Proxy user name, if the proxy requires authentication. Empty user name means no authentication. |
mfp.push.apns.proxy.password | Optional | Proxy password, if the proxy requires authentication. |
mfp.push.apns.connections | Optional | Push APNs max connections. Default : 3 |
mfp.push.apns.connectionIdleTimeout | Optional | APNs Idle Connection Timeout. Default : 0 seconds |
mfp.push.notification.db.fetch.delay | Optional | Customise delay in seconds between SELECT query batches for notifications. Default : 0 seconds |
mfp.push.apns.http2.enabled | Optional | Shows if HTTP/2 protocol is enabled Default : true |
List of JNDI properties for Persistent Mobile Foundation Server liveupdate service
When you configure the Persistent Mobile Foundation Server config service for your application server, you can set the following JNDI properties. The table lists the JNDI properties for the IBM relational database liveupdate service.
Property | Optional or mandatory | Description |
---|---|---|
mfp.liveupdate.db.relational.queryTimeout | Optional | Timeout for executing a query in RDBMS, in seconds. A value of zero means an infinite timeout. A negative value means the default (no override). In case no value is configured, a default value is used. For more information, see setQueryTimeout. |
mfp.liveupdate.db.cloudant.url | Optional | The Cloudant account URL. When this property is defined, the Cloudant DB will be directed to this URL. |
mfp.liveupdate.db.cloudant.dbName | Optional | The name of the database in the Cloudant account. It must start with a lowercase letter and consist only of lowercase letters, digits, and the characters _, $, and -. Default: mfp_liveupdate_db |
mfp.liveupdate.db.cloudant.username | Optional | The user name of the Cloudant account, used to store the database. when this property is not defined, a relational database is used. |
mfp.liveupdate.db.cloudant.password | Optional | The password of the Cloudant account, used to store the database. This property must be set when mfp.db.cloudant.username is set. |
mfp.liveupdate.db.cloudant.connectionTimeout | Optional | A timeout for establishing a network connection for Cloudant, in milliseconds. A value of zero means an infinite timeout. A negative value means the default (no override). Default. See https://github.com/cloudant/java-cloudant#advanced-configuration. |
Configuring data sources
Find out some data source configuration details pertaining to the supported databases.
- Managing the DB2 transaction log size
- Configuring DB2 HADR seamless failover for Persistent Mobile Foundation Server and Application Center data sources
- Handling stale connections
- Stale data after creating or deleting apps from PMF Operations Console
Managing the DB2 transaction log size
When you deploy an application that is at least 40 MB with Persistent PMF Operations Console, you might receive a transaction log full error.
The following system output is an example of the transaction log full error code.
DB2 SQL Error: SQLCODE=-964, SQLSTATE=57011
The content of each application is stored in the PMF administration database.
The active log files are defined in number by the LOGPRIMARY and LOGSECOND database configuration parameters, and in size by the LOGFILSIZ database configuration parameter. A single transaction cannot use more log space than LOGFILSZ * (LOGPRIMARY + LOGSECOND) * 4096 KB.
The DB2 GET DATABASE CONFIGURATION
command includes information about the log file size, and the number of primary and secondary log files.
Depending on the largest size of the PMF application that is deployed, you might need to increase the DB2 log space.
Using the DB2 update db cfg
command, increase the LOGSECOND parameter. Space is not allocated when the database is activated. Instead, the space is allocated only as needed.
Configuring DB2 HADR seamless failover for Persistent Mobile Foundation Server and Application Center data sources
You must enable the seamless failover feature with WebSphere Application Server Liberty profile. With this feature, you can manage an exception when a database fails over and gets rerouted by the DB2 JDBC driver.
Note: DB2 HADR failover is not supported for Apache Tomcat.
By default with DB2 HADR, when the DB2 JDBC driver performs a client reroute after detecting that a database failed over during the first attempt to reuse an existing connection, the driver triggers com.ibm.db2.jcc.am.ClientRerouteException, with ERRORCODE=-4498 and SQLSTATE=08506. WebSphere Application Server maps this exception to com.ibm.websphere.ce.cm.StaleConnectionException before it is received by the application.
In this case, the application would have to catch the exception and execute again the transaction. The PMF and Application Center runtime environments do not manage the exception but rely on a feature that is called seamless failover. To enable this feature, you must set the enableSeamlessFailover JDBC property to “1”.
WebSphere Application Server Liberty profile configuration
You must edit the server.xml file, and add the enableSeamlessFailover property to the properties.db2.jcc element of the PMF and Application Center data sources. For example:
<dataSource jndiName="jdbc/WorklightAdminDS" transactional="false">
<jdbcDriver libraryRef="DB2Lib"/>
<properties.db2.jcc databaseName="WLADMIN" currentSchema="WLADMSC"
serverName="db2server" portNumber="50000"
enableSeamlessFailover= "1"
user="worklight" password="worklight"/>
</dataSource>
For more information about how to configure a connection to an HADR-enabled DB2 database, see Setting up a connection to an HADR-enabled DB2 database.
Handling stale connections
Configure your application server to avoid database timeout issues.
A StaleConnectionException is an exception that is generated by the Java application server profile database connection code when a JDBC driver returns an unrecoverable error from a connection request or operation. The StaleConnectionException is raised when the database vendor issues an exception to indicate that a connection currently in the connection pool is no longer valid. This exception can happen for many reasons. The most common cause of StaleConnectionException is due to retrieving connections from the database connection pool and finding out that the connection has timed out or dropped when it was unused for a long time.
You can configure your application server to avoid this exception.
Apache Tomcat configuration
MySQL
The MySQL database closes its connections after a period of non-activity on a connection. This timeout is defined by the system variable called wait_timeout. The default is 28000 seconds (8 hours).
When an application tries to connect to the database after MySQL closes the connection, the following exception is generated:
com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after statement closed.
Edit the server.xml and context.xml files, and for every <Resource>
element add the following properties:
- testOnBorrow=”true”
- validationQuery=”select 1”
For example:
<Resource name="jdbc/AppCenterDS"
type="javax.sql.DataSource"
driverClassName="com.mysql.jdbc.Driver"
...
testOnBorrow="true"
validationQuery="select 1"
/>
WebSphere Application Server Liberty profile configuration
Edit the server.xml file and for every <dataSource>
element (runtime and Application Center databases) add a <connectionManager>
element with the agedTimeout property:
<connectionManager agedTimeout="timeout_value"/>
The timeout value depends mainly on the number of opened connections in parallel but also on the minimum and maximum number of the connections in the pool. Hence, you must tune the different connectionManager attributes to identify the most adequate values.
Note: MySQL in combination with WebSphere Application Server Liberty profile is not classified as a supported configuration.
Stale data after creating or deleting apps from PMF Operations Console
On a Tomcat 9 application server, if you use a MySQL database, some calls from PMF Operations Console to services return a 404 error.
On a Tomcat 9 application server, if you work with a MySQL database, when you use PMF Operations Console to delete an app, or add a new one, and try to refresh the console a couple of times, you might see stale data. For example, users might see an already deleted app in the list.
To avoid this problem, change the isolation level to READ_COMMITTED, either in the data source, or in the database management system.
For the meaning of READ_COMMITTED, see the MySQL documentation at http://dev.mysql.com/doc/refman/5.7/en/innodb-transaction-isolation-levels.html.
- To change the isolation level to READ_COMMITTED in the data source, modify the server.xml Tomcat configuration file: In the <Resource name=”jdbc/mfpAdminDS” …/> section, add the defaultTransactionIsolation=”READ_COMMITTED” attribute.
- To change the isolation level to READ_COMMITTED globally in the database management system, refer to the SET TRANSACTION Syntax page of the MySQL documentation at http://dev.mysql.com/doc/refman/5.7/en/set-transaction.html.
Note: MySQL in combination with WebSphere Application Server Liberty profile is not classified as a supported configuration.
Configuring logging and monitoring mechanisms
PMF reports errors, warnings, and informational messages into a log file. The underlying logging mechanism varies by application server.
Persistent Mobile Foundation Server
PMF (Persistent Mobile Foundation Server for short) uses the standard java.util.logging package. By default, all PMF logging goes to the application server log files. You can control Persistent Mobile Foundation Server logging by using the standard tools that are available in each application server. For example, if you want to activate trace logging in WebSphere Application Server Liberty, add a trace element to the server.xml file.
PMF logs all begin with com.ibm.mfp.
Application Center logs begin with com.ibm.puremeap.
For more information about the logging models of each application server, including the location of the log files, see the documentation for the relevant application server, as shown in the following table.
Application server | Location of documentation |
---|---|
Apache Tomcat | http://tomcat.apache.org/tomcat-9.0-doc/logging.html#Using_java.util.logging_(default) |
WebSphere Application Server Version Liberty profile | https://openliberty.io/docs/24.0.0.6/log-trace-configuration.html |
Log level mappings
Persistent Mobile Foundation Server uses the java.util.logging API. The logging levels map to the following levels:
- WL.Logger.debug: FINE
- WL.Logger.info: INFO
- WL.Logger.warn: WARNING
- WL.Logger.error: SEVERE
Back-end connectivity
To enable trace to monitor back-end connectivity, see the documentation for your specific application server platform in the table of section Persistent Mobile Foundation Server of this page. Use the com.ibm.mfp.server.js.adapter package and set the log level to FINEST.
Audit log for administration operations
PMF Operations Console stores an audit log for login, logout, and for all administration operations, such as deploying apps or adapters or locking apps. You can disable the audit log by setting the JNDI property mfp.admin.audit to false on the web application of the PMF administration service (mfp-admin-service.war).
When the audit log is enabled, you can download it from PMF Operations Console by clicking the Audit log link in the footer of the page.
Login and authentication issues
To diagnose login and authentication issues, enable the package com.ibm.mfp.server.security for trace and set the log level to FINEST.
Configuring multiple runtimes
You can configure Persistent Mobile Foundation Server with multiple runtimes, creating a visual differentiation between application “types” in the PMF Operations Console.
Jump to
- Configuring multiple runtimes in WebSphere Liberty profile
- Registering applications and deploying adapters to different runtimes
- Exporting and importing runtime configurations
Configuring multiple runtimes in WebSphere Liberty profile
-
Open the server.xml file of the application server. Typically located in the [application-server]/usr/servers/server-name/ folder. For example, with the PMF Developer Kit, the file can be found it [installation-folder]/mfp-server/usrs/servers/mfp/server.xml.
-
Add a second
application
element:<application id="second-runtime" name="second-runtime" location="mfp-server.war" type="war"> <classloader delegation="parentLast"> </classloader> </application>
-
Add a second set of JNDI entries:
<jndiEntry jndiName="second-runtime/mfp.analytics.url" value='"http://localhost:9080/analytics-service/rest"'/> <jndiEntry jndiName="second-runtime/mfp.analytics.console.url" value='"http://localhost:9080/analytics/console"'/> <jndiEntry jndiName="second-runtime/mfp.analytics.username" value='"admin"'/> <jndiEntry jndiName="second-runtime/mfp.analytics.password" value='"admin"'/> <jndiEntry jndiName="second-runtime/mfp.authorization.server" value='"embedded"'/>
-
Add a second
dataSource
element:<dataSource jndiName="second-runtime/jdbc/mfpDS" transactional="false"> <jdbcDriver libraryRef="DerbyLib"/> <properties.derby.embedded databaseName="${wlp.install.dir}/databases/second-runtime" user='"MFPDATA"'/> </dataSource>
Note:
- Make sure the
dataSource
is pointing to a different database schema. - Make sure you have created another database instance for the new runtime.
- In the development environment, add
createDatabase="create"
in theproperties.derby.embedded
child-element.
- Make sure the
-
Restart the application server.
Registering applications and deploying adapters to different runtimes
When a Persistent Mobile Foundation Server is configured with multiple runtimes, the registration of applications and deployment of adapters is slightly different.
- Registering and deploying from the PMF Operations Console
- Registering and deploying from the Command-line
Registering and deploying from the PMF Operations Console
When performing these actions in the PMF Operations Console, you now need to select the runtime to register or deploy to.
Registering and deploying from the Command-line
When performing these actions using the pmfdev command-line tool, you now need to add the runtime name to register or deploy to.
To register an application: pmfdev app register <server-name> <runtime-name>
.
pmfdev app register local second-runtime
To deploy an adapter: pmfdev adapter deploy <server-name> <runtime-name>
.
pmfdev adapter deploy local second-runtime
- local is the name of the default server definition in the PMF CLI. Replace local with a the server definition name you need to register or deploy to.
- runtime-name is the name of the runtime to register or deploy to.
Learn more with the following CLI help commands:
pmfdev help server add
pmfdev help app register
pmfdev help adapter deploy
Exporting and importing runtime configurations
You can export a runtime configuration and import it to another Persistent Mobile Foundation Server using the REST APIs of the Persistent Mobile Foundation Server administration service.
For example, you can setup a runtime configuration in a development environment, export its configuration and then import it to a testing environment for a quick set-up, and then further configure it for the specific needs of the testing environment.
Find out all available REST APIs in the API Reference.
Configuring license tracking
License tracking is enabled by default. Read the following topics to learn how you can configure license tracking.
Configuring license tracking for client device and addressable device
License tracking for client devices and addressable device is enabled by default. License reports are available in the PMF Operations Console. You can specify the following JNDI properties to change the default settings for license tracking.
You can specify the following JNDI properties to change the default settings for license tracking.
mfp.device.decommission.when
The number of days of inactivity after which a device is decommissioned by the device decommissioning task. License reports do not count decommissioned devices as active devices. The default value for the property is 90 days. Do not set a value lower than 30 days if your software is licensed by Client Device or by Addressable Device, or license reports might not be sufficient to prove compliance.
mfp.device.archiveDecommissioned.when
A value, in days, that defines when decommissioned devices are placed in an archive file when the decommissioning task is run. The archived devices are written to a file in the Persistent Persistent Mobile Foundation Server home\devices_archive directory. The name of the file contains the time stamp when the archive file is created. The default value is 90 days.
mfp.device.decommissionProcessingInterval
Defines how often (in seconds) the decommissioning task is run. Default: 86400, which is one day. The decommissioning task performs the following actions:
- Decommissions inactive devices, based on the mfp.device.decommission.when setting.
- Optionally, archives older decommissioned devices, based on the mfp.device.archiveDecommissioned.when setting.
- Generates the license tracking report.
mfp.licenseTracking.enabled
A value that is used to enable or disable license tracking in PMF. By default, license tracking is enabled. For performance reasons, you can disable this flag when PMF is not licensed by Client Device or by Addressable Device. When device tracking is disabled, the license reports are also disabled and no license metrics are generated.
For more information about specifying JNDI properties, see List of JNDI properties for PMF runtime.
WebSphere Application Server SSL configuration and HTTP adapters
By setting a property, you can let HTTP adapters benefit from WebSphere SSL configuration.
By default, HTTP adapters do not use WebSphere SSL by concatenating the Java Runtime Environment (JRE) truststore with the Persistent Mobile Foundation Server keystore, which is described in Configuring the Persistent Mobile Foundation Server keystore. Also see Configuring SSL between adapters and back-end servers by using self-signed certificates.
To have HTTP adapters use the WebSphere SSL configuration, set the ssl.websphere.config JNDI property to true. The setting has the following effects in order of precedence:
- Adapters running on WebSphere use the WebSphere keystore and not the Persistent Mobile Foundation Server keystore.
- If the ssl.websphere.alias property is set, the adapter uses the SSL configuration that is associated with the alias as set in this property.